信号量 控制 并发--解决NSURlSession 同步请求

信号量(dispatch_semaphore_t)的问题应该是 Unix开发人员在熟悉不过的 技术啦,利用信号量 我们可以更好的控制线程。

这两天 开发的时候 遇到了  一个问题  就是  iOS9 之后  苹果将NSURLConnection网相关组件废除,不再建议使用,但他的一些功能还是很不错的 ,  比方说 ,有的时候 我们就是要等待网络数据比对, 就很棘手啦,当时NSURLConnection时,是有发送同步请求 的方法的:

+ (nullable NSData *)sendSynchronousRequest:(NSURLRequest *)request returningResponse:(NSURLResponse * __nullable * __nullable)response error:(NSError **)error


思路:

首先 考虑 的事 实现 以前同步请求可以完成的 事情

其次 我们可以利用信号量 来堵塞线程

最后 我们 可以 在适当的时候去释放堵塞的线程。

废话不说上代码:

- (void)viewDidLoad

{

[super viewDidLoad];

// 首先  我们  创建一个  打印。。。。    将  打印  放入  异步队列  当中。。。。

logQueue = dispatch_queue_create("GaoWH.Demo", DISPATCH_QUEUE_SERIAL);

//创建  信号量

semaphore = dispatch_semaphore_create(0);

//创建  定时器  让  5s  后  给  信号量 发送 增量消息 。。。 控制

NSTimer *timer = [NSTimer timerWithTimeInterval:5 target:self selector:@selector(timerAction) userInfo:nil repeats:NO];

[timer fire];

dispatch_async(logQueue, ^

{

//将等待信号 先 放入 队列  起到  堵塞线程的作用。

dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER);

[self shouldFirstRespond];

});

[self shouldSoeundRespoond];

}

-(void)shouldFirstRespond

{

NSLog(@"-----------11111111111111111111111111  我们应该是  第一个执行。。。。。");

}

-(void)shouldSoeundRespoond

{

NSLog(@"-----------22222222222222222222222222  我们应该是  第222个执行。。。。。");

// 这里 我们发送 了

dispatch_semaphore_signal(semaphore);

}

//5s 后执行方法。。。。

-(void)timerAction

{

[self shouldSoeundRespoond];

}

[/php]

这样的 话  执行结果:

执行结果。。。

执行结果。。。

例子  虽然简单  但也展示了 信号量 对 线程的 管理 。

这样的话  我们  就不难  对  NSURLSession  同步请求 的控制啦  。

简单的纪录写一下 对  NSURLSession 同步请求:

[php]

dispatch_semaphore_t semaphore = dispatch_semaphore_create(0);

NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:[NSURL URLWithString:请求地址]];

[request setHTTPMethod:@"POST"];

NSString *appStartRequestStr = [NSString stringWithFormat:请求参数];

[request setHTTPBody:[appStartRequestStr dataUsingEncoding:NSUTF8StringEncoding]];

NSURLSession *urlSession = [NSURLSession sharedSession];

NSURLSessionDataTask *urlSessionDataTask = [urlSession dataTaskWithRequest:请求 completionHandler:^(NSData * _Nullable data, NSURLResponse * _Nullable response, NSError * _Nullable error)

{

dispatch_semaphore_signal(semaphore);

}];

[urlSessionDataTask resume];

dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER);

其实现在  看来  我们  就不难发现  利用  信号量 来控制 NSURLSession 同步请求的原理,其实 实质还是  对线程的管理。

当然啦 这里的信号量控制的例子    只是 一个  展现 信号量  一小点诱人魅力 的 例子  ,关于信号量,利用它你可以很好的 控制  线程。

你可能感兴趣的:(信号量 控制 并发--解决NSURlSession 同步请求)