博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
c语言中 int *p = NULL 和 *p = NULL 有什么区别
阅读量:7063 次
发布时间:2019-06-28

本文共 906 字,大约阅读时间需要 3 分钟。

1. int *p = NULL; 代表定义一个指向整型变量的指针p,然后p的值设为NULL,也就是设为0;用另一种方式说,就是对一个刚定义的指向整型变量的指针,赋初始值,让其指向0地址。 

2. *p = NULL; 代表对一个由指针p指向的变量(什么类型,不知道),赋值为0,是将那个变量赋值为0。

 

我们可以先看下面的代码:

1
int 
*p = NULL;

这时候我们可以通过编译器查看p的值为0x00000000。

这句代码的意思是:定义一个指针变量p,其指向的内存里面保存的是int类型的数据;在定义变量p的同时把p的值设置为0x00000000,而不是把*p的值设置为0x00000000。这个过程叫做初始化,是在编译的时候进行的。就好比我们定义了一个int型的变量,但是没有赋初值,那么编译器会自动赋初值为0,同理对于指针,就赋初值为0地址。

明白了什么是初始化之后,再看下面的代码:

1
2
int 
*p;
*p = NULL;

同样,我们可以在编译器上调试这两行代码。第一行代码,定义了一个指针变量p,其指向的内存里面保存的是int类型的数据;但是这时候变量p本身的值是多少不得而知,也就是说现在变量p保存的有可能是一个非法的地址。第二行代码,给*p赋值为NULL,即给p指向的内存赋值为NULL;但是由于p指向的内存可能是非法的,所以调试的时候编译器可能会报告一个内存访问错误。这样的话,我们可以把上面的代码改写改写,使p指向一块合法的内存:

1
2
3
int 
i = 
10
;
int 
*p = &i;
*p = NULL;

在编译器上调试一下,我们发现p指向的内存由原来的10变为0了;而p本身的值, 即内存地址并没有改变。经过上面的分析,相信你已经明白它们之间的区别了。不过这里还有一个问题需要注意,也就是这个NULL。

初学者往往在这里犯错误。

注意NULL就是NULL,它被宏定义为0:

1
#define NULL 
0

本文转自二郎三郎博客园博客,原文链接:http://www.cnblogs.com/haore147/p/3647174.html,如需转载请自行联系原作者  

你可能感兴趣的文章
java中关于继承的问题
查看>>
认证服务号可通过模板消息向用户发送重要的服务通知
查看>>
OVS 中的各种网络设备 - 每天5分钟玩转 OpenStack(128)
查看>>
Spring源码学习之:模拟实现BeanFactory,从而说明IOC容器的大致原理
查看>>
iOS - UIActionSheet
查看>>
用户 'IIS APPPOOL\xxxx' 登录失败
查看>>
iOS - TouchID 指纹识别
查看>>
centos7上安装redis
查看>>
【笔记3】用pandas实现矩阵数据格式的推荐算法 (基于用户的协同)
查看>>
(转) Face-Resources
查看>>
虚拟机克隆后找不到eth0
查看>>
MySQL案例-show fileds from 提示无权限
查看>>
Oracle推导参数Derived Parameter介绍
查看>>
解决TCP网络传输“粘包”问题
查看>>
【中亦安图】Oracle内存过度消耗风险提醒(6)
查看>>
8.9. usb device
查看>>
OSS控制台新增函数计算处理事件入口
查看>>
第一章——计算机系统架构介绍
查看>>
Struts2.5使用通配符的方式实现动态方法调用报错
查看>>
【MySQL】replace into 浅析之一
查看>>