多线程交替输出字符串(2)

与上一篇逻辑类似,这里采用同样的生产者消费者模式

创建线程使用了BlockOperation封装操作,使用OperationQueue作为并发队列

代码如下:

复制代码
import Foundation
var run: Bool = true
/// 将字符转成UInt8
func charToInt(chr: Character) -> UInt8? {
    return chr.asciiValue
}
/// 将Uint8转成字符
func intToChr(asciiValue: UInt8) -> Character? {
    return Character(UnicodeScalar(asciiValue))
}
///
let group = DispatchGroup()
group.enter()
let queue = OperationQueue()
queue.maxConcurrentOperationCount = 2
guard var start1: UInt8 = charToInt(chr: Character("A")) else {
    exit(-1)
}
let semaphore1 = DispatchSemaphore(value: 1)
let semaphore2 = DispatchSemaphore(value: 0)

let op1 = BlockOperation(block: {
    while run {
        sleep(1)
        semaphore1.wait()
        let first = (start1 - 65) % 26 + 65
        start1 = start1 + 1
        let second = (start1 - 65) % 26 + 65
        start1 = start1 + 1
        print("\(intToChr(asciiValue: first)!), \(intToChr(asciiValue: second)!)")
        semaphore2.signal()
    }
    group.leave()
})
var start2 = 0
let op2 = BlockOperation(block: {
    while run {
        sleep(1)
        semaphore2.wait()
        print("\(start2 % 10)")
        start2 = start2 + 1
        semaphore1.signal()
    }
    group.leave()
})
queue.addOperation(op1)
queue.addOperation(op2)
group.wait()
复制代码

 

posted @   兜兜有糖的博客  阅读(81)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
历史上的今天:
2017-03-13 IOS Video Tool Box后台解码失败
点击右上角即可分享
微信分享提示