主线程退出后子线程是否还会正常运行?

问题: 父子线程的关系

今天突然有感而发, 想要来探讨一下主线程和子线程之间的关系。

例一:子线程执行时间较父线程慢

java 复制代码
public class ThreadTest {
    public static void main(String[] args) {
        // 测试主线程 和 子线程
        Thread sonThread = new Thread(
                () -> {
                    try {
                        Thread.sleep(3000);
                    } catch (InterruptedException e) {
                        throw new RuntimeException(e);
                    }
                    System.out.println("子线程结束");
                }
        );
        sonThread.start();
        System.out.println("父线程结束");
    }
}

结果是都进行了执行,这说明主线程执行完毕后,会等待子线程进行执行完毕后退出。

例二:主线程执行的较慢

java 复制代码
public class ThreadTest {
    public static void main(String[] args) {
        // 测试主线程 和 子线程
        Thread sonThread = new Thread(
                () -> {

                    System.out.println("子线程结束");
                }
        );
        sonThread.start();
        try {
            Thread.sleep(3000);
        } catch (InterruptedException e) {
            throw new RuntimeException(e);
        }
        System.out.println("父线程结束");
    }
}

结果也是都进行了执行

而对于Go来说则不一样,Go一旦主线程结束,协程就会自动的退出

例三 主线程执行的较快

go 复制代码
func main() {

	go func() {
		fmt.Println("1111")
	}()
	fmt.Println("主线程结束")
}

如果想要协程执行完才退出的话,必须使用阻塞来进行控制。

相关推荐
qq_38061916几秒前
html怎么用deno运行_Deno如何作为本地服务器运行HTML文件
jvm·数据库·python
小红的布丁8 分钟前
BIO、NIO、AIO 与 IO 多路复用:select、poll、epoll 详解
java·数据库·nio
Elastic 中国社区官方博客8 分钟前
在 Elastic 中使用 OpenTelemetry 内容包可视化 OpenTelemetry 数据
大数据·开发语言·数据库·elasticsearch·搜索引擎
lifallen9 分钟前
Flink Checkpoint 流程、Barrier 流动与 RocksDB 排障
java·大数据·flink
C+++Python11 分钟前
如何学习Python的应用领域知识?
开发语言·python·学习
疯狂打码的少年13 分钟前
【Day12 Java转Python】Python工程的“骨架”——模块、包与__name__
java·开发语言·python
希望永不加班18 分钟前
SpringBoot 自定义 Starter:从零开发一个私有 Starter
java·spring boot·后端·spring·mybatis
全栈开发圈22 分钟前
新书速览|MATLAB数据分析与可视化实践:视频教学版
开发语言·matlab·数据分析
网域小星球28 分钟前
C 语言从 0 入门(二十二)|内存四区:栈、堆、全局、常量区深度解析
c语言·开发语言
u01074754631 分钟前
mysql如何实现高可用集群架构_基于MHA环境搭建与部署
jvm·数据库·python