#import <Foundation/Foundation.h>
@interface MainUI : NSObject
{
NSLock* _lock;
}
-(void)initialize;
@property(nonatomic, retain) NSLock* _enterEmShopLock;
@property(atomic, assign) volatile BOOL _bEnterEmShop;
@end
#import "MainUI.h"
@implementation MainUI
@synthesize _bEnterEmShop=bEnterEmShop;
@synthesize _enterEmShopLock=enterEmShopLock;
-(void)initialize
{
[NSThread detachNewThreadSelector:@selector(run:) toTarget:self withObject:nil];
[NSThread mainThread].name = @"Main";
NSLog(@"main thread name is %@", [[NSThread mainThread]name]);
bEnterEmShop = YES;
[enterEmShopLock lock];
NSLog(@"cur thread name is %@ and enter lock", [[NSThread currentThread]name]);
[NSThread sleepUntilDate:[NSDate dateWithTimeIntervalSinceNow:2]];
NSLog(@"cur thread name is %@ and exit unlock", [[NSThread currentThread]name]);
[enterEmShopLock unlock];
}
-(void)run:(MainUI*)mainUI
{
[NSThread currentThread].name = @"Sub";
if(!mainUI._bEnterEmShop)
{
NSLog(@"cur thread name is %@", [[NSThread currentThread]name]);
[[mainUI _enterEmShopLock]lock];
NSLog(@"cur thread name is %@ and enter lock", [[NSThread currentThread]name]);
[NSThread sleepUntilDate:[NSDate dateWithTimeIntervalSinceNow:2]];
NSLog(@"cur thread name is %@ and exit unlock", [[NSThread currentThread]name]);
[[mainUI _enterEmShopLock]unlock];
}
else {
NSLog(@"cur thread name is %@ and can't be allowed to do anything", [[NSThread currentThread]name]);
}
}
@end
出现的结果:
2013-10-13 16:50:41.368 ThreadSynPrj[18231:f803] main thread name is Main
2013-10-13 16:50:41.368 ThreadSynPrj[18231:1290b] cur thread name is Sub
2013-10-13 16:50:41.370 ThreadSynPrj[18231:f803] cur thread name is Main and enter lock
2013-10-13 16:50:41.370 ThreadSynPrj[18231:1290b] cur thread name is Sub and enter lock
2013-10-13 16:50:43.372 ThreadSynPrj[18231:f803] cur thread name is Main and exit unlock
2013-10-13 16:50:43.372 ThreadSynPrj[18231:1290b] cur thread name is Sub and exit unlock
为什么主线程没有退出,子线程又进来了?NSLock不是互斥锁嘛?
请高手指导,谢谢!