ObjC 线程同步加锁[转]

2024-01-27 19:18
文章标签 线程 同步 加锁 objc

本文主要是介绍ObjC 线程同步加锁[转],希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


Objective-C对线程同步和异常处理提供支持,关于异常处理,请参考“Exception Handling.” 你可以使用编译标记-fobjc-exceptions来打开对异常的支持,不过必须是在GCC3.3或以上版本中才能使用。

注: 只是线程同步或异常的程序必须在Mac OS X10.3版本或以上的系统运行,应为以前的版本不支持这些特性。

Objective-C支持多线程。因此会存在两个线程在同一个时间访问同一资源的可能,这是一个很危险的事情。为了让一个线程能一次不受打断的执行完一段代码,Objective-C提供了@synchronized()来阻止上面这样事情的发生。

@synchronized()导致被保护的代码块只能被一个线程执行,其他的线程在试图执行这个代码块的时候会被阻塞,直到当前正在执行这个代码块的线程执行完这个代码块的最后一句话。

@synchronized()可以使用一个Objective-C对象(包括self)来作为参数。这个对象作为信号量使用。它可以锁住一节代码,免得多个线程进入。在程序,你应该使用不同的信号量来锁不同的代码。在程序进入多线程前创建所有的心好了,以避免有争用的情况出现。

Listing 11-1演示了使用self作为信号量来锁住这个实例函数的代码。在稍后的例子中,任何时候只有一个线程执行受保护的代码,因为它使用了但例模式。

Listing 11-1  使用self对函数加锁

- (void)criticalMethod{ @synchronized(self) { // Critical code. ... }}

一般情况下,我们使用Listing 11-2演示的方式。在获得对互斥资源的访问前,你需要使用获得Account类的信号量,然后对这个信号量加锁。这个信号量一般在Account类的初始化函数中创建。

Listing 11-2  使用自定义互斥量加锁

Account *account = [Account accountFromString:[accountField stringValue]];// Get the semaphore.id accountSemaphore = [Account semaphore];@synchronized(accountSemaphore) { // Critical code. ...}

Objective-C的同步机制支持回归调用和重入机制。一个线程可以多次对一个信号量加锁;其他的线程会等到这个线程对这个信号量的所有解锁。也就是说,每一个@synchronized()块都正常退出或抛出异常。

当在@synchronized()块中代码抛出了一个异常,Objective-C运行器会捕获这个异常,然后是否这个信号量(以利于受保护资源能被其他线程访问),然后前转者个异常到后继异常处理模块。

转自:http://www.it900.net/yingyongchengxu/268.html

这篇关于ObjC 线程同步加锁[转]的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/651226

相关文章

C#控制台程序同步调用WebApi实现方式

《C#控制台程序同步调用WebApi实现方式》控制台程序作为Job时,需同步调用WebApi以确保获取返回结果后执行后续操作,否则会引发TaskCanceledException异常,同步处理可避免异... 目录同步调用WebApi方法Cls001类里面的写法总结控制台程序一般当作Job使用,有时候需要控制

Go语言使用sync.Mutex实现资源加锁

《Go语言使用sync.Mutex实现资源加锁》数据共享是一把双刃剑,Go语言为我们提供了sync.Mutex,一种最基础也是最常用的加锁方式,用于保证在任意时刻只有一个goroutine能访问共享... 目录一、什么是 Mutex二、为什么需要加锁三、实战案例:并发安全的计数器1. 未加锁示例(存在竞态)

SpringBoot实现虚拟线程的方案

《SpringBoot实现虚拟线程的方案》Java19引入虚拟线程,本文就来介绍一下SpringBoot实现虚拟线程的方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录什么是虚拟线程虚拟线程和普通线程的区别SpringBoot使用虚拟线程配置@Async性能对比H

在Java中实现线程之间的数据共享的几种方式总结

《在Java中实现线程之间的数据共享的几种方式总结》在Java中实现线程间数据共享是并发编程的核心需求,但需要谨慎处理同步问题以避免竞态条件,本文通过代码示例给大家介绍了几种主要实现方式及其最佳实践,... 目录1. 共享变量与同步机制2. 轻量级通信机制3. 线程安全容器4. 线程局部变量(ThreadL

Linux线程同步/互斥过程详解

《Linux线程同步/互斥过程详解》文章讲解多线程并发访问导致竞态条件,需通过互斥锁、原子操作和条件变量实现线程安全与同步,分析死锁条件及避免方法,并介绍RAII封装技术提升资源管理效率... 目录01. 资源共享问题1.1 多线程并发访问1.2 临界区与临界资源1.3 锁的引入02. 多线程案例2.1 为

Java中的xxl-job调度器线程池工作机制

《Java中的xxl-job调度器线程池工作机制》xxl-job通过快慢线程池分离短时与长时任务,动态降级超时任务至慢池,结合异步触发和资源隔离机制,提升高频调度的性能与稳定性,支撑高并发场景下的可靠... 目录⚙️ 一、调度器线程池的核心设计 二、线程池的工作流程 三、线程池配置参数与优化 四、总结:线程

WinForm跨线程访问UI及UI卡死的解决方案

《WinForm跨线程访问UI及UI卡死的解决方案》在WinForm开发过程中,跨线程访问UI控件和界面卡死是常见的技术难题,由于Windows窗体应用程序的UI控件默认只能在主线程(UI线程)上操作... 目录前言正文案例1:直接线程操作(无UI访问)案例2:BeginInvoke访问UI(错误用法)案例

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

Javaee多线程之进程和线程之间的区别和联系(最新整理)

《Javaee多线程之进程和线程之间的区别和联系(最新整理)》进程是资源分配单位,线程是调度执行单位,共享资源更高效,创建线程五种方式:继承Thread、Runnable接口、匿名类、lambda,r... 目录进程和线程进程线程进程和线程的区别创建线程的五种写法继承Thread,重写run实现Runnab