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

问题: 父子线程的关系

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

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

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("主线程结束")
}

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

相关推荐
小bo波10 小时前
使用Thread子类创建线程 VS 使用Runnable接口创建线程的区别
java·多线程·thread·并发编程·runnable
SamDeepThinking11 小时前
高并发场景下,CompletableFuture与ForkJoinPool该如何取舍?
java·后端·面试
张不才14 小时前
CPU 100% 了怎么办?Java 性能排障的标准化操作
java·后端
shepherd11115 小时前
吞吐量提升 10 倍:高并发大批量数据处理任务的架构演进与性能调优
java·后端·架构
plainGeekDev18 小时前
单例模式 → object 声明
android·java·kotlin
用户2986985301419 小时前
Java 实现 Word 文档文本与图片提取的方法
java·后端
SimonKing20 小时前
铁子,IntelliJ IDEA 2026.1.3来了,升不升?
java·后端·程序员
咖啡八杯1 天前
GoF设计模式——策略模式
java·后端·spring·设计模式
用户128526116022 天前
我把祖传Java项目重构后,接口响应从3s砍到了200ms,只改了这几行代码
java