信息量

作者: GFan | 来源:发表于2022-08-25 15:54 被阅读0次

1个信号量:

- (IBAction)dispatchSingal0:(UIButton *)sender {

    dispatch_semaphore_t semaphore1 = dispatch_semaphore_create(0);

    dispatch_queue_t queue1 = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);

    // 任务1

    dispatch_async(queue1, ^{

        dispatch_semaphore_signal(semaphore1);

        NSLog(@"run task 1");

        sleep(2);

        NSLog(@"任务全部执行完成 complete task 1");

        dispatch_semaphore_wait(semaphore1, DISPATCH_TIME_FOREVER);

    });

}

2019-11-11 10:02:12.328143+0800 123334567[3976:47598] run task 1

2019-11-11 10:02:14.333569+0800 123334567[3976:47598] 任务全部执行完成 complete task 1

由于设定的信号值为0,所以只有一个线程

2个信号量:

- (IBAction)dispatchSingal1:(UIButton *)sender {

    //create(value)表示,最多几个资源可访问,现在最多可访问2个资源(0,1)

    dispatch_semaphore_t semaphore = dispatch_semaphore_create(1);

    dispatch_queue_t quene = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);

    //任务1

    dispatch_async(quene, ^{

        dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER);

        NSLog(@"run task 1");

        sleep(2);

        NSLog(@"任务全部执行完成 complete task 1");

        dispatch_semaphore_signal(semaphore);

    });

    //任务2

    dispatch_async(quene, ^{

        dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER);

        NSLog(@"run task 2");

        sleep(2);

        NSLog(@"任务全部执行完成 complete task 2");

        dispatch_semaphore_signal(semaphore);

    });

}

2019-11-11 10:16:19.435266+0800 123334567[4481:54963] run task 1

2019-11-11 10:16:21.437668+0800 123334567[4481:54963] 任务全部执行完成 complete task 1

2019-11-11 10:16:21.437969+0800 123334567[4481:55783] run task 2

2019-11-11 10:16:23.439545+0800 123334567[4481:55783] 任务全部执行完成 complete task 2

由于设定的信号值为1,所以会先执行一个线程,等执行完一个,才会继续执行另一个,保证同一时间执行的线程数为1

3个信号量:

- (IBAction)dispatchSingal2:(UIButton *)sender {

    //create(value)表示,最多几个资源可访问,现在最多可访问3个资源(0,1,2)

    dispatch_semaphore_t semaphore = dispatch_semaphore_create(2);

    dispatch_queue_t quene = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);

    //任务1

    dispatch_async(quene, ^{

        dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER);

        NSLog(@"run task 1");

        sleep(1);

        NSLog(@"任务全部执行完成 complete task 1");

        dispatch_semaphore_signal(semaphore);

    });

    //任务2

    dispatch_async(quene, ^{

        dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER);

        NSLog(@"run task 2");

        sleep(1);

        NSLog(@"任务全部执行完成 complete task 2");

        dispatch_semaphore_signal(semaphore);

    });

    //任务3

    dispatch_async(quene, ^{

        dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER);

        NSLog(@"run task 3");

        sleep(1);

        NSLog(@"任务全部执行完成 complete task 3");

        dispatch_semaphore_signal(semaphore);

    });

}

① 第一种情况

2019-11-11 10:20:10.961881+0800 123334567[4481:55783] run task 1

2019-11-11 10:20:10.962065+0800 123334567[4481:57698] run task 3

2019-11-11 10:20:11.966846+0800 123334567[4481:57698] 任务全部执行完成 complete task 3

2019-11-11 10:20:11.966847+0800 123334567[4481:55783] 任务全部执行完成 complete task 1

2019-11-11 10:20:11.967167+0800 123334567[4481:57697] run task 2

2019-11-11 10:20:12.971532+0800 123334567[4481:57697] 任务全部执行完成 complete task 2

------------------------------------------------------------------------------------------

② 第二种情况

2019-11-11 10:24:03.889155+0800 123334567[4798:60740] run task 1

2019-11-11 10:24:03.889277+0800 123334567[4798:60847] run task 2

2019-11-11 10:24:04.894150+0800 123334567[4798:60740] 任务全部执行完成 complete task 1

2019-11-11 10:24:04.894125+0800 123334567[4798:60847] 任务全部执行完成 complete task 2

2019-11-11 10:24:04.894492+0800 123334567[4798:60848] run task 3

2019-11-11 10:24:05.899918+0800 123334567[4798:60848] 任务全部执行完成 complete task 3

由于设定的信号值为2,先执行两个线程,等执行完一个,才会继续执行下一个,保证同一时间执行的线程数不超过2

相关文章

  • 信息量

    这一次,信息量真的很大。 2016-05-23 看一眼,就会爱上它,你还等什么,赶紧看完收藏吧!!!! 论文 论文...

  • 信息量

    身处当今世界,每天接触最大的就是铺天盖地的信息了!信息量越来越大的今天,对于生活其中的人们来说,其实也有它的...

  • 信息量

    1个信号量: - (IBAction)dispatchSingal0:(UIButton *)sender { ...

  • 2018年6月6日

    上午: 通信原理 求信息量和平均信息量

  • 什么熵

    信息量 定义概率越低信息量越大概率越高信息量越低 公式例如事件概率信息量电脑炸了0.1电脑无法开机0.2电脑开机0...

  • 信息量和信息熵

    信息量的定义: 信息量度量的是一个具体事件发生所带来的信息,衡量信息量大小就看这个信息消除不确定性的程度; 信息量...

  • Entropy,Gini ,Information gain

    Entropy 信息量:值域发生概率越小,信息量越大。不确定性越高,信息量越大。 信息熵:值域,更确切为:,为类别...

  • “缩小”信息量

    现代社会,我们每天都要接触很多信息,无论是工作上的,微信推送的,微博刷出来的,似乎我们的生活被爆照性的信息所填满,...

  • 信息量太大!

    几十个微信群,每一秒钟都在翻新信息,阅读的速度与越来越跟不上信息更新的速度,而且这个差距会越来越大。。。 如何在庞...

  • 信息量太大

    好多事情冲到脑子里,今天去做了个检查,不太好,虽然有心理准备,但是,还是不开心啊。 我喜欢健健康康的呀,我希望健健...

网友评论

      本文标题:信息量

      本文链接:https://www.haomeiwen.com/subject/sefzgrtx.html