内容简介:启动两个线程, 一个输出1,3,5,7,9....99,另一个输出2,4,6,8....100,最后在terminal中输出1,2,3,4,5,6.....100协程是用户级别的线程。在java中程序调度的基本单位是线程,java的线程和操作系统的线程是一一对应的,线程的调度是由操作系统内核完成的。golang中提供了协程来实现并发,多个协程运行在一个操作系统的线程上,协程的调度由用户态代码来实现,因而协程序更加轻量级。
启动两个线程, 一个输出1,3,5,7,9....99,另一个输出2,4,6,8....100,最后在terminal中输出1,2,3,4,5,6.....100
java 线程实现
/** * 多线程并发的时候需要通过一个锁来进行wait和notify控制线程的唤醒和等待 */ Object lock = new Object(); /** * lambda代码块只能操作lambda代码块外的final变量,但是有时候又需要改变这个变量, * 所以通过final数组来规避这个问题。 */ final Thread[] threads = new Thread[2]; /** * 当两个打印线程结束之后main线程退出 */ CountDownLatch countDownLatch = new CountDownLatch(2); threads[1] = new Thread(() -> { for (int i = 2; i <= 100; i += 2) { System.out.println(i); /** * wait, notify, notifyAll 等方法需要在同步代码块中执行以保证并发安全。 */ synchronized (lock) { try { /** *唤醒thread[0] */ lock.notifyAll(); if (i != 100) { /** * 本线程进入等待状态,释放cpu */ lock.wait(); } } catch (InterruptedException e) { e.printStackTrace(); } } } countDownLatch.countDown(); }); threads[0] = new Thread(() -> { for (int i = 1; i < 100; i += 2) { System.out.println(i); synchronized (lock) { try { /** * 当i==1时代表thread[1]尚未开始启动 * 当i!=1时唤醒thread[1] * 然后本线程进入等待状态释放cpu */ if (i == 1) { threads[1].start(); } else { lock.notifyAll(); } if (i != 99) { lock.wait(); } } catch (InterruptedException e) { e.printStackTrace(); } } } countDownLatch.countDown(); }); /** * 启动thread[0] */ threads[0].start(); /** * main线程进入等待状态,当thread[0]和thread[1]的任务执行完成之后main线程被唤醒 */ countDownLatch.await(); System.out.println("两个线程通过notify和wait实现循环打印100以内的数");
golang 协程实现
协程是用户级别的线程。在 java 中程序调度的基本单位是线程,java的线程和操作系统的线程是一一对应的,线程的调度是由操作系统内核完成的。golang中提供了协程来实现并发,多个协程运行在一个操作系统的线程上,协程的调度由用户态代码来实现,因而协程序更加轻量级。
a := make(chan bool, 1) b := make(chan bool) Exit := make(chan bool) // <- chan 当chan中没有数据时会阻塞 // a <- true 往chan a 中放入放入一个值,此时阻塞的协程开始执行 // go func 启动一个协程 go func() { for i := 1; i < 100; i += 2 { if ok := <-a; ok { fmt.Println(i) b <- true } } }() go func() { for i := 2; i <= 100; i += 2 { if ok := <-b; ok { fmt.Println(i) a <- true } } // 循环打印结束,主协程退出 close(Exit) }() fmt.Println("end") a <- true _ := <-Exit
以上所述就是小编给大家介绍的《多线程协作demo》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
树莓派学习指南
[英]Peter Membrey、[澳]David Hows / 张志博、孙峻文 / 人民邮电出版社 / 2014-4 / 49.00元
树莓派(Raspberry Pi)是一款基于Linux系统的、只有一张信用卡大小的卡片式计算机。由于功能强大、性能出色、价格便宜等特点,树莓派得到了计算机硬件爱好者以及教育界的欢迎,风靡一时。 《树莓派学习指南(基于Linux)》是学习在树莓派上基于Linux进行开发的一本实践指南。全书共3个部分11章,第一部分是前两章,讲述如何设置和运行图形用户界面(GUI)。第二部分是第3章到第7章,讲......一起来看看 《树莓派学习指南》 这本书的介绍吧!
RGB转16进制工具
RGB HEX 互转工具
SHA 加密
SHA 加密工具