引言
本文主要讲述内存里,指针的指向与取值,是一篇补充内容
###指针
指针的具体概述以及用法,此处不再细诉,请各位看官移步自行Google哦。
####普通指针
废话不多说,直接上代码

  1. int a = 10;
  2. int b = 10;
  3. NSLog(@"%d--%p",a,&a);
  4. NSLog(@"%d--%p",b,&b);

打印结果005--OC对象原理探究 - 内存偏移 - 图1
a和b的值都是10,&a&b得到的地址不一样,说明的是不同地址可以访问同一个值,简单来说就是值copy
####对象指针

  1. QLDog *dog = [QLDog alloc];
  2. NSLog(@"%@---%p----%p",dog,dog,&dog);

打印结果:005--OC对象原理探究 - 内存偏移 - 图2

1、QLDog的对象dog的地址为0x600002754520
2、换一种方式看,dog其实是(QLDog *)类型的指针,称为指针变量,指针变量dog地址为0x600002754520,即在alloc开辟的能装下QLDog所有数据大小的内存的地址。改地址位于中。
3、&dog指针dog的指针,为0x7ffee244fcf8,换句话说就是,指针dog内的值为堆中alloc出来的地址,抽出身来看,指针dog也在内存中,那么指针dog也有自己的地址,也就是&dog显示的地址,该地址位于中。
是不是有点懵,请看图005--OC对象原理探究 - 内存偏移 - 图3

数组指针

  1. int c[4] = {5,6,7,8};
  2. int *d = c;
  3. NSLog(@"%p---%p---%p",c,&c[0],&c[1]);
  4. NSLog(@"%p---%p---%p",d, d + 1 , d + 2 );
  5. for (int i = 0; i < 4; i ++) {
  6. int value = c[i];
  7. NSLog(@"%d",value);
  8. }

打印结果005--OC对象原理探究 - 内存偏移 - 图4

1、c&c[0]的地址一致,是因为数组的地址即为数组首个元素的地址。
2、dint *指针,存放的是数组c的地址,d + 1,d + 2分别表示d 偏移了1、2个步长(step)此处+1,+2操作是对指针的操作,不是对值的操作哦,不要混淆了。
3、dd + 1分别与c&c[1]地址一致。地址对应的值都是6。说明了d + 1的偏移可以得到数组c的c[1]元素
4、我们可以将for循环内的取值改为

  1. for (int i = 0; i < 4; i ++) {
  2. int value = *(d + i);
  3. NSLog(@"%d",value);
  4. }

总结
上面的例子,int类型占的是4字节,数组c的元素类型大小为4字节,即c[0]到c[1]相差4个字节d + 1,d + 2的操作相当于d在原来的地址上+4字节,+8字节,这就是指针的操作此 +1 非彼 +1
这就为我们提供了思路,可以对指针平移一些大小(步长step),来得到一些我们想要的内容。