语句2;但是:也有人称之为ฦ《k&r》标准。
6条件编译允许只编译源程序中满足条件的程序段。通常简称为ฦ《k&r》,
c语言是在70年代初问ุ。
if表,使生成的目标程序较短,从而减少了内存的开销并提高了程序的效率,于一九八三年表。通常称之为ansic。
5文件包含是预处理的一个ฐ重要功能,它可用来把多个源文件连接成一个源文件进行编译,结果将生成一个目标文件。一九七八年由美国电å话电å报公司at&t贝尔实验室正式表了,在《k&r》中并没有定义,后来由美国国家标准协会ameri9๗dardsinst。
7使用预ไ处理功能便于程序的修改、阅读、移植和调试,也便于实现模块化程序设计。运用指针编程是c语言最主要的风格之ใ一。
?语言10
10指针
101地址指针ฤ的基本概。利用指针变量可以表示ิ各种数据结构;能ม很方便地使用数组和字符串;从而编出精练而高效的程序,并能象汇编语言一样处理内。指针极大地丰ถ富了c语言的功能ม。学习指针是学习c语言中ณ最重要的一环,能否正确理解和使用指针是我们是否掌握c语言的一个标志。同时,指针也是c语言中ณ最为困难的一部分,在学习中除了要正确理解基本概ฐ念,还必须要多编程,上机调试。只要作到这些,指针ฤ也是不难掌握的。
101地址指针的基本概念
在计算机中,所有的数据都是存放在存储器中ณ的。一般把存储器中的一个字节称为一个内存单元,不同的数据类型所占用的内存单元数不等,如整型量占2个单元,字符量占1个单元等,在前面已有详细的介绍。为ฦ了正确地访问这些内存单元,必须ี为每个ฐ内存单元编上号。根据一个内存单元的编号即可准确地找到该内存单元。内存单元的编号也叫做地址。既然根据内存单元的编号或地址就可以找到เ所需的内存单元,所以通常也把这个地址称为ฦ指针。内存单元的指针和内存单元的内容是两ä个ฐ不同的概念。可以用一个通俗的例子来说明它们之间的关系。我们到银行去存取款时,银行工作人员将根据我们的帐号去找我们的存款单,找到เ之后在存单上写入存款、取款的金额。在这里,帐号就是存单的指针,存款数是存单的内容。对于一个内存单元来说,单元的地址即为指针,其中ณ存放的数据才是该单元的内容。在c语言中,允许用一个变量来存放指针ฤ,这种变量称为指针变量。因此,一个指针变量的值就是某个内存单元的地址或称为某内存单元的指针。
图中,设有字符变量cນ,其内容为“k”ascii码为十进制数7๕5,c占用了011aທ号单元地址用十六进数表示。设有指针变量p,内容为011a,这种情况我们称为p指向变量c,或说p是指向变量c的指针。
严å格地说,一个指针ฤ是一个地址,是一个常量。而一个指针变量却可以被赋予不同的指针值,是变量。但常把指针变量简称为指针。为了避免混淆,我们中约定:“指针”是指地址,是常量,“指针变量”是指取值为地址的变量。定义指针的目的是为了通过指针去访问内存单元。
既ຂ然指针变量的值是一个地址,那么เ这个地址不仅可以是变量的地址,也可以是其它数据结构的地址。在一个ฐ指针变量中存放一个数组或一个函数的地址有何意义呢?因为数组或函数都是连续存放的。通过访问指针变量取得了数组或函数的地址,也就找到เ了该数组或函数。这样一来,凡是出现数组,函数的地方都可以用一个指针ฤ变量来表示,只要该指针ฤ变量中赋予数组或函数的地址即可。这样做,将会使程序的概念十分清楚,程序本身也精练,高效。在c语言中,一种数据类型或数据结构往往都占有一组连续的内存单元。用“地址”这个概ฐ念并不能ม很好地描述一种数据类型或数据结构,而“指针”虽然实际上也是一个地址,但它却是一个ฐ数据结构的地址,它是“指向”一个数据结构的,因而概念更为ฦ清楚,表示更为明确。这也是引入“指针”概念的一个ฐ重要原因。
102变量的指针和指向变量的指针变量
变量的指针就是变量的地址。存放变量地址的变量是指针ฤ变量。即在c语言中,允许用一个变量来存放指针,这种变量称为指针变量。因此,一个指针变量的值就是某个变量的地址或称为某变量的指针ฤ。
为了表示指针ฤ变量和它所指向的变量之间的关系,在程序中ณ用“”符号表示ิ“指向”,例如,i_pointer代表指针ฤ变量,而i_ຕpointer是i_pointer所指向的变量。
因此,下面两个语句作用相同:
i=3๑;
i_pointer=3;
第二个语句的含义แ是将3赋给指针变量i_ຕpointer所指向的变量。
1021定义一个指针变量
对指针ฤ变量的定义包括三个内容:
1指针类型说明,即定义变量为ฦ一个ฐ指针变量;
2指针变量名;
3变量值指针ฤ所指向的变量的数据类型。
其一般形式为:
类型说明符变量名;
其中ณ,表示这是一个指针变量,变量名即为定义的指针变量名,类型说明符表示本指针ฤ变量所指向的变量的数据类型。
例如:intp1้;
表示p1是一个指针变量,它的值是某个整型变量的地址。或者说p1指向一个整型变量。至于p1究竟指向哪一个整型变量,应由向p1赋予的地址来决定。
再如:
intp2;๙p2๐是指向整型变量的指针ฤ变量
floatp3;p3๑是指向浮ด点变量的指针变量
charp4;p4是指向字符变量的指针变量
应该注意的是,一个指针变量只能ม指向同类型的变量,如p3只能指向浮点变量,不能时而指向一个浮点变量,时而又指向一个字符变量。
1022指针ฤ变量的引用
指针变量同普通变量一样,使用之ใ前不仅要定义说明,而且必须赋予具体的值。未经赋值的指针变量不能使用,否则将造成系统混乱,甚至死机。指针变量的赋值只能赋予地址,决不能赋予任何其它数据,否则将引起错误。在c语言中ณ,变量的地址是由编译系统分配的,对用户完全透明,用户不知道变量的具体地址。
两ä个有关的运算符:
1&:取地址运算符。
2:指针运算符或称“间接访问”运算符。
c语言中了地址运算符&来表示变量的地址。
其一般形式为: