当前位置: 首页 > 编程笔记 >

IOS开发-多线程队列测试代码

姚子石
2023-03-14
本文向大家介绍IOS开发-多线程队列测试代码,包括了IOS开发-多线程队列测试代码的使用技巧和注意事项,需要的朋友参考一下

直接贴测试代码了。

当前考虑的问题:
1.队列有多少个消费者
2.添加到队列的新task是同步运行(当前线程阻塞)还是异步(当前线程不阻塞)
3.多个队列之间的调度(此文章未涉及)

//
// 单线程和多线程并发队列测试(同步和异步)
//
// 基础原理:
// 1)队列:
//  1.1 dispatch_queue_t 是一个队列,一个FIFO的消费队列
//  1.2 消费者:队列配置的运行线程
//  1.3 被消费对象: 添加到队列中的运行任务(block等)
//  1.4 运行任务:将任务放到队列中,等待消费者消费
// 2)同步,异步  (对于任务) (此处的运行指将任务发入到请求队列中)
//  2.1 同步:A任务在运行时,插入B任务,A任务等待B任务运行完才能运行
//  2.2 异步: A任务在运行时,插入B任务,A任务不等待并且继续运行,B任务也运行
// 假设:
// ATask: 运行fooA的Block
// BTask: 运行fooB的Block
//
//
// 总结:
// 不管单线程或多线程,同步或异步,一定要联系请求队列考虑



#import "TestQueueSi.h"

@interface TestQueueSi ()

@property (strong,nonatomic) dispatch_queue_t serialQueue;
@property (strong,nonatomic) dispatch_queue_t concurrentQueue;

@end

@implementation TestQueueSi


- (instancetype)init {
  self = [super init];
  if(self) {
    _serialQueue = dispatch_queue_create("chenhh.serialQueue", DISPATCH_QUEUE_SERIAL);
    _concurrentQueue = dispatch_queue_create("chenhh.concurrentQueue", DISPATCH_QUEUE_CONCURRENT);

  }
  return self;
}

/**
 QUEUE_SERIAL(单线程) 同步
 死锁崩溃
 
 1.ATask运行,同步加入BTask
 2.BTask加入到请求队列中,可是没有其他空余线程(ATask线程在 等待BTask),BTask等待空余线程,
 3.死锁发生
 
 */
- (void)testSerialQueueSync {
  dispatch_sync(_serialQueue,^{
    [self fooA];
    dispatch_sync(_serialQueue,^{
       [self fooB];
    });
    [self fooA];
  });
}

/**
 QUEUE_CONCURRENT(多线程) 同步
 正常运行

 1.ATask运行,同步加入BTask,Atask线程等待
 2.BTask加入到请求队列中,有其他空余线程(ATask线程在等待BTask),BTask运行
 3.BTask运行结束,ATask停止等待,继续运行
 
 */
- (void)testConcurrentQueueSync {
  dispatch_sync(_concurrentQueue,^{
    [self fooA];
    NSLog(@"first");
    
    // 同步 需要等待运行结果
    dispatch_sync(_concurrentQueue,^{
      [self fooB];
    });
    
    // 等待同步代码完成,再运行
    [self fooA];
  });
}

/*
 QUEUE_SERIAL(单线程) 异步
 正常
 
 
 1.ATask运行,异步加入BTask,Atask线程继续运行不等待
 2.BTask加入到请求队列中,没有其他空余线程(ATask线程在正常运行),BTask等待空余
 3.ATask运行完成,线程空出,BTask运行
 
 */
- (void)testSerialQueueAsync {
  dispatch_async(_serialQueue,^{
    [self fooA];
    dispatch_async(_serialQueue,^{
      [self fooB];
    });
     [self fooA];
  });
}

/**
 QUEUE_CONCURRENT(多线程) 异步
 正常运行
 
 1.ATask运行,同步加入BTask,Atask线程继续运行不等待
 2.BTask加入到请求队列中,有其他空余线程(ATask等线程在正常运行),BTask运行(ABTask同时运行)
 
 */
- (void)testConcurrentQueueAsync {
  dispatch_async(_concurrentQueue,^{
    [self fooA];
    // 同步 需要等待运行结果
    dispatch_async(_concurrentQueue,^{
      [self fooB];
    });
    
    // 等待同步代码完成,再运行
    [self fooA];
  });
}

- (void)fooA {
  NSLog(@" ************ fooA ************ ");
}

- (void)fooB {
  NSLog(@" ************ fooB ************ ");
}

@end
 类似资料:
  • 本文向大家介绍iOS多线程开发——NSThread浅析,包括了iOS多线程开发——NSThread浅析的使用技巧和注意事项,需要的朋友参考一下   在iOS开发中,多线程的实现方式主要有三种,NSThread、NSOperation和GCD,我前面博客中对NSOperation和GCD有了较为详细的实现,为了学习的完整性,今天我们主要从代码层面来实现NSThread的使用。案例代码上传至 http

  • 本文向大家介绍IOS多线程开发之线程的状态,包括了IOS多线程开发之线程的状态的使用技巧和注意事项,需要的朋友参考一下 大家都知道,在开发过程中应该尽可能减少用户等待时间,让程序尽可能快的完成运算。可是无论是哪种语言开发的程序最终往往转换成汇编语言进而解释成机器码来执行。但是机器码是按顺序执行的,一个复杂的多步操作只能一步步按顺序逐个执行。改变这种状况可以从两个角度出发:对于单核处理器,可以将多个

  • 问题 你有一个线程队列集合,想为到来的元素轮询它们, 就跟你为一个客户端请求去轮询一个网络连接集合的方式一样。 解决方案 对于轮询问题的一个常见解决方案中有个很少有人知道的技巧,包含了一个隐藏的回路网络连接。 本质上讲其思想就是:对于每个你想要轮询的队列,你创建一对连接的套接字。 然后你在其中一个套接字上面编写代码来标识存在的数据, 另外一个套接字被传给 select() 或类似的一个轮询数据到达

  • 我需要一个库或我们的软件工具,可以: 1)将线程/作业/任务(任何东西--如果需要,我们可以重写代码,我们在mintue有线程对象)放入像system这样的队列中2)我们可以定义同时最多运行多少线程3)线程完成后,线程从队列中移除,这样GC就可以移除所有涉及的实体。 我正在进行大量阅读,发现ExecutorService(Executors.newFixedThreadPool(5);)但问题可能

  • 在使用TensorFlow进行异步计算时,队列是一种强大的机制。 正如TensorFlow中的其他组件一样,队列就是TensorFlow图中的节点。这是一种有状态的节点,就像变量一样:其他节点可以修改它的内容。具体来说,其他节点可以把新元素插入到队列后端(rear),也可以把队列前端(front)的元素删除。 为了感受一下队列,让我们来看一个简单的例子。我们先创建一个“先入先出”的队列(FIFOQ

  • 考试的时候没做出来,下去看了看,有了下面的思路,代码在我这边均可成功运行。用的Java语言。 1.n个格子,小明操作m次,输入m行,每行包括两个整数,代表小明连续涂鸦的格子。输出一个整数s,表示有s段连续的黑色格子。 2.n把武器,k个强化石,每个强化石作用到武器上面强化1级。输出一个数,表示所有的武器等级中位数能达到最大值。 第一题 #秋招#