- block代码分析
1.1 单独的一个文件,比如 在新建文件夹中新建一个test.m的文件
执行clang命令
clang -rewrite-objc test.m
就可以生成相应的.cpp代码,
修改test.m文件代码
再次执行 clang -rewrite-objc test.m
很明显可以看出差异
1.2 不是单文件是在工程中(导入了UIKit 怀疑) 执行 clang -rewrite-objc 会出现这个问题
解决办法
使用
xcrun -sdk iphonesimulator10.3(版本号) clang -rewrite-objc ViewController.m
具体参考 clang -rewrite-objc的使用点滴
得到 ViewController.cpp 文件
1.3 对于__weak 类型的用 clang -rewrite-objc test.m 编译
#import <Foundation/Foundation.h>
@interface Foo : NSObject
typedef void (^Cap)(NSObject *obj);
@property (nonatomic, strong) Cap cap;
- (void)capObject;
@end
@implementation Foo
- (void)capObject {
NSMutableArray __weak *muArray = [NSMutableArray array];
_cap = ^(NSObject *obj){
[muArray addObject:obj];
NSLog(@"元素个数%ld",[muArray count]);
};
}
@end
int main () {
Foo* foo = [[Foo alloc] init];
[foo capObject];
foo.cap([[NSObject alloc] init]);
return 0;
}
会报错,
错误信息: cannot create __weak reference because the current deployment target does not support weak references
解决办法:
clang -rewrite-objc -fobjc-arc -stdlib=libc++ -mmacosx-version-min=10.7 -fobjc-runtime=macosx-10.7 -Wno-deprecated-declarations test.m
How to use __weak reference in clang?
- 什么情况下block会进行copy操作
在MRC下block定义的属性都要加上copy,ARC的时候block定义copy或strong都是可以的,因为ARC下strong类型的block会自动完成copy的操作。
当 block 作为函数返回值返回时。
当 block 被赋值给 __strong id 类型的对象或 block 的成员变量时。
当 block 作为参数被传入方法名带有 usingBlock 的 Cocoa Framework 方法或 GCD 的 API 时。
参考
Objective-C中block的底层原理
clang -rewrite-objc的使用点滴
How to use __weak reference in clang?
Objective-C编译成C++代码报错