用户线程已经全部退出运行了,只剩下守护线程存在了,虚拟机也就退出了。 因为没有了被守护者
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)
java20的虚拟线程和go的协程线程
于 2023-08-29 11:07:30 首次发布