二级指针:也叫双指针,指针的指针用作参数,大多用在需 要函数改变该指针的指向时 代码目的是setPeople方法执行后,people指针指向了一个新 创建的people对象。
一级指针
ZYPeople *people=nil;
NSLog(@"1__%@__%p__%p",people,people,&people);
[self setPeople:people];
NSLog(@"4__%@__%p__%p",people,people,&people);
-(void)setPeople:(ZYPeople *)people2
{
NSLog(@"2__%@__%p__%p",people2,people2,&people2);
people2=[[ZYPeople alloc] init];
NSLog(@"3__%@__%p__%p",people2,people2,&people2);
}
}log输出如下:
1__(null)__0x0__0xbfffcae4
2__(null)__0x0__0xbfffca64
3__<ZYPeople: 0x8ce9750>__0x8ce9750__0xbfffca64
4__(null)__0x0__0xbfffcae4
概述:
people为一个指针,可以直接使用这个指针所储存的内存地 址,又可以使用这个地址里储存的值。 指针是一种数据类型,与其它的数据类型不同的是指针是一 种“用来存放地址值”的变量%p 一般以十六进制整数方式输出指针的值 &取地址符号:&后面跟变量标识符即可获得变量的内存地址 指针虽然很小 但还是占一些内存,也有自己的内存地址log中打印了3项:指针指向地址中的值(对象)、指针的值 (对象地址)、指针的地址
分析:2和1中的对象内容、指针的值都一样,只有指针本身 的地址不 一样,两个指针指向了同一块地址,但是这两个指针本身的 地址不同,这是两个不同的指针变量。 在函数的参数传递中,编译器会为函数的每个参数制作临时 副本。
此处people2就是people的副本; 3、people2指针指向了一个新创建的ZYPeople对象的地址 输出了指针指向地址中的值(对象)、指针的值(对象地 址)、指针的地址
4、和1一样
因为在函数的参数传递中,编译器会为函数的每个参数制作 临时副本(也就是拷贝指针)。所以people2在方法中赋值, 与外部的people没关系 实现不了目的
二级指针
ZYPeople *people=nil;
NSLog(@"1__%@__%p__%p",people,people,&people);
[self setPeople:&people];
NSLog(@"4__%@__%p__%p",people,people,&people);
-(void)setPeople:(ZYPeople **)people2
{
NSLog(@"2__%@__%p__%p",*people2,people2,&people2);
*people2=[[ZYPeople alloc] init];
NSLog(@"3__%@__%p__%p",*people2,people2,&people2);
}
log输出如下
1__(null)__0x0__0xbfffcae4
2__(null)__0xbfffcae0__0xbfffca60
3__<ZYPeople: 0x8cc5bc0>__0xbfffcae0__0xbfffca60
4__<ZYPeople: 0x8cc5bc0>__0x8cc5bc0__0xbfffcae4
在我看来,所谓的双指针就是新建一个对象p ,再创建一个指针p1指向p,然后再创建一个指针p2,p2内保存了p1指针的地址,取得p2指针的内容,就是拿到了p1指针的地址,然后对其的指向进行修改.