今年WWDC 2012苹果全球开发者大会上,苹果针对LLVM编译器都做了重大改进,新版的Xcode 4.4中的LLVM编译器升级到了4.0,给Objective-C带来了很多令人惊喜的特性。
注意,下面的语法需要下载Xcode 4.4。
老写法:
typedef enum Week{ Moday, Tuesday, Wednesday, Thursday, Friday, Saturday, Sunday }Week;老方法的问题是枚举值的数据范围是模糊的,这个数值可能非常大,可能是负数,无法界定
新写法:
typedef enum Week:NSUInteger{ Moday, Tuesday, Wednesday, Thursday, Friday, Saturday, Sunday }Week;新方法在列出枚举内容的同时绑定了枚举数据类型NSUInteger,这样带来的好处是增强的类型检查和更好的代码可读性。
没在.h文件中声明的方法,在时候的时候如果方法不在前面,可能会有警告。
比如:
@interface MyClass : NSObject -(void)doSomething:(NSString *) print; @end
@implementation MyClass -(void)doSomething:(NSString *)print{ NSLog(@"%@", [print stringByAppendingFormat:[self getString]]); } -(NSString *)getString{ return@"string for something"; } @end
新的编译器会先扫描代码中的方法,然后再编译,这样就避免了找不到方法这种情况了
@property对于使用Objective-C的程序员来说是相当熟悉的,property方便自动生成变量的getter 和setter。在.h文件中声明之后,还要在.m文件中加上@synthesize关键字,这样才能完成自动getter 和setter的过程。
比如说,我在.h文件中写了
@property (strong, nonatomic) NSDictionary *order;
我还要去对于的.m文件中写上@synthesize order;
是不是感觉很多余啊?现在在语法新特性中不用写这行代码了,新版的编译器帮你实现这行代码,这叫帮人帮到底。也是说,你在.h文件中声明order属性后,就可以直接在实现文件中使用该属性的getter和setter方法,编译器还会根据属性的可读和可写自动判断是否提供setter方法。智能多了。
咱们看看各个数据类型简化前后的对比。
老写法:
NSNumber *number; number = [NSNumber numberWithChar:'X']; number = [NSNumber numberWithInt:12345]; number = [NSNumber numberWithUnsignedLong:12345ul]; number = [NSNumber numberWithLongLong:12345ll]; number = [NSNumber numberWithFloat:123.45f]; number = [NSNumber numberWithDouble:123.45]; number = [NSNumber numberWithBool:YES];
新写法:
NSNumber *number; number = @'X'; number = @12345; number = @12345ul; number = @12345ll; number = @123.45f; number = @123.45; number = @YES;
老写法:
NSArray *array; array = [NSArray arrayWithObjects:@"object1", @"object2", @"object3", nil];
NSArray *array = @[ @"object1", @"object2", @"object3" ];
4.3、NSDictionary类型
老写法
NSDictionary *dict = [NSDictionary dictionaryWithObjects:@[@"value1", @"value2", @"value3"] forKeys:@[@"key1", @"key2", @"key3"]];新写法
NSDictionary *dict = @{@"key1": @"value1",@"key2": @"value2",@"key3": @"value3" }; NSLog(@"%@", dict);
运行结果正常:
{
key1 = value1;
key2 = value2;
key3 = value3;
}
他们说新的语法这样是可以的,数组和字典都可以通过下标访问,
NSArray *array =@[ @"object1", @"object2", @"object3" ]; id obj = array[0]; //通过下标方式获取数组对象,替换原有写法:array objectAtIndex:i]; NSString *obj1 = @"oooo"; array[0] = obj1; //也可以直接为数组对象赋值。替换原有写法:[array replaceObjectAtIndex:i withObject:newObj]; NSDictionary *dict = @{@"key1": @"value1",@"key2": @"value2",@"key3": @"value3" }; id obj2 = dict[@"key1"];//获取o2对象,替换原有写法:[dic objectForKey:k2]; dict[@"key2"] = obj; //重新为键为k2的对象赋值,替换原有写法:[dic setObject:newObj forKey:k2]可是事实是这样的:
现实总是残忍的。于是google 了一下,发现这个语法是针对iOS 6 or OS X 10.8 SDKs的,我没有ios 6模拟器而已没有10.8 SDKs。所以报错了。可以参考这里:http://stackoverflow.com/questions/11425976/compiler-error-expected-method-not-found-when-using-subscript-on-nsarray
截图可以给你解释,新的语法特性编译器是怎么实现的。
著作权声明:本文由http://blog.csdn.net/totogo2010/原创,欢迎转载分享。请尊重作者劳动,转载时保留该声明和作者博客链接,谢谢!