**p,*p和&p使用有感
*p两种使用情况:
1.定义指针变量,如char *p;这里p是一个变量,单单在这一点上与int a 无差别;但p这个变量特殊在其中只能存地址。
引申:对于char **p,p中存一个地址add1,add1对应存储区存放add2,而add2地址对应存储区才存放有真正的data;如下图1所示:

2.*p,用来取p中所存地址对应存储区的数据,如上图2所示。
例如:主函数main中有char *p,p=。。。令p中存放某一内存首地址。这时调用子函数,若想在子函数fun中修改p指向的内存,必须:
(1)要得到p的地址即fun(&p),然后用*p=。。。才能需改p指向的内存,具体如下:
void func(char **p2)
{
char *p1 ;
//p1 = (char *)malloc(sizeof(char) * );
p1 = "hello";
*p2 = p1;
}
int main(){
char *p = NULL; func(&p);
printf("p=%s\n",p);//打印p指向内存所存字符串。
getchar(); return ;
}
输出:hello
(2)若不想传地址,就需要子函数带返回值,程序如下:
char * func(void)
{
char *p1 ;
p1 = "hello";
return p1;
}
int main(){ char *p = NULL; p=func();
printf("p=%s\n",p);//打印p指向内存所存字符串。
getchar(); return ;
}
输出:hello
引申:下面给出一些案例
一个典型错误:
看你能不能找出来:
void t(char **p2){
char *p1 ;
p1 = (char *)malloc();
*p2 = p1;
}
int main(){
char **p ;
t(p);
return ;
}
为什么一运行就提示p没有初始化。
改进:下面为对**p正确应用的例子:
void t(char **p2)
{
char *p1 ;
//p1 = (char *)malloc(1);
p1 = "hello";
*p2 = p1;//*p本来指向arr[],现在指向"hello"所在内存区域首地址,所以堆arr[]没影响。
}
int main(){
char **p;
p = (char **)malloc(sizeof(char) * );
char arr[] = "zhang";
*p = arr;//*p中存放arr地址,区别于p = (char **)arr直接p中存放arr地址
printf("a[0]=%c\n",arr[]);
t(p);
printf("*p=%s,p=%d\n",*p,p);
printf("a[0]=%c\n",arr[]);
return ;
}
输出:
a[0]=z
*p=hello,p=13531344//不同人结果不一样。
a[0]=z
这种方式原本的arr[]数据还在,只是*p不指向了,*p指向了“hello”所在内存的地址。
再看一种:注意与上面程序对比,你就能明白**p到底这么用。
void t(char **p2)
{
char *p1 ;
p1 = "hello";
*p2 = p1;//p存放arr地址,*p 对应arr[0]的值,因此这句会破坏原理的arr数组。
}
int main(){
char **p;
//p = (char **)malloc(sizeof(char) * 8);
char arr[] = "zhang";
p = (char **)arr;//*p = arr思考注释中的这种方式的差别?//p存放arr地址
printf("a[0]=%c\n",arr[]);
t(p);
printf("p=%s,p=%x\n",*p,p);
printf("a[0]=%c\n",arr[]);
return ;
}
输出:
a[]=z
p=hello,p=75fe70
a[]=?
思考:为什么结果和上面程序不一样。其实注释里已经给出了答案,哈哈。
**p,*p和&p使用有感的更多相关文章
- 从小工到专家 ——读《Java程序员职场全攻略》有感
从小工到专家 ——读<Java程序员职场全攻略>有感 <Java程序员职场全攻略>是以故事的形式,向读者介绍Java程序员的职场经验.作者牛开复在北京从事软件开发,已经是一 ...
- 漫谈可视化Prefuse(三)---Prefuse API数据结构阅读有感
前篇回顾:上篇<漫谈可视化Prefuse(二)---一分钟学会Prefuse>主要通过一个Prefuse的具体实例了解了构建一个Prefuse application的具体步骤.一个Pre ...
- 见证历史 -- 2013 NBA 热火夺冠之路有感
见证历史-- 2013 NBA 热火夺冠之路有感今年NBA季后赛从第一轮看起,到最终的热火夺冠,应该看得是最爽的一次.但一些情节和细节,回忆起来,深有感悟. 1. 做人要低调詹宁斯豪言演黑八雄鹿本赛季 ...
- <构建之法>第十三章到十七章有感以及这个项目读后感
<构建之法>第十三章到十七章有感 第13章:软件测试方法有哪些? 主要讲了软件测试方法:要说有什么问题就是哪种效率最高? 第14章:质量保障 软件的质量指标是什么?怎么样能够提升软件的质量 ...
- 段描述符表(GDT+LDT)的有感
[0]写在前面 要知道,在汇编中,代码的装入顺序决定了在内存中的地址位置.所有的代码或者数据都在硬盘上,当调试或者启动的时候,加载到内存:当需要对数据进行处理的时候,我们通过将数据从内存载入到regi ...
- 驱动:中断【2】中断处理程序、中断上下文中处理延时及一些函数的调用规则(调IIC中断驱动有感)
中断处理程序.中断上下文中处理延时及一些函数的调用规则(调IIC中断驱动有感)http://blog.csdn.net/samantha_sun/article/details/6790492 1,中 ...
- 第一次QQ群视频教育有感
标题:第一次QQ群视频教育有感 作者:丁又专, 时间:2014.08.16 教育的目的:启示学生心智,发现个人优势,激发探索欲望. 今天早上看到 中国大学MOOC<文献管理与信息 ...
- 10.读google测试之道有感
(一)读google测试之道有感.
- 重读COM技术内幕(inside com)有感
重读COM技术内幕(inside com)有感 面向对象设计哲学在复杂领域并不能很好地解决问题.参考(http://www.richardlord.net/blog/what-is-an-entity ...
- [minecraft]mcCoder制作有感
mcCoder是一个minecraft-forge-mod制作库,力图让mod制作者可以更简单的制作mod,减少mod制作者的mod制作难度. 在GitHub上关注这个项目: 原理 mcCoder主要 ...
随机推荐
- Excel催化剂开源第9波-VSTO开发图片插入功能,图片带事件
图片插入功能,这个是Excel插件的一大刚需,但目前在VBA接口里开发,如果用Shapes.AddPicture方法插入的图片,没法对其添加事件,且图片插入后需等比例调整纵横比例特别麻烦,特别是对于插 ...
- Excel催化剂开源第1波-自定义函数的源代码全公开
Excel催化剂插件从2018年1月1日开始运营,到今天刚好一周年,在过去一年时间里,感谢社区里的许多友人们的关心和鼓励,得以坚持下来,并收获一定的用户量和粉丝数和少量的经济收入回报和个人知名度的提升 ...
- java的System.currentTimeMillis()和System.nanoTime
纳秒 ns(nanosecond):纳秒, 时间单位.一秒的10亿分之一,即等于10的负9次方秒.常用作 内存读写速度的单位,其前面数字越小则表示速度越快. 1纳秒=1000 皮秒 1纳秒 = ...
- 谈谈用Boox Max 2 阅读A4纸文献的体验
首先说说选择Boox的几个原因: 护眼.这个不用多说,之所以除了电脑,还要电子阅读器,主要是为了护眼. 减少纸质书籍购买.纸质书籍拿在手上是有质感,读起来也更舒服,可一则一些外文书买纸质的是很贵的,相 ...
- 那些年,想和你一起认识的SpringCloud Eureka
前几天鲁班LB跟我说:你玩把游戏都要半个钟啦,为何不用这时间来看看书,如果涨工资还可以帮我买个皮肤. 面对如此合理的这需求,但我不以为然,事实上并不是我不想学习,而是 ↓ 实力不允许呀~ 直到有一天, ...
- Calico 网络通信原理揭秘
Calico 是一个纯三层的数据中心网络方案,而且无缝集成像 OpenStack 这种 Iaas 云架构,能够提供可控的 VM.容器.裸机之间的 IP 通信.为什么说它是纯三层呢?因为所有的数据包都是 ...
- CoreCLR Host源码分析(C++)
废话不多说,直接上源码: 1.在托管程序集里面执行方法 HRESULT CorHost2::ExecuteAssembly(DWORD dwAppDomainId,//通过CreateAppDomai ...
- go 学习笔记之工作空间
搭建好 Go 的基本环境后,现在可以正式开始 Go 语言的学习之旅,初学时建议在默认的 GOPATH 工作空间规范编写代码,基本目录结构大概是这个样子. . |-- bin | `-- hello.e ...
- ArrayList源码分析--jdk1.8
ArrayList概述 1. ArrayList是可以动态扩容和动态删除冗余容量的索引序列,基于数组实现的集合. 2. ArrayList支持随机访问.克隆.序列化,元素有序且可以重复. 3. ...
- 跟着大彬读源码 - Redis 8 - 对象编码之字典
目录 1 字典的实现 2 插入算法 3 rehash 与 渐进式 rehash 总结 字典,是一种用于保存键值对的抽象数据结构.由于 C 语言没有内置字典这种数据结构,因此 Redis 构建了自己的字 ...