- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章浅析iOS应用开发中线程间的通信与线程安全问题由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
线程间的通信 简单说明 线程间通信:在1个进程中,线程往往不是孤立存在的,多个线程之间需要经常进行通信 线程间通信的体现 1个线程传递数据给另1个线程 在1个线程中执行完特定任务后,转到另1个线程继续执行任务 线程间通信常用方法 。
线程间通信示例 – 图片下载 。
。
。
// // yyviewcontroller.m // 06-nsthread04-线程间通信 // // created by apple on 14-6-23. // copyright (c) 2014年 itcase. all rights reserved. // 。
。
#import "yyviewcontroller.h" @interface yyviewcontroller () @property (weak, nonatomic) iboutlet uiimageview *iconview; @end 。
。
@implementation yyviewcontroller 。
。
- (void)viewdidload { [super viewdidload]; } 。
-(void)touchesbegan:(nsset *)touches withevent:(uievent *)event { 。
// 在子线程中调用download方法下载图片 [self performselectorinbackground:@selector(download) withobject:nil]; } 。
。
-(void)download { //1.根据url下载图片 //从网络中下载图片 nsurl *urlstr=[nsurl urlwithstring:@"fdsf"],
//把图片转换为二进制的数据 nsdata *data=[nsdata datawithcontentsofurl:urlstr];//这一行操作会比较耗时 。
//把数据转换成图片 uiimage *image=[uiimage imagewithdata:data]; //2.回到主线程中设置图片 [self performselectoronmainthread:@selector(settingimage:) withobject:image waituntildone:no]; } 。
。
//设置显示图片 -(void)settingimage:(uiimage *)image { self.iconview.image=image; } 。
@end 。
代码2:
// // yyviewcontroller.m // 06-nsthread04-线程间通信 // // created by apple on 14-6-23. // copyright (c) 2014年 itcase. all rights reserved. // 。
。
#import "yyviewcontroller.h" #import <nsdata.h> 。
@interface yyviewcontroller () @property (weak, nonatomic) iboutlet uiimageview *iconview; @end 。
。
@implementation yyviewcontroller 。
。
- (void)viewdidload { [super viewdidload]; } 。
-(void)touchesbegan:(nsset *)touches withevent:(uievent *)event { // 在子线程中调用download方法下载图片 。
[self performselectorinbackground:@selector(download) withobject:nil]; } 。
-(void)download { 。
//1.根据url下载图片 //从网络中下载图片 nsurl *urlstr=[nsurl urlwithstring:@"fdsf"],
//把图片转换为二进制的数据 nsdata *data=[nsdata datawithcontentsofurl:urlstr];//这一行操作会比较耗时 。
//把数据转换成图片 uiimage *image=[uiimage imagewithdata:data],
//2.回到主线程中设置图片 //第一种方式 // [self performselectoronmainthread:@selector(settingimage:) withobject:image waituntildone:no],
//第二种方式 // [self.imageview performselector:@selector(setimage:) onthread:[nsthread mainthread] withobject:image waituntildone:no],
//第三种方式 [self.iconview performselectoronmainthread:@selector(setimage:) withobject:image waituntildone:no]; } 。
//设置显示图片 //-(void)settingimage:(uiimage *)image //{ // self.iconview.image=image; //} 。
@end 。
。
线程安全 1、多线程的安全隐患 资源共享 1块资源可能会被多个线程共享,也就是多个线程可能会访问同一块资源 比如多个线程访问同一个对象、同一个变量、同一个文件 当多个线程访问同一块资源时,很容易引发数据错乱和数据安全问题 示例一:
示例二:
问题代码:
// // yyviewcontroller.m // 05-线程安全 // // created by apple on 14-6-23. // copyright (c) 2014年 itcase. all rights reserved. // 。
。
#import "yyviewcontroller.h" 。
@interface yyviewcontroller () //剩余票数 。
@property(nonatomic,assign) int leftticketscount; @property(nonatomic,strong)nsthread *thread1; @property(nonatomic,strong)nsthread *thread2; @property(nonatomic,strong)nsthread *thread3,
@end 。
。
@implementation yyviewcontroller 。
。
- (void)viewdidload { [super viewdidload],
//默认有20张票 。
self.leftticketscount=10,
//开启多个线程,模拟售票员售票 。
self.thread1=[[nsthread alloc]initwithtarget:self selector:@selector(selltickets) object:nil],
self.thread1.name=@"售票员a",
self.thread2=[[nsthread alloc]initwithtarget:self selector:@selector(selltickets) object:nil],
self.thread2.name=@"售票员b",
self.thread3=[[nsthread alloc]initwithtarget:self selector:@selector(selltickets) object:nil]; self.thread3.name=@"售票员c"; } 。
-(void)selltickets { while (1) { //1.先检查票数 int count=self.leftticketscount; if (count>0) { //暂停一段时间 [nsthread sleepfortimeinterval:0.002],
//2.票数-1 self.leftticketscount= count-1; //获取当前线程 nsthread *current=[nsthread currentthread]; nslog(@"%@--卖了一张票,还剩余%d张票",current,self.leftticketscount); }else { //退出线程 [nsthread exit]; } } } 。
-(void)touchesbegan:(nsset *)touches withevent:(uievent *)event { //开启线程 。
[self.thread1 start]; [self.thread2 start]; [self.thread3 start],
} 。
@end 。
打印结果:
。
2、安全隐患分析 。
3、如何解决 互斥锁使用格式 @synchronized(锁对象) { // 需要锁定的代码 } 注意:锁定1份代码只用1把锁,用多把锁是无效的 代码示例:
// // yyviewcontroller.m // 05-线程安全 // // created by apple on 14-6-23. // copyright (c) 2014年 itcase. all rights reserved. // 。
。
#import "yyviewcontroller.h" 。
@interface yyviewcontroller () 。
//剩余票数 @property(nonatomic,assign) int leftticketscount; @property(nonatomic,strong)nsthread *thread1; @property(nonatomic,strong)nsthread *thread2; @property(nonatomic,strong)nsthread *thread3; @end 。
@implementation yyviewcontroller 。
- (void)viewdidload { [super viewdidload]; //默认有20张票 self.leftticketscount=10; //开启多个线程,模拟售票员售票 。
self.thread1=[[nsthread alloc]initwithtarget:self selector:@selector(selltickets) object:nil],
self.thread1.name=@"售票员a",
self.thread2=[[nsthread alloc]initwithtarget:self selector:@selector(selltickets) object:nil],
self.thread2.name=@"售票员b",
self.thread3=[[nsthread alloc]initwithtarget:self selector:@selector(selltickets) object:nil],
self.thread3.name=@"售票员c"; } 。
-(void)selltickets { while (1) { @synchronized(self){//只能加一把锁 //1.先检查票数 。
int count=self.leftticketscount; if (count>0) { //暂停一段时间 [nsthread sleepfortimeinterval:0.002]; //2.票数-1 。
self.leftticketscount= count-1; //获取当前线程 nsthread *current=[nsthread currentthread]; nslog(@"%@--卖了一张票,还剩余%d张票",current,self.leftticketscount),
}else { //退出线程 [nsthread exit]; } } } } 。
-(void)touchesbegan:(nsset *)touches withevent:(uievent *)event { 。
//开启线程 [self.thread1 start]; [self.thread2 start]; [self.thread3 start]; } 。
@end 。
执行效果图 。
。
互斥锁的优缺点 优点:能有效防止因多线程抢夺资源造成的数据安全问题 缺点:需要消耗大量的cpu资源 互斥锁的使用前提:多条线程抢夺同一块资源 相关专业术语:线程同步,多条线程按顺序地执行任务 互斥锁,就是使用了线程同步技术 四:原子和非原子属性 oc在定义属性时有nonatomic和atomic两种选择 atomic:原子属性,为setter方法加锁(默认就是atomic) nonatomic:非原子属性,不会为setter方法加锁 atomic加锁原理 。
@property (assign, atomic) int age,
。
- (void)setage:(int)age { 。
@synchronized(self) { _age = age; } } 。
原子和非原子属性的选择 nonatomic和atomic对比 。
。
ios开发的建议 。
最后此篇关于浅析iOS应用开发中线程间的通信与线程安全问题的文章就讲到这里了,如果你想了解更多关于浅析iOS应用开发中线程间的通信与线程安全问题的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
大多数语言都支持双向进程通信。例如,在 Python 中,我可以(草率地)执行以下操作: >>> from subprocess import * >>> p = Popen('nslookup',
致力于使用 C++ 在 arduino 和 PC (Win 7) 之间进行通信。使用 WriteFile 和 ReadFile 创建通信或简单地发送或接收数据没有问题。但是当我想以某种方式“协调”沟通
我们正在开发一个基于微服务的应用程序。它们将使用 Helm Package Manager 部署到 kubernetes,并且它们都存储了自己的存储库和 helm chart。以下是我们微服务的名称。
我正在开发一个大型 MVVM 应用程序。我为此使用了 MVVM 轻量级工具包。该应用程序就像一个带有后退和前进按钮的网络浏览器。主视图是一个用户控件。我在主视图用户控件中放置了后退和前进按钮。主视图又
我在 java 和 freepascal(lazarus) 应用程序之间的通信有问题。我使用套接字。它们正确连接。一切都很顺利,直到我想从一个应用程序向另一个应用程序发送一些东西。在java而不是“a
我已经使用客户端套接字和服务器套接字使用C#编写了群聊。 当我使用VS 2017在自己的PC中运行程序(服务器和客户端)时,客户端和服务器之间的通信工作正常。 当我在笔记本电脑中运行客户端程序,并在自
Kubernetes 中两个不同 Pod 之间的通信是如何发生的? 就我而言,我有两个 Pod:前端和后端,它们都有不同的容器。 我希望我的前端 pod 与后端 pod 通信,但我不想使用后端 pod
我正在尝试在浏览器中嵌入的 flash 实例与在 C# WinForms 应用程序中运行的 flash 实例之间进行通信...我收到一个编译错误,内容为: 1119 Access of possibl
鉴于网络上缺乏信息,请问一个问题:我要在 Android 中创建一个应用程序,使用一个数据库应用程序 rails 。为此,我需要一个手动 session 。所以如果有人准备好了示例/教程显示通信 an
我正在编写一个应用程序,它将通过 MySQL 数据库对用户进行身份验证。我已经用 Java (android) 编写了它,但现在正在移植到 Windows 手机。 PHP 文件使用 $get 然后回显
是否可以通过互联网在两个不同设备上的两个不同应用程序之间建立通信。我想从设备 A 上的应用程序点击一个设备 B 上的应用程序,然后从设备 B 上的应用程序获取数据到设备 A 上的应用程序。如果可能,如
这是脚本: 它被放置在其他网站上。 com 并显示一个 iframe。如果有人点击 iframe 中的某个内容,脚本应该将一个 div 写入 othersite 。 com. 所以我的问题是如何做到
你好我是 php 的新手,我用 c++ 编写了整个代码并想在 php 中使用这段代码。所以我为我的代码制作了 dll 以使用它。但是我不能在 php 中使用这个 dll,可以谁能给我完整的代码来使用
我确定之前已经有人问过(并回答过)此类问题,所以如果是这样,请将我链接到之前的讨论... 在 C++ 中,假设我有一个 ClassA 类型的对象,其中包含一个 ClassB 类型的私有(private
我正在尝试使用 ATmega32 进行串行通信。首先,我使用 RS232,使用 USB-to-RS232 建立使用串行终端的接收和传输(在我的例子中是 tera 术语)。无论我从串行终端 Atmega
我找不到适用于 Ruby 的 SSL 实现。 我的部分项目需要服务器和客户端之间的安全通信链接,我希望为此使用 SSL 以创建安全 session 。 谢谢 最佳答案 如果你使用 Ruby 1.9.x
我正在尝试在客户端/服务器之间进行 SSL 通信。 到目前为止,我已经从 keystore 创建了 java.security.cert.X509Certificate。接下来我应该怎么做才能使这次沟
我在与 Windows 上的 USB 设备 通信时遇到问题。我不能使用 libusb 或 WinUSB,因为我有一个特定的驱动程序(Silabs USB 到 UART,这是一个 USB 到串口的桥接器
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我发现 xcom 实际上是将数据写入数据库并从其他任务中提取数据。我的数据集很大,将其腌制并写入数据库会导致一些不必要的延迟。有没有办法在不使用 xcom 的情况下在同一 Airflow Dag 中的
我是一名优秀的程序员,十分优秀!