数组指针和指针数组
2021-06-28 17:03
标签:amp hang 字节 地址 只读 数组 编译 系统 指针 首先: 指针在32位系统中,占4个字节。 首先讲一下指针数组: 有4只看不见的手指向数据区的空间。 再来看数组指针:总是搞不清这个,理由就是,不管赋值给它是一维还是二维数据,它都是二维来处理,它就是个二维指针,所以每次指向其所需的地址数值时,要解引用2次, 第一次是所在行,确定进入哪个子集,第二次解引用是确定子集中的哪个位置 · 数组指针和指针数组 标签:amp hang 字节 地址 只读 数组 编译 系统 指针 原文地址:https://www.cnblogs.com/ymd12103410/p/9648923.html
校正一下读法:
数组指针:给它在中间加上一个的,数组的指针,重心是指针,全名叫指向数组的指针,它就一个指针,指向数组 指针数组:同样也在中间加上一个的,指针的数组,重心是数组,全名叫存储指针的数组,一听名字就知道,里面存的是指针,所以它有很多个指针构成
char *arr [4]={" hello " , " world "," hang" , " zhou "}; 数组中的4个指针元素,分别存放着4个字符串的首地址,存放在栈区中,初始化的值被分配在只读数据区,从栈区 数组指针也叫行指针,如:int (*p) [n] 每次p加1,不是实实在在的加1,而是跨过n个整形数据的长度,从a[0] [ ]到a[1] [ ]
根据读法来判读属于哪个:看当前的P是什么(注意根据优先级),那么词组的中心词就是什么
如:int (*p) [n] ()的优先级比[ ]高,所以P是指针,所以就是数组指针
int main() { char a[5]={‘A‘,‘B‘,‘C‘,‘D‘}; char (*p3)[5] = &a; //在visual 2013 中下述语句无法编译通过,要进行类型转换 // char (*p4)[5] = a; char(*p4)[5]=(char(*)[5])a; //可以编译通过 return 0; }
数组指针:指向的是整个数组,&a是整个数组的首地址,a是数组首元素首地址,两者的值虽然相同,但是类型不同。