我们先来定义一个指针变量a,然后b将把变量的地址分配给指针,最后c将访问指针变量中可用地址的值。以上运算都是通过一元运算符*来完成的,该运算符将返回指定地址的变量值,请看一下示例:
#include int main () {
int var = 20; /* actual variable declaration */
int *ip; /* pointer variable declaration */
ip = &var; /* store address of var in pointer variable*/
printf("Address of var variable: %x\n", &var );
/* address stored in pointer variable */
printf("Address stored in ip variable: %x\n", ip );
/* access the value using the pointer */
printf("Value of *ip variable: %d\n", *ip );
return 0;}
当上述代码被编译执行后,将反馈以下结果:
Address of var variable: bffd8b3c
Address stored in ip variable: bffd8b3c
Value of *ip variable: 20
“文艺”指针的用法
将NULL值分配给指针变量算是个好习惯,这样可以防止程序因为指针而崩溃,我们有时看到的程序非法操作而被终止运行就是因为指针问题。NULL等同于0,请看下列执行程序:
#include int main () {
int *ptr = NULL;
printf("The value of ptr is : %x\n", ptr );
return 0;}
当上述代码被编译执行后,将反馈以下结果:
The value of ptr is 0
在大多数操作系统中,程序是不允许访问地址为0的内存,因为是由操作系统保留的位置。内存地址为0具有特殊的意义,它表示指针不指向任何可以访问的内存地址。按照习惯,如果一个指针包含NULL值(0)值,则假定它不指向任何地址。如果要检查一个空指针,可以使用if语句,比如这么玩:
if(ptr) /* succeeds if ptr is not null */
if(!ptr) /* succeeds if ptr is null */
“二逼”指针的用法
比如下面这位大佬,他为指针分配分配了一个值“ptr”。估计是穿着女装上班精神不太集中,就忘了ptr是用于存储变量地址的指针变量:
int * ptr , m = 100 ;
ptr = m ; //这行上的错误
更正后:
ptr =&m;
今天给大家的C语言“指针”进阶教程大家还满意吗?如果你希望能学到更多知识,赶快退掉那些无趣的咸鱼群吧!