Java Thead为线程,线程是操作系统调度的最小单位。
1、线程间切换(不出让情况下):抢占式调度,随机执行。
2、实现:继承Thread类或者实现Runnable接口,Callable类似,或者通过线程池。
3、线程切换代价大
4、一般通过共享内存通信
Goroutine 为go并发执行的调度单位。
1、Goroutine间切换:业务要求切换(runtime.Gosched())、发生IO,等待chanel导致执行阻塞,否则单核goroutine是串行执行。
2、实现:function前加 ‘go’关键字
3、goroutine切换代价小
4、一般通过通信共享内存
goroutine可以说是golang实现的协程,不归操作系统管理。
参考文章:
https://blog.csdn.net/yinyi364501377/article/details/79780459
https://www.cnblogs.com/shenguanpu/archive/2013/05/05/3060616.html