我使用ARC在NSInvocation中测试,但它会触发内存泄漏。在MRC中,它运作良好。我不知道为什么。
- (NSArray *)a:(NSString *)a b:(NSString *)b c:(NSString *)c
{
return @[a, b, c];
}
- (void)testNSInvocation
{
NSMethodSignature *sig = [self methodSignatureForSelector:@selector(a:b:c:)];
NSInvocation *inv = [NSInvocation invocationWithMethodSignature:sig];
[inv setTarget:self];
[inv setSelector:@selector(a:b:c:)];
NSString *a = @"a", *b = @"b", *c = @"c";
[inv setArgument:&a atIndex:2];
[inv setArgument:&b atIndex:3];
[inv setArgument:&c atIndex:4];
[inv retainArguments];
[inv invoke];
NSArray *ret;
[inv getReturnValue:&ret];//this is problem,but why?
NSLog(@"ret:%@", ret);
}
答案 0 :(得分:0)
我在stackOverflow中找到答案。问题是getReturnValue:,它只是将返回值的字节复制到给定的内存缓冲区中,而不管类型如何。如果返回类型是可保留的对象指针类型,则它不知道或不关心内存管理。由于ret是对象指针类型的__strong变量,因此ARC假定已保留已放入变量的任何值,因此当它超出范围时将释放它。在这种情况下不是这样,所以它崩溃了。 (此外,最初指向ret的数组将被泄露,因为getReturnValue:覆盖该值而不释放它。为什么你甚至将该变量指向一个对象首先超出了我。) NSInvocation returns value but makes app crash with EXC_BAD_ACCESS