Objective-C进化特性
Objective-C进化特性
[TOC]
毫无疑问,Objective-C (下称ObjC)在诞生三十年后,因为iOS系统在移动设备领域的制霸,迎来了近五年来一年一波的进化,这些新特性表明ObjC这个年事已高的语言,仍在一步一步追逐现代编程语言的步伐。
Modern Objective-C 现代Objective-C语言
Automatic Reference Counting
自动引用计数技术,简称ARC,是Objective-C的一项重要进化。编译器在编译过程中,自动分析代码,为对象添加release、retain、dealloc调用,大大减少开发中的内存管理代码,减少了工程师将近三分之一的工作负担,并且更加安全稳定。
如今的Xcode工程,都自动开启了ARC模式,在这种模式下,工程师不可以手动调用release、retain、dealloc、autoreloease等函数,但工程师还是可以灵活处理。
例如:
@property (nonatomic, strong) NSArray* datas;...//某处self.datas = nil; //编译器会自动在这据句调用前执行 [self.datas release];...
在例如:
@autoreleasepool { //括号里面分配内存的对象,都会加入大括号包裹的自动释放持,在大括号结束时释放。 }
当然,任何ObjC的方法,每一对大括号都是自带自动释放池的,不是特殊需要不用特别地使用@autoreleasepool。
Literals 字面量特性
这个的翻译一直很难确定,可以认为是一种简写。
不使用Literals特性时我们这样写:
NSArray *myArray = [NSArray arrayWithObjects:object1,object2,object3,nil];NSDictionary *myDictionary1 = [NSDictionary dictionaryWithObject:someObject forKey:@"key"];NSDictionary *myDictionary2 = [NSDictionary dictionaryWithObjectsAndKeys:object1, key1, object2, key2, nil];NSNumber *myNumber = [NSNumber numberWithInt:myInt];NSNumber *mySumNumber= [NSNumber numberWithInt:(2 + 3)];NSNumber *myBoolNumber = [NSNumber numberWithBool:YES];
使用Literals特性,就可以简写了:
NSArray *myArray = @[ object1, object2, object3 ];NSDictionary *myDictionary1 = @{ @"key" : someObject };NSDictionary *myDictionary2 = @{ key1: object1, key2: object2 };NSNumber *myNumber = @(myInt);NSNumber *mySumNumber = @(2+3);NSNumber *myBoolNumber = @YES;NSNumber *myIntegerNumber = @8;
让基本数据对象,操作起来更便捷,就是一大进步。
Subscripting
同样举例比对,首先是不使用Subscripting特性
id object1 = [someArray objectAtIndex:0];id object2 = [someDictionary objectForKey:@"key"];[someMutableArray replaceObjectAtIndex:0 withObject:object3];[someMutableDictionary setObject:object4 forKey:@"key"];
然后是用了Subscripting特性
id object1 = someArray[0];id object2 = someDictionary[@"key"];someMutableArray[0] = object3;someMutableDictionary[@"key"] = object4;
一目了然,更接近现代编程语言的风格。
技术革新
block 闭包
iOS4引入的block特性,看看下面的例子,关于闭包的详细我们将单独写一篇文章进行讲解。
# include # include typedef int (^IntBlock)();IntBlock MakeCounter(int start, int increment) { __block int i = start; return Block_copy( ^ { int ret = i; i += increment; return ret; });}int main(void) { IntBlock mycounter = MakeCounter(5, 2); printf("First call: %d\n", mycounter()); printf("Second call: %d\n", mycounter()); printf("Third call: %d\n", mycounter()); /* because it was copied, it must also be released */ Block_release(mycounter); return 0;}/* Output: First call: 5 Second call: 7 Third call: 9*/
Grand Central Dispatch
简称GCD技术,是Apple开发的用于简化开发多核多线程编程提供的一套底层C接口,详细内容将在单独的章节进行讲解。
//单线程阻塞
- (IBAction)analyzeDocument:(NSButton *)sender { NSDictionary *stats = [myDoc analyze]; [myModel setDict:stats]; [myStatsView setNeedsDisplay:YES];}
//多线程异步等待,数据加载完毕后,主线程渲染。
- (IBAction)analyzeDocument:(NSButton *)sender { dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{ NSDictionary *stats = [myDoc analyze]; dispatch_async(dispatch_get_main_queue(), ^{ [myModel setDict:stats]; [myStatsView setNeedsDisplay:YES]; }); });}
关键字:产品经理
版权声明
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处。如若内容有涉嫌抄袭侵权/违法违规/事实不符,请点击 举报 进行投诉反馈!