使用NSOperation和NSOperationQueue启动iOS多线程

在app store中的很多应用程序非常的笨重,他们有好的界面,但操作性很差,比如说当程序从网上或本地载入数据的时候,界面被冻结了,用户只能等程序完全载入数据之后才能进行操作。
当打开一个应用程序时,iphone会产生一个包含main方法的线程,所用程序中的界面都是运行在这个线程之中的(table views, tab bars, alerts…),有时候我们会用数据填充这些view,现在问 题是如何有效的载入数据,并且用户还能自如的操作程序。方法是启动新的线程,专门用于数据的下载,而主线程不会因为下载数据被阻塞。
不管使用任何编程语言,在实现多线程时都是一件很麻烦的事情。更糟糕的是,一旦出错,这种错误通常相当糟糕。然而,幸运的是apple从os x10.5在这方面做了很多的改进,NSThread的引入,使得开发多线程应用程序容易多了。除此之外,它们还引入了两个全新的类,NSOperation和NSOperationQueue。
接下来我们通过一个实例来剖析如何使用这两个类实现多线程。这里指示展示这两个类的基本用法,当然这不是使用他们的唯一办法。

继续阅读 More

ObjectiveC中的单例设计模式

注意class method中什么时候用self,什么时候用super!

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
#import "PostOfficeProxy.h"  
#import "HTTPPostOffice.h"
static PostOffice *_sharedPostOffice = nil;
@implementation PostOfficeProxy
@synthesize realPostOffice;
+ (PostOffice*)sharedPostOfficeProxy {
NSLog(@"shared");
@synchronized([PostOffice class]) {
if (nil == _sharedPostOffice) {
[[self alloc] init];

}
}
return _sharedPostOffice;
}
+ (id)allocWithZone:(NSZone *)zone {
NSLog(@"alloc zone");
@synchronized([PostOffice class]) {
if (nil == _sharedPostOffice) {
_sharedPostOffice= [super allocWithZone:zone];


}
}
return _sharedPostOffice;
}
- (id)init {
NSLog(@"init");
self = [super init];
if (nil != self) {
self.realPostOffice = [[HTTPPostOffice alloc] init];
}

return self;

}
- (id)copyWithZone:(NSZone *)zone {
return self;
}
- (id)retain
{
return self;
}
- (unsigned)retainCount
{
return UINT_MAX;
}
- (void)release
{
//do nothing
}
- (id)autorelease
{
return self;
}
@end