一、NSCondition是对条件变量互斥量的一个封装,用于线程之间的同步。

  其中的互斥量用于保护对条件变量的修改,条件变量变化以信号量的方式通知其它线程实现线程之间的同步。

  

二、NSCondition的API

  NSCondition实现了NSLocking协议,这个协议定义了lock和unlock方法,用于多个线程互斥得执行一段代码,以保护共享的数据。

  同时,NSCondition还包含以下方法:

  - (void)wait;

  - (BOOL)waitUntilDate:(NSDate *)limit;

  - (void)signal;

  - (void)broadcast;

  

  wait:释放互斥量,使当前线程等待,切换到其它线程执行。

  waitUntilDate:释放互斥量,使当前线程等待到某一个时间,切换到其它线程执行。

  signal:唤醒一个其它等待该条件变量的线程

  broadcast:唤醒所有其它等待该条件变量的线程

三、demo

  下面的例子来源于网络,对其做了一点修改

  

 int main(int argc, const char * argv[]) {
@autoreleasepool {
// insert code here... NSConditionSample *sample = [[NSConditionSample alloc] init]; [NSThread detachNewThreadSelector:@selector(createConsumenr)
toTarget:sample
withObject:nil]; [NSThread detachNewThreadSelector:@selector(createProducter)
toTarget:sample
withObject:nil]; getchar();
}
return ;
}

  下面是生产者、消费者:

 #import "NSConditionSample.h"

 @interface NSConditionSample ()
{
NSCondition *condition;
NSMutableArray *products;
} @end @implementation NSConditionSample - (instancetype)init
{
if(self = [super init])
{
condition = [[NSCondition alloc] init];
products = [[NSMutableArray alloc] init];
}
return self;
} - (void)createConsumenr
{
while (YES) {
NSLog(@"createConsumenr before lock");
[condition lock];
NSLog(@"createConsumenr after lock");
while ([products count] == ) {
NSLog(@"wait for products");
[condition wait];
}
[products removeObjectAtIndex:];
NSLog(@"comsume a product");
[condition unlock];
}
} - (void)createProducter
{
while (YES) {
NSLog(@"createProducter before lock");
[condition lock];
NSLog(@"createProducter after lock");
[products addObject:[[NSObject alloc] init]];
NSLog(@"produce a product");
[condition signal];
[condition unlock];
} } @end

执行的log:

2015-07-24 11:05:48.374 NSConditionSample[45259:40628634] createConsumenr before lock

2015-07-24 11:05:48.374 NSConditionSample[45259:40628635] createProducter before lock

2015-07-24 11:05:48.374 NSConditionSample[45259:40628634] createConsumenr after lock

2015-07-24 11:05:48.375 NSConditionSample[45259:40628634] wait for products

2015-07-24 11:05:48.375 NSConditionSample[45259:40628635] createProducter after lock

2015-07-24 11:05:48.375 NSConditionSample[45259:40628635] produce a product

2015-07-24 11:05:48.375 NSConditionSample[45259:40628635] createProducter before lock

2015-07-24 11:05:48.375 NSConditionSample[45259:40628634] comsume a product

2015-07-24 11:05:48.375 NSConditionSample[45259:40628634] createConsumenr before lock

2015-07-24 11:05:48.375 NSConditionSample[45259:40628635] createProducter after lock

2015-07-24 11:05:48.375 NSConditionSample[45259:40628635] produce a product

2015-07-24 11:05:48.375 NSConditionSample[45259:40628634] createConsumenr after lock

2015-07-24 11:05:48.375 NSConditionSample[45259:40628635] createProducter before lock

2015-07-24 11:05:48.375 NSConditionSample[45259:40628634] comsume a product

2015-07-24 11:05:48.376 NSConditionSample[45259:40628634] createConsumenr before lock

2015-07-24 11:05:48.376 NSConditionSample[45259:40628635] createProducter after lock

2015-07-24 11:05:48.376 NSConditionSample[45259:40628635] produce a product

2015-07-24 11:05:48.376 NSConditionSample[45259:40628634] createConsumenr after lock

2015-07-24 11:05:48.376 NSConditionSample[45259:40628635] createProducter before lock

2015-07-24 11:05:48.376 NSConditionSample[45259:40628634] comsume a product

2015-07-24 11:05:48.390 NSConditionSample[45259:40628634] createConsumenr before lock

2015-07-24 11:05:48.390 NSConditionSample[45259:40628635] createProducter after lock

2015-07-24 11:05:48.390 NSConditionSample[45259:40628635] produce a product

NSCondition的更多相关文章

  1. NSCondition的用法,NSCondication实现线程同步,生产者消费问题实现(转载)

    NSCondition的用法 使用NSCondition,实现多线程的同步,即,可实现生产者消费者问题. 基本思路是,首先要创建公用的NSCondition实例.然后: 消费者取得锁,取产品,如果没有 ...

  2. 使用NSCondition实现多线程同步

    iOS中实现多线程技术有非常多方法. 这里说说使用NSCondition实现多线程同步的问题,也就是解决生产者消费者问题(如收发同步等等). 问题流程例如以下: 消费者取得锁,取产品,假设没有,则wa ...

  3. NSCondition用法

    NSCondition用法 使用NSCondition,实现多线程同步...举个列子 消费者跟生产者... 现在传言6s要出了.. 消费者想买6s.现在还没有6s.消费者等待6s生产. 生产了一个产品 ...

  4. iOS线程之——NSCondition

    多线程在各种编程语言中都是难点,很多语言中实现起来很麻烦,objective-c虽然源于c,但其多线程编程却相当简单,可以与java相媲美.这篇文章主要从线程创建与启动.线程的同步与锁.线程的交互.线 ...

  5. NSCondition(转)

    NSConditionLock 继承类NSObject 遵从的协议NSLocking NSObject NSConditionLock 类定义特定的.用户定义的条件锁 协议NSLocking 方法 l ...

  6. 修改版: 小伙,多线程(GCD)看我就够了,骗你没好处!

    多线程(英语:multithreading),是指从软件或者硬件上实现多个线程并发执行的技术.具有多线程能力的计算机因有硬件支持而能够在同一时间执行多于一个线程,进而提升整体处理性能.具有这种能力的系 ...

  7. iOS开发系列--并行开发其实很容易

    --多线程开发 概览 大家都知道,在开发过程中应该尽可能减少用户等待时间,让程序尽可能快的完成运算.可是无论是哪种语言开发的程序最终往往转换成汇编语言进而解释成机器码来执行.但是机器码是按顺序执行的, ...

  8. iOS-多线程基础

    进程与线程: 1>   一个应用程序对应一个进程,一个进程帮助程序占据一块存储空间 2>   要想在进程中执行任务,就必须开启线程,一条线程就代表一个任务 3>   一个进程中允许开 ...

  9. 谈谈iOS中的锁

    1 前言 近日工作不是太忙,刚好有时间了解一些其他东西,本来打算今天上午去体检,但是看看天气还是明天再去吧,也有很大一个原因:就是周六没有预约上!闲话少说,这里简单对锁来个简单介绍分享. 2 目录 第 ...

随机推荐

  1. 关于map()与filter()

    def f1(a): if a == 3: pass else: return a*a li = [1,2,3,4] for i in filret(f1,li) print(i) def f1(a) ...

  2. http://www.spasvo.com/ceshi/open/kyxncsgj/Jmeter/

    http://www.spasvo.com/ceshi/open/kyxncsgj/Jmeter/

  3. CSS3学习之——【特殊属性】

    一.CSS3的一些特殊属性 1.1 text-shadow text-shadow曾经在css2中就出现过,但在css2.1版本中又被抛弃了,现在css3.0版本又重新捡回来了.这说明text-sha ...

  4. fiddler还是浏览器的问题

    当我在浏览器里输入http://localhost/infomanage/price?cityid=1&cateid=246&timer=3 后端接收的参数是timer的时候,浏览器会 ...

  5. CODE[VS]-数的计算-递推-天梯白银

    题目描述 Description 我们要求找出具有下列性质数的个数(包含输入的自然数n): 先输入一个自然数n(n<=1000),然后对此自然数按照如下方法进行处理: 1.不作任何处理; 2.在 ...

  6. 字符函数库 - cctype 和 climits 中的符号常量

    一. C++从C语言中继承一个与字符相关的.非常方便的函数软件包,他可以简化诸如确定字符是否为大写字母‘数字.标点符号等工作,这些函数的原型在头文件cctype(老式的为ctype.h)中定义的.例如 ...

  7. Facebook 在page添加自己开发的app

    最初接到的需求是,在facebook主页中嵌入一个类似这样领取游戏礼包的页面. 一开始连facebook开发者中心在哪里都不知道,在万能的搜索框里面找到static html之类的第三方应用,但是这样 ...

  8. Gulp安装使用教程

    题记:为什么要使用gulp,网上有很多关于gulp的优势,而在我看来,这些都是工具的优势!工具的优势最主要体现在易用性上,听说gulp比grunt更易用,所以这里写个文档记录. 同样要保证nodejs ...

  9. ibaits的一个简单的完整的例子

    ibaits的简单介绍: iBatis 是apache 的一个开源项目,一个O/R Mapping(对象/关系映射) 解决方案,iBatis 最大的特点就是小巧,上手很快.如果不需要太多复杂的功能,i ...

  10. 一个快速、高效的Levenshtein算法实现——代码实现

    在网上看到一篇博客讲解Levenshtein的计算,大部分内容都挺好的,只是在一些细节上不够好,看了很长时间才明白.我对其中的算法描述做了一个简单的修改.原文的链接是:一个快速.高效的Levensht ...