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

相关文章

Java多线程父线程向子线程传值问题及解决

《Java多线程父线程向子线程传值问题及解决》文章总结了5种解决父子之间数据传递困扰的解决方案,包括ThreadLocal+TaskDecorator、UserUtils、CustomTaskDeco... 目录1 背景2 ThreadLocal+TaskDecorator3 RequestContextH

java父子线程之间实现共享传递数据

《java父子线程之间实现共享传递数据》本文介绍了Java中父子线程间共享传递数据的几种方法,包括ThreadLocal变量、并发集合和内存队列或消息队列,并提醒注意并发安全问题... 目录通过 ThreadLocal 变量共享数据通过并发集合共享数据通过内存队列或消息队列共享数据注意并发安全问题总结在 J

异步线程traceId如何实现传递

《异步线程traceId如何实现传递》文章介绍了如何在异步请求中传递traceId,通过重写ThreadPoolTaskExecutor的方法和实现TaskDecorator接口来增强线程池,确保异步... 目录前言重写ThreadPoolTaskExecutor中方法线程池增强总结前言在日常问题排查中,

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

详谈redis跟数据库的数据同步问题

《详谈redis跟数据库的数据同步问题》文章讨论了在Redis和数据库数据一致性问题上的解决方案,主要比较了先更新Redis缓存再更新数据库和先更新数据库再更新Redis缓存两种方案,文章指出,删除R... 目录一、Redis 数据库数据一致性的解决方案1.1、更新Redis缓存、删除Redis缓存的区别二

C语言线程池的常见实现方式详解

《C语言线程池的常见实现方式详解》本文介绍了如何使用C语言实现一个基本的线程池,线程池的实现包括工作线程、任务队列、任务调度、线程池的初始化、任务添加、销毁等步骤,感兴趣的朋友跟随小编一起看看吧... 目录1. 线程池的基本结构2. 线程池的实现步骤3. 线程池的核心数据结构4. 线程池的详细实现4.1 初

Java子线程无法获取Attributes的解决方法(最新推荐)

《Java子线程无法获取Attributes的解决方法(最新推荐)》在Java多线程编程中,子线程无法直接获取主线程设置的Attributes是一个常见问题,本文探讨了这一问题的原因,并提供了两种解决... 目录一、问题原因二、解决方案1. 直接传递数据2. 使用ThreadLocal(适用于线程独立数据)

Nacos集群数据同步方式

《Nacos集群数据同步方式》文章主要介绍了Nacos集群中服务注册信息的同步机制,涉及到负责节点和非负责节点之间的数据同步过程,以及DistroProtocol协议在同步中的应用... 目录引言负责节点(发起同步)DistroProtocolDistroSyncChangeTask获取同步数据getDis

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r