C语言了解语句

首先,将我首要了解C的语言的魅力的原理和数据产生数据也到底如何形成,以及将类型进行调动起来将类型进行一步一步缓存曾数据进行输出类型点了,也更好了解类型种类之间到底是如何形成和该什么声明正确的表述的语句进行跳动起来。现在就行更好逻辑理解。

  • 通过指针变量访问整型变量。

 

程序分析:(1)在程序第4行定义两个指针变量pointer_1和pointer_2,pointer_1和pointer_2前面的*”表示所定义的变量是指针变量,而不是普通变量。本行最前面的int表示所定义的指针变量是指向整型变量的,经此定义后,它们可以指向任何整型变量(或数组元素),但不能指向其他类型的数据(如float, double, char型的数据)。注意,虽然已定义了指针变量pointer_1和pointer_2,但它们并未被赋予初值,即它们并未指向任何一个实际的变量。只是提供两个指针变量,规定它们可以指向整型变量,至于指向哪一个整型变量,由程序的语句指定。(2)程序第6、7行分别把a的地址赋给pointer_1,把b的地址赋给pointer_2,此时pointer_1的值为&a(即a的地址),pointer_2的值为&b(b的地址)。这就使pointer_1指向a,pointer_2指向b,。(3)最后一个语句中的* pointer_1和* pointer_2就是变量a和b。这里的"*”表示“指向的对象”。*pointer_1代表pointer_1所指向的变量,也就是变量a,见图8.4。因此最后两个printf函数的作用是相同的。程序中有两处出现* pointer_1和* pointer_2,含义是不同的。程序第4行的*pointer_1和*pointer_2表示定义两个指针变量pointer_1和pointer_2。它们前面的"*”只是表示该变量是指针变量。程序最后一行printf函数中的* pointer_1 和* pointer_2则代表 pointer_1 和pointer_2所指向的变量

 

程序分析:当输入a=5,b=9时,由于a<b,将pl和p2的值交换,也就是把它们的指向交换。交换前的情况见图8.5(a),交换后的情况见图8.5(b)。请注意,a和b的值并未交换,它们仍保持原值,但pl和p2的值改变了。pl的值原为&a,后来变成&b,p2原值为&b,后来变成&a。这样在输出*pl和*p2时,实际上是输出变量b和a的值,所以先输出9,然后输出5。这个问题的算法是不交换整型变量的值,而是交换两个指针变量的值(即a和b的地址)。说明:前面已说明了指针代表地址。实际上,指针代表的不仅是一个纯地址(即内存单

 

元的编号),而且还是一个带类型的地址。在C语言中,所有数据都是存放在内存单元中的,因此所有数据都是有类型的。例如,123是整型数据,按整型数据存储方式存储;123.0是单精度实型数据,按单精度实型数据存储方式存储。可以说,所有数据都是“带类型”的数据,同样,地址也是有类型的。分析下面的定义:

 

它包含以下两个内容:(1)定义了p是一个指向整型类数据的指针变量(即p的基类型为整型)。(2)把p整型变量a的地址&a赋给p,使p指向a。分析一下&a,在对整型变量a进行&操作(取地址操作)时,不仅得到a的纯地址(即内存编号,如2000),而且得到a的类型(int)。因此,&a包含了两个信息:纯地址和a的类型(即地址的基类型)。在将&a赋值给p时,不是简单地把内存编号2000直接赋给p,而是先检查&a和p是否类型相同(或赋值兼容),现在&a和p类型相同,可以将a的地址赋给p。如果另有一个float变量b,即使其内存单元编号也是2000,也不能进行赋值,因为其类型不同。&a和&b是两个不同的地址(尽管它们的纯地址相同),因此,我们说地址2000,应理解为内存编号为2000的纯地址以及它指向的数据的类型,这二者是二位一体、合二为一的。在C语言中用到的“地址”都是指带类型的地址。只有纯地址是无法对内存单元进行访问的。p的类型用"* int"表示,其中"*”表示它为指针型变量,"* int”表示其基类型为整型

 

程序分析swap是用户自定义函数,它的作用是交换两个变量(a和b)的值。swap函数的两个形参pl和p2是指针变量。程序运行时,先执行main函数,输人a和b的值(现输人5和9)。然后将a和b的地址分别赋给指针变量pointer_1 和pointer_2,使pointer_1指向a,pointer2指向b,见图8.6(a)。接着执行if语句,由于a<b,因此执行swap函数。注意实参pointer_1 和pointer_2是指针变量,在函数调用时,将实参变量的值传送给形参变量,采取的依然是“值传递”方式。因此虚实结合后形参pl的值为&a,p2的值为&b,见图8.6(b)。这时pl和pointer_1都指向变量a,p2和pointer_2都指向b。接着执行swap函数的函数体,使* pl和*p2的值互换,也就是使a和b的值互换。互换后的情况见图8.6(c)。函数调用结束后,形参pl和p2不复存在(已释放),情况如图8.6(d)所示。最后在main函数中输出的a和b的值已是经过交换的值(a=9,b=5)

 

 

*pl是a,是整型变量。而*temp是指针变量temp所指向的变量。但由于未给temp赋值,因此temp中并无确定的值(它的值是不可预见的),所以temp所指向的单元也是不可预见的。所以,对* temp赋值就是向一个未知的存储单元赋值,而这个未知的存储单元中可能存储着一个有用的数据,这样就有可能破坏系统的正常工作状况。应该将*pl的值赋给与*p1相同类型的变量,在例8.3中用整型变量temp作为临时辅助变量实现* p1和*p2的交换注意:本例采取的方法是交换a和b的值,而pl和p2的值不变。这恰和例8.2相反。可以看到,在执行swap函数后,变量a和b的值改变了。请仔细分析,这个改变是怎么实现的。这个改变不是通过将形参值传回实参来实现的。请读者考虑一下能否通过下面的函数实现a和b互换

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值