objective-c中使用release不能释放内存,用alloc创建了一个对象,将其release后,仍可使用该对象
直接上代码intmain(intargc,constchar*argv[]){@autoreleasepool{Cpu*powerPC=[[Cpualloc]init];...
直接上代码
int main(int argc, constchar * argv[])
{
@autoreleasepool {
Cpu *powerPC = [[Cpualloc] init];
[powerPC setCID:101];
Laptop *apple = [[Laptop alloc] init];
[apple setCPU:powerPC];
[powerPC release]; //我在这里将对象释放,但下条代码仍可执 行,程序并未crash掉
NSLog(@"%d",[[apple cpu] cID]);
}
return0;
}
- (void)setCPU:(Cpu *)cpu
{
_cpu = cpu;
}
这些为代码主要部分
求解答,谢谢 展开
int main(int argc, constchar * argv[])
{
@autoreleasepool {
Cpu *powerPC = [[Cpualloc] init];
[powerPC setCID:101];
Laptop *apple = [[Laptop alloc] init];
[apple setCPU:powerPC];
[powerPC release]; //我在这里将对象释放,但下条代码仍可执 行,程序并未crash掉
NSLog(@"%d",[[apple cpu] cID]);
}
return0;
}
- (void)setCPU:(Cpu *)cpu
{
_cpu = cpu;
}
这些为代码主要部分
求解答,谢谢 展开
4个回答
展开全部
Cpu *powerPC = [[Cpualloc] init];这句使得powerPC 对象引用计数为1;
[apple setCPU:powerPC];这句使得powerPC 对象对象引用计数为2;
[powerPC release]; 这句之后powerPC 对象引用计数为1,因此NSLog(@"%d",[[apple cpu] cID]);不会崩溃;
powerPC 对象引用计数为0后才释放;
[apple setCPU:powerPC];这句使得powerPC 对象对象引用计数为2;
[powerPC release]; 这句之后powerPC 对象引用计数为1,因此NSLog(@"%d",[[apple cpu] cID]);不会崩溃;
powerPC 对象引用计数为0后才释放;
更多追问追答
追问
不是在set方法里使用retain、copy才使引用计数加1吗 ?
我set方法里没使用这些
追答
额,没有的话应该是release操作的延迟问题,我试了试把NSLog延迟执行,会崩溃的,立刻执行则不会。总而言之,没有崩溃是release操作还没完全释放掉对象,就执行了NSLog,估计和系统安排的一些方法执行队列有关。
展开全部
[apple setCPU:powerPC];这句话的意思是,给apple对象的CPU成员赋值,[powerPC release];只是释放了powerPC,apple的CPU成员你又没释放,后面为什么不能用它呢
更多追问追答
追问
我的主要问题是powerPC并没释放,NSLog(@"%d",[[apple cpu] cID]);这句话仍能正常执行,其实本身该句运行会crash掉,因为apple调用cpu这个方法,而apple的Cpu就是powerPC。事实powerPC本已释放了。
追答
set的时候引用技术会+1,你看一下set方法的原理,你可以把set当成深拷贝来看待
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
改一下你的setCPU:方法即可
- (void)setCPU:(Cpu *)cpu
{
[_cpu release];
_cpu = cpu;
[_cup retain];
}
你完全可以使用属性来管理CPU。省去了自己去管理CPU的引用计数。
.h
@property (nonatomic,retain) Cpu *cpu;
.m
@Sythesize cpu;
- (void)setCPU:(Cpu *)cpu
{
[_cpu release];
_cpu = cpu;
[_cup retain];
}
你完全可以使用属性来管理CPU。省去了自己去管理CPU的引用计数。
.h
@property (nonatomic,retain) Cpu *cpu;
.m
@Sythesize cpu;
追问
先感谢你的回答。我只是在自学看视频时,看到它里面说的我上面的程序,我看到它运行时,直接崩溃了,所以我也去试了下,发现结果不一样,所以就来请教了。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
=-= 你看一下 XCode 的工程选项卡里 ”自动垃圾回收“ 是否被选中,如果被选中,则所有的内存操作指令无效
追问
是不是Objective-C Automatic Reference Counting选项,已经设置为NO了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询