Java线程与goroutine对比

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

你可能感兴趣的:(golang)