引言
本文主要讲述内存里,指针的指向与取值,是一篇补充内容
###指针
指针的具体概述以及用法,此处不再细诉,请各位看官移步自行Google哦。
####普通指针
废话不多说,直接上代码
int a = 10;int b = 10;NSLog(@"%d--%p",a,&a);NSLog(@"%d--%p",b,&b);
打印结果
a和b的值都是10,&a与&b得到的地址不一样,说明的是不同地址可以访问同一个值,简单来说就是值copy。
####对象指针
QLDog *dog = [QLDog alloc];NSLog(@"%@---%p----%p",dog,dog,&dog);
打印结果:
1、QLDog的对象dog的地址为0x600002754520,
2、换一种方式看,dog其实是(QLDog *)类型的指针,称为指针变量,指针变量dog地址为0x600002754520,即在堆中alloc开辟的能装下QLDog所有数据大小的内存的地址。改地址位于堆中。
3、&dog为指针dog的指针,为0x7ffee244fcf8,换句话说就是,指针dog内的值为堆中alloc出来的地址,抽出身来看,指针dog也在内存中,那么指针dog也有自己的地址,也就是&dog显示的地址,该地址位于栈中。
是不是有点懵,请看图
数组指针
int c[4] = {5,6,7,8};int *d = c;NSLog(@"%p---%p---%p",c,&c[0],&c[1]);NSLog(@"%p---%p---%p",d, d + 1 , d + 2 );for (int i = 0; i < 4; i ++) {int value = c[i];NSLog(@"%d",value);}
打印结果
1、c 和 &c[0]的地址一致,是因为数组的地址即为数组首个元素的地址。
2、d为int *指针,存放的是数组c的地址,d + 1,d + 2分别表示d 偏移了1、2个步长(step)此处+1,+2操作是对指针的操作,不是对值的操作哦,不要混淆了。
3、d,d + 1分别与c、&c[1]地址一致。地址对应的值都是6。说明了d + 1的偏移可以得到数组c的c[1]元素。
4、我们可以将for循环内的取值改为
for (int i = 0; i < 4; i ++) {int value = *(d + i);NSLog(@"%d",value);}
