当前位置:编程学习 > wap >>

NSLock为什么不能锁住

#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不是互斥锁嘛?
请高手指导,谢谢! NSLock ios同步 多线程 锁 --------------------编程问答--------------------
    [NSThread detachNewThreadSelector:@selector(run:) toTarget:self withObject:self];
    [NSThread mainThread].name = @"Main";
    NSLog(@"main thread name is %@", [[NSThread mainThread]name]);
    
    bEnterEmShop = YES;
    enterEmShopLock = [[NSLock alloc]init];
    [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];

头文件忘记初始化了,不过这样也还是不行,还是会出现上述问题,不知道什么原因! --------------------编程问答-------------------- 原来是我自己写错了,在启动子线程的时候,detachNewThreadSelector 是立即启动,这个时候我的初始化放在他的后面,这样当执行子线程的时候,就是未初始化的数据。
补充:移动开发 ,  iPhone
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,