java20的虚拟线程和go的协程线程

用户线程已经全部退出运行了,只剩下守护线程存在了,虚拟机也就退出了。 因为没有了被守护者
thread.setDaemon(true)必须在thread.start()之前设置

Java 中的线程是对操作系统线程的一个简单包装,线程的创建,调度和销毁等都是由操作系统完成;
Java线程和系统线程是一一对应的关系;
线程切换需要消耗 CPU 时间,这部分时间是与业务无关的;
线程的性能直接受操作系统处理能力的影响;
(线程池)的方式进行管理线程,避免线程频繁创建和销毁带来的开销
虚拟线程是 JVM 进行调度的,而不是操作系统

VirtualThread 继承 BaseVirtualThread 类,BaseVirtualThread 类继承 Thread 类
创建 Thread.startVirtualThread(thread); 
Thread.ofVirtual().start(thread); 
ExecutorService executor = Executors.newVirtualThreadPerTaskExecutor();
executor.submit(customThread);

goroutine 和 channel 实现并发编程
函数调用前加上 go 关键字 go func() {}

线程程序在单核CPU上面运行就是并发
多线程程序在多核CUP上运行就是并行

调用new JavaThread(&thread_entry,sz)进行线程的创建,同时根据不同的操作系统调用不同的os::craete_thread方法进行线程创建; 
等待被唤醒后继续执行thread->run()方法;Thread::start(native_thread)方法进行线程启动,此时将线程状态设置为RUNNABLE,接着调用os::start_thread(thrread)

go new的协程数量不太会影响系统线程创建

Java的虚拟线程是在Java虚拟机内部实现的,不能跨越多个处理器或核心执行。多个虚拟线程需要挂载在一个平台线程
Go的协程是在操作系统内部实现的,它们可以跨越多个处理器或核心执行,并且Go的协程有更灵活的内存管理机制,执行效率可能不如虚拟线程。
-xss 指定线程栈大小, 不指定默认 1024KB
java线程 1Mb的虚拟内存 和 20Kb到60Kb的固定内存
协程2Kb到4Kb的固定内存
![在这里插入图片描述](https://img-blog.csdnimg.cn/5b09e71122034655808755157459578a.png#pic_center)
![在这里插入图片描述](https://img-blog.csdnimg.cn/9110d7de855640e49f87d5d992657323.png#pic_center)


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值