一.NSThread线程间通信

#import "ViewController.h"

@interface ViewController ()<UIScrollViewDelegate>

@property (strong, nonatomic) IBOutlet UIScrollView *scrollView;

@property (weak, nonatomic)  UIImageView *imageView;

@end

@implementation ViewController

- (void)viewDidLoad {

[super viewDidLoad];

//1.创建我们的UIImageView

[self createUIImageView];

//2.去网络上下载图片

NSString *URLString = @"http://e.hiphotos.bdimg.com/album/pic/item/9345d688d43f8794f0ab07ddd01b0ef41ad53ae8.jpg";

[self performSelectorInBackground:@selector(loadImage:) withObject:URLString];

//3.设置最大最小缩放比例

self.scrollView.maximumZoomScale  = 2.0;

self.scrollView.minimumZoomScale  = 0.5;

}

/**

去子线程下载图片

*/

- (void)loadImage:(NSString *)URLString{

NSLog(@"---loadImage start---");

//1.生成NSURL

NSURL *url = [NSURL URLWithString:URLString];

//2.去网络上下载,网络上传输的都是一堆01010的二进制

NSData *imageData = [NSData dataWithContentsOfURL:url];

//3.将我们的imageData转成我们UIImage

UIImage *image = [UIImage imageWithData:imageData];

/**

waitUntilDone 等我们的updateUI 方法执行完毕之后,再执行后面的

*/

[self performSelectorOnMainThread:@selector(updateUI:) withObject:image waitUntilDone:NO];

NSLog(@"---loadImage end---");

}

- (void)updateUI:(UIImage *)image{

//1.将image设置给imageView

self.imageView.image = image;

//2.根据我们的图片大小,来决定我们UIImageView的尺寸

[self.imageView sizeToFit];

//3.设置scrollView的contentSize

self.scrollView.contentSize = image.size;

NSLog(@"update UI end");

}

- (void)createUIImageView{

UIImageView *imageView =[[UIImageView alloc] init];

[self.scrollView addSubview:imageView];

self.imageView = imageView;

}

#pragma mark - scrollViewDelegate

- (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView{

return self.imageView;

}

- (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event{

NSLog(@"%s",__func__);

}

@end

二.GCD线程间通信

#import "ViewController.h"

@interface ViewController ()<UIScrollViewDelegate>

@property (strong, nonatomic) IBOutlet UIScrollView *scrollView;

@property (weak, nonatomic)  UIImageView *imageView;

@end

@implementation ViewController

- (void)viewDidLoad {

[super viewDidLoad];

//1.创建我们的UIImageView

[self createUIImageView];

//2.去网络上下载图片

/**

去子线程,并发,全局,串行         方法:异步

两个参数

参数1:队列

参数2:任务

*/

dispatch_async(dispatch_get_global_queue(0, 0), ^{

NSLog(@"loadImage----%@",[NSThread currentThread]);

//0.URLString

NSString *URLString = @"http://e.hiphotos.bdimg.com/album/pic/item/9345d688d43f8794f0ab07ddd01b0ef41ad53ae8.jpg";

//1.生成NSURL

NSURL *url = [NSURL URLWithString:URLString];

//2.去网络上下载,网络上传输的都是一堆01010的二进制

NSData *imageData = [NSData dataWithContentsOfURL:url];

//3.将我们的imageData转成我们UIImage

UIImage *image = [UIImage imageWithData:imageData];

//去主线程更新UI

dispatch_async(dispatch_get_main_queue(), ^{

NSLog(@"---updateUI---%@",[NSThread currentThread]);

//1.将image设置给imageView

self.imageView.image = image;

//2.根据我们的图片大小,来决定我们UIImageView的尺寸

[self.imageView sizeToFit];

//3.设置scrollView的contentSize

self.scrollView.contentSize = image.size;

});

});

//3.设置最大最小缩放比例

self.scrollView.maximumZoomScale  = 2.0;

self.scrollView.minimumZoomScale  = 0.5;

}

- (void)createUIImageView{

//1.创建imageView

UIImageView *imageView =[[UIImageView alloc] init];

[self.scrollView addSubview:imageView];

self.imageView = imageView;

}

#pragma mark - scrollViewDelegate

- (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView{

return self.imageView;

}

- (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event{

NSLog(@"%s",__func__);

}

@end

三.NSOperation线程间通信

#import "ViewController.h"

@interface ViewController ()<UIScrollViewDelegate>

@property (strong, nonatomic) IBOutlet UIScrollView *scrollView;

@property (weak, nonatomic)  UIImageView *imageView;

@end

@implementation ViewController

- (void)viewDidLoad {

[super viewDidLoad];

//1j.创建我们的UIImageView

[self createUIImageView];

//2.去网络上下载图片

//先去子线程做耗时操作(下载)  然后再去主线程更新UI

//创建并发队列

NSOperationQueue  *queue = [[NSOperationQueue alloc] init];

[queue addOperationWithBlock:^{

//子线程

NSLog(@"loadImage----%@",[NSThread currentThread]);

//0.URLString

NSString *URLString = @"http://e.hiphotos.bdimg.com/album/pic/item/9345d688d43f8794f0ab07ddd01b0ef41ad53ae8.jpg";

//1.生成NSURL

NSURL *url = [NSURL URLWithString:URLString];

//2.去网络上下载,网络上传输的都是一堆01010的二进制

NSData *imageData = [NSData dataWithContentsOfURL:url];

//3.将我们的imageData转成我们UIImage

UIImage *image = [UIImage imageWithData:imageData];

//去主线程更新UI

[[NSOperationQueue mainQueue] addOperationWithBlock:^{

//主线程

NSLog(@"---updateUI---%@",[NSThread currentThread]);

//1.将image设置给imageView

self.imageView.image = image;

//2.根据我们的图片大小,来决定我们UIImageView的尺寸

[self.imageView sizeToFit];

//3.设置scrollView的contentSize

self.scrollView.contentSize = image.size;

}];

}];

//3.设置最大最小缩放比例

self.scrollView.maximumZoomScale  = 2.0;

self.scrollView.minimumZoomScale  = 0.5;

}

- (void)createUIImageView{

UIImageView *imageView =[[UIImageView alloc] init];

[self.scrollView addSubview:imageView];

self.imageView = imageView;

}

#pragma mark - scrollViewDelegate

- (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView{

return self.imageView;

}

- (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event{

NSLog(@"%s",__func__);

}

@end

线程间通信的三种方式(NSThread,GCD,NSOperation)的更多相关文章

  1. VC 线程间通信的三种方式

    1.使用全局变量(窗体不适用)     实现线程间通信的方法有很多,常用的主要是通过全局变量.自定义消息和事件对象等来实现的.其中又以对全局变量的使用最为简洁.该方法将全局变量作为线程监视的对象,并通 ...

  2. 【转】VC 线程间通信的三种方式

    原文网址:http://my.oschina.net/laopiao/blog/94728 1.使用全局变量(窗体不适用)      实现线程间通信的方法有很多,常用的主要是通过全局变量.自定义消息和 ...

  3. 容器间通信的三种方式 - 每天5分钟玩转 Docker 容器技术(35)

    容器之间可通过 IP,Docker DNS Server 或 joined 容器三种方式通信. IP 通信 从上一节的例子可以得出这样一个结论:两个容器要能通信,必须要有属于同一个网络的网卡. 满足这 ...

  4. Java并发编程:线程间协作的两种方式:wait、notify、notifyAll和Condition

    Java并发编程:线程间协作的两种方式:wait.notify.notifyAll和Condition 在前面我们将了很多关于同步的问题,然而在现实中,需要线程之间的协作.比如说最经典的生产者-消费者 ...

  5. Java线程间通信-回调的实现方式

    Java线程间通信-回调的实现方式   Java线程间通信是非常复杂的问题的.线程间通信问题本质上是如何将与线程相关的变量或者对象传递给别的线程,从而实现交互.   比如举一个简单例子,有一个多线程的 ...

  6. 多线程之线程间协作的两种方式:wait、notify、notifyAll和Condition

    Java并发编程:线程间协作的两种方式:wait.notify.notifyAll和Condition 在前面我们将了很多关于同步的问题,然而在现实中,需要线程之间的协作.比如说最经典的生产者-消费者 ...

  7. 19、Java并发编程:线程间协作的两种方式:wait、notify、notifyAll和Condition

    Java并发编程:线程间协作的两种方式:wait.notify.notifyAll和Condition 在前面我们将了很多关于同步的问题,然而在现实中,需要线程之间的协作.比如说最经典的生产者-消费者 ...

  8. [转] 微信小程序页面间通信的5种方式

    微信小程序页面间通的5种方式 PageModel(页面模型)对小程序而言是很重要的一个概念,从app.json中也可以看到,小程序就是由一个个页面组成的. 如上图,这是一个常见结构的小程序:首页是一个 ...

  9. Angular 组件通信的三种方式

    我们可以通过以下三种方式来实现: 传递一个组件的引用给另一个组件 通过子组件发送EventEmitter和父组件通信 通过serive通信 1. 传递一个组件的引用给另一个组件 Demo1 模板引用变 ...

随机推荐

  1. AngularJs学习(1)

    以下是学习过程中的笔记,有些是网上摘录 <!DOCTYPE HTML> <html lang="zh-cn"> <head> <meta ...

  2. Android 多线程断点下载(非原创)

    1.服务器的CPU分配给每条线程的时间片相同,服务器带宽平均分配给每条线程,所以客户端开启的线程越多,就能抢占到更多的服务器资源,这里在客户端开启多个线程来从服务器下载资源 2.fragment_ma ...

  3. ES6 let和const命令

    一.let定义变量 { let a = 1;} console.log(a);只在let所在的代码块有效,console的结果是a is not defined,报错. 不存在var的变量提升,即使用 ...

  4. winsock开发重复定义问题

    参考: VS2013使用winsock.h和winsock2.h发生冲突后的终极解决方法:http://www.cnblogs.com/Shirlies/p/5137548.html WINSOCK. ...

  5. codeforces 342D Xenia and Dominoes(状压dp+容斥)

    转载请注明出处: http://www.cnblogs.com/fraud/          ——by fraud D. Xenia and Dominoes Xenia likes puzzles ...

  6. git merge的recursive策略和merge-base

    git的合并策略总共有3种,一种是resovle,一种是recursive,一种是octopus.其中resolve和recursive适用于合并2个branch,octopus适用于合并3个或者3个 ...

  7. 菜单之一:Menu基础内容

    参考<疯狂android讲义>2.10节P168 1.重要接口 Android菜单相关的重要接口共有以下四个: 其中Menu为普通菜单,SubMenu包含子项,ContextMenu当长时 ...

  8. IOS通过PushSharp开源框架发送推送

    1,首先生成推送证书: openssl x509 -in aps_developer_identity.cer -inform DER -out aps_developer_identity.pem ...

  9. jQuery中的$.extend方法总结

    原文见:jQuery.extend()函数详解 Jquery的扩展方法extend是我们在写插件的过程中常用的方法,但是经常容易搞不清楚以下两个写法的关系: 1.$.extend(dest,src1, ...

  10. Frogger(最短路)

    Frogger(poj2253) Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 31854   Accepted: 1026 ...