偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

利用操作隊(duì)列和信號(hào)量來(lái)實(shí)現(xiàn)操作同步

移動(dòng)開(kāi)發(fā) iOS
最近在開(kāi)發(fā)iOS過(guò)程中遇到一個(gè)問(wèn)題:某一些操作需要在一個(gè)初始化操作后才允許執(zhí)行。但是這些操作的執(zhí)行時(shí)刻有可能比初始化操作來(lái)得要快。那么,如果不等待初始化操作后再執(zhí)行的話(huà),這些操作就等于是丟失了。

最近在開(kāi)發(fā)iOS過(guò)程中遇到一個(gè)問(wèn)題:某一些操作需要在一個(gè)初始化操作后才允許執(zhí)行。但是這些操作的執(zhí)行時(shí)刻有可能比初始化操作來(lái)得要快。那么,如果不等待初始化操作后再執(zhí)行的話(huà),這些操作就等于是丟失了。

針對(duì)這個(gè)問(wèn)題,我想到了兩種解決方案:***就是執(zhí)行這些操作之前先判斷是否已經(jīng)初始化,如果尚未初始化則使用一個(gè)數(shù)組隊(duì)列把操作參數(shù)及調(diào)用的方法存儲(chǔ)起來(lái),等待初始化完成后再檢測(cè)數(shù)組隊(duì)列中的保存的操作進(jìn)行調(diào)用并清空隊(duì)列。但這種方式有個(gè)問(wèn)題就是操作中傳遞的參數(shù)以及調(diào)用方法引用都需要自己來(lái)維護(hù),這無(wú)疑是給自己帶來(lái)了一定的工作量以及風(fēng)險(xiǎn),稍有不慎就有可能會(huì)導(dǎo)致內(nèi)存泄露。

因此第二中解決方法就是利用串行隊(duì)列結(jié)合信號(hào)量的方式來(lái)控制操作的執(zhí)行。此方案的思路是,先創(chuàng)建一條串行隊(duì)列,此隊(duì)列用于執(zhí)行所有的操作。但是***入隊(duì)的是一個(gè)等待信號(hào)的操作。而這個(gè)信號(hào)的初始值是0,直到初始化操作完成后才會(huì)發(fā)送一個(gè)信號(hào)來(lái)通知此操作。因此,在尚未初始化完成的時(shí)候此隊(duì)列是一直處于阻塞狀態(tài)的。所以到有操作進(jìn)入隊(duì)列時(shí)都會(huì)立刻執(zhí)行,而是需要等到初始化信號(hào)過(guò)來(lái)后才開(kāi)始執(zhí)行。

為了驗(yàn)證這一想法,我新建了一個(gè)應(yīng)用工程,在ViewController中定義了操作隊(duì)列_quque和信號(hào)量_sema,如下:

  1. @interface ViewController : UIViewController   
  2.  
  3.  {   
  4.  
  5.  @private  
  6.  
  7.      dispatch_queue_t _queue;   
  8.  
  9.      dispatch_semaphore_t _sema;   
  10.  
  11.  }   
  12.     
  13.  
  14. @end  

初始化時(shí)創(chuàng)建操作隊(duì)列

  1. - (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil   
  2.  
  3.  {   
  4.  
  5.      if (self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil])   
  6.  
  7.      {   
  8.  
  9.          _queue = dispatch_queue_create("cn.vimfung.demo", DISPATCH_QUEUE_SERIAL);   
  10.  
  11.     }   
  12.  
  13.          
  14.  
  15.      return self;   
  16.  
  17.  }  

在ViewController中定義了三個(gè)按鈕,分別為DoSomething、Signal、Wait。其中DoSomething為執(zhí)行的操作。Signal為通知阻塞隊(duì)列可以執(zhí)行操作了。Wait為阻塞當(dāng)前隊(duì)列。

  1. - (void)viewDidLoad   
  2.  
  3.  {   
  4.  
  5.      [super viewDidLoad];   
  6.  
  7.      // Do any additional setup after loading the view, typically from a nib.   
  8.  
  9.          
  10.  
  11.      UIButton *btn = [UIButton buttonWithType:UIButtonTypeRoundedRect];   
  12.  
  13.      [btn setTitle:@"DoSomething" forState:UIControlStateNormal];   
  14.  
  15.      [btn sizeToFit];   
  16.  
  17.      [btn addTarget:self action:@selector(doSomethingHandler:) forControlEvents:UIControlEventTouchUpInside];   
  18.  
  19.      [self.view addSubview:btn];   
  20.  
  21.          
  22.  
  23.      UIButton *btn1 = [UIButton buttonWithType:UIButtonTypeRoundedRect];   
  24.  
  25.      [btn1 setTitle:@"Signal" forState:UIControlStateNormal];   
  26.  
  27.      [btn1 sizeToFit];   
  28.  
  29.      [btn1 addTarget:self action:@selector(signalHanlder:) forControlEvents:UIControlEventTouchUpInside];   
  30.  
  31.      btn1.frame = CGRectMake(0.0, 50.0, btn1.frame.size.width, btn1.frame.size.height);   
  32.  
  33.      [self.view addSubview:btn1];   
  34.  
  35.          
  36.  
  37.      UIButton *btn2 = [UIButton buttonWithType:UIButtonTypeRoundedRect];   
  38.  
  39.      [btn2 setTitle:@"Wait" forState:UIControlStateNormal];   
  40.  
  41.      [btn2 sizeToFit];   
  42.  
  43.      [btn2 addTarget:self action:@selector(waitHanlder:) forControlEvents:UIControlEventTouchUpInside];   
  44.  
  45.      btn2.frame = CGRectMake(0.0, 100.0, btn2.frame.size.width, btn2.frame.size.height);   
  46.  
  47.      [self.view addSubview:btn2];   
  48.  
  49.  }   
  50.  
  51.      
  52.  
  53.  - (void)doSomethingHandler:(id)sender   
  54.  
  55.  {   
  56.  
  57.      dispatch_async(_queue, ^{   
  58.  
  59.         NSLog(@"do something");   
  60.  
  61.      });   
  62.  
  63.  }   
  64.  
  65.      
  66.  
  67.  - (void)signalHanlder:(id)sender   
  68.  
  69.  {   
  70.  
  71.      dispatch_semaphore_signal(_sema);   
  72.  
  73.  }   
  74.  
  75.      
  76.  
  77.  - (void)waitHanlder:(id)sender   
  78.  
  79.  {   
  80.  
  81.      if (_sema)   
  82.  
  83.     {   
  84.  
  85.          dispatch_release(_sema);   
  86.  
  87.      }   
  88.  
  89.     _sema = dispatch_semaphore_create(0);   
  90.  
  91.     dispatch_async(_queue, ^{   
  92.  
  93.          dispatch_semaphore_wait(_sema, DISPATCH_TIME_FOREVER);   
  94.  
  95.      });   
  96.  
  97.  } 

運(yùn)行后,先點(diǎn)擊Wait讓隊(duì)列阻塞、然后這時(shí)無(wú)論怎么點(diǎn)擊DoSomething都是不會(huì)有l(wèi)og信息顯示,直到點(diǎn)擊Signal后,之前點(diǎn)擊的DoSomething將會(huì)一一打印出來(lái)信息。

可見(jiàn)這種解決方案是可行的,并且可以更加容易操作。

責(zé)任編輯:張葉青 來(lái)源: 開(kāi)源社區(qū)
相關(guān)推薦

2010-04-21 16:42:48

Unix信號(hào)量

2010-07-15 15:32:10

Perl線(xiàn)程

2021-04-13 09:20:15

鴻蒙HarmonyOS應(yīng)用開(kāi)發(fā)

2010-04-21 16:50:31

Unix信號(hào)量

2020-11-05 09:59:24

Linux內(nèi)核信號(hào)量

2017-05-11 14:05:25

Consul分布式信號(hào)量

2010-04-21 15:37:38

Unix信號(hào)量

2020-09-25 07:34:40

Linux系統(tǒng)編程信號(hào)量

2021-09-07 07:53:42

Semaphore 信號(hào)量源碼

2010-04-21 16:25:13

Unix信號(hào)量

2016-11-23 16:08:24

Python處理器分布式系統(tǒng)

2024-07-25 11:53:53

2024-10-29 15:23:45

Python線(xiàn)程安全

2009-12-08 12:14:43

2010-04-21 17:10:25

Unix信號(hào)量

2010-03-17 16:36:10

Java信號(hào)量模型

2019-11-19 09:00:38

JavaAND信號(hào)量

2021-05-18 06:55:07

Java AQS源碼

2020-11-10 15:25:26

SemaphoreLinux翻譯

2025-04-16 08:50:00

信號(hào)量隔離線(xiàn)程池隔離并發(fā)控制
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)