前面我介绍过,从机器语言的角度去看计算机,一切皆是地址;从汇编语言的角度去看计算器,除了操作码,其余皆是地址,冯诺依曼结构和哈佛结构的计算机,外设全都映射到了CPU的存储地址。C语言指针类型,本质上是存储的地址。因此,C语言的指针,理论上可以让我们访问计算机的任何一个外设。
定义指针变量
先看一段代码:
int main(void)
{
int *piZhiZhen ;
}
以上代码中的:
int *piZhiZhen ;
再变量名的左边加一个星号“*”,就是定义了一个指针变量,int表示这个指针变量指向一个整形数据,有了这个变量,我们理论上就可以访问计算机的所有的存储地址了,当然由于系统的权限问题,有些地址其实访问不了。
我们已经知道,C语言的指针,其实就是存储的地址,那么我们定义了一个指针,怎么让它指向预期的地址呢?
指针变量赋值
比如我定义一个整形变量 iZhengXing,再定义个指向整形的指针变量 piZhiZhen,可以通过如下方式,让指针指向 iZhengXing 的地址:
int main(void)
{
int iZhengXing ;
int *piZhiZhen ;
piZhiZhen = &iZhengXing ;
}
C语言中规定,变量定义完成后,在变量名的左边加一个“&”符号,就表示获取这个变量的地址。因此,上述代码的含义就是,先定义一个整形变量 iZhengXing,再定义一个指向整形的指针变量 piZhiZhen,然后把iZhengXing的地址赋值给 piZhiZhen 。
注意:指针定义后,必须通过赋值的方式,明确的指向一个预期值,然后才能使用。如若不然,轻则系统崩溃重启;重则看起来什么都没有发生,但是播放器莫名的开始放歌了、屏幕莫名的有美女飞来飞去、明明保存了的作业不翼而飞了……。这既不是人性的扭曲,也不是道德的沦丧,仅仅是因为指针没有赋值。
指针变量使用
指针变量定义,且指向预期地址后,通过如下方式改变地址里面的值;
*piZhiZhen = 100 ;
也可以通过下面的方式,地址里面的值,赋值给另一个整形变量:
iYanshi = *piZhiZhen ;
我们看下面这段代码:
int main(void)
{
int iZhengXing ;
int iYanshi ;
int *piZhiZhen ;
piZhiZhen = &iZhengXing ;
iZhengXing = 10 ;
printf("2. *piZhiZhen == %d\r\n", *piZhiZhen);
*piZhiZhen = 100 ;
printf("3. iZhengXing == %d\r\n", iZhengXing);
iYanshi = 2 ;
printf("4. iYanshi == %d\r\n", iYanshi);
iYanshi = *piZhiZhen ;
printf("5. iYanshi == %d\r\n", iYanshi);
}
咱们一部分一部分解释。
下面三行,是定义了两个整形变量(iZhengXing,iYanshi),和一个指向整形的指针变量(piZhiZhen):
int iZhengXing ;
int iYanshi ;
int *piZhiZhen ;
下面这行,是给指针变量赋值为 iZhengXing 的地址。
piZhiZhen = &iZhengXing ;
下面两行,是给 iZhengXing 赋值为 10 ,然后打印 *piZhiZhen,因为 piZhiZhen 的值是 iZhengXing的地址,因此 *piZhiZhen 和 iZhengXing 应该是一样的,都是10。
iZhengXing = 10 ;
printf("2. *piZhiZhen == %d\r\n", *piZhiZhen);
下面两行,是给 *piZhiZhen 赋值为 100,然后打印 iZhengXing,因为 piZhiZhen 的值是 iZhengXing的地址,所以 *piZhiZhen 赋值为100后, iZhengXing 应该也变成了100。
*piZhiZhen = 100 ;
printf("3. iZhengXing == %d\r\n", iZhengXing);
下面4行,是先给 iYanshi 赋值2,然后打印,再将 iYanshi赋值为 *piZhiZhen ,再打印iYanshi。
第一次应该打印2,第二次打印 100
iYanshi = 2 ;
printf("4. iYanshi == %d\r\n", iYanshi);
iYanshi = *piZhiZhen ;
printf("5. iYanshi == %d\r\n", iYanshi);
运行结果如下: