主线程和子线程

本文探讨了Java中主线程创建子线程并通过接口回调到主线程的过程。具体介绍了如何在子线程执行完毕后通过回调函数返回主线程,并验证回调函数是否运行在主线程上。

线程切换

//1、主线程新建子线程,子线程执行完后调用interface回调主线程,回调函数中代码跑在主线程还是子线程?
public class T803 {
    public static void main(String[] args) {
        //获得当前线程的名称  
        System.out.println("main:"+Thread.currentThread().getName()); 

        final TT tt=new TT(){
            @Override
            public void finish() {
                System.out.println("finish:"+Thread.currentThread().getName());
            }

        };

        new Thread(){
            public void run() {
                System.out.println("new Thread run:"+Thread.currentThread().getName()); 
                tt.finish();
            };
        }.start();

    }
    public interface TT{
        void finish();
    }

}
### Linux 中主线程子线程的区别及用法 #### 一、主线程子线程的概念区别 在 Linux 系统中,主线程通常是指程序启动时创建的第一个线程。它是整个进程的入口点,并负责初始化其他资源线程。子线程则是由主线程或其他线程通过 `pthread_create` 函数创建的新线程[^1]。 - **生命周期独立性** 主线程子线程可以具有不同的生命周期模式。一种常见的场景是两者互不干扰,即使主线程结束,子线程仍可继续运行;另一种情况是当主线程结束后,所有未完成的子线程也会随之终止。 - **资源共享特性** 所有的线程(包括主线程子线程)都共享同一进程地址空间内的资源,例如文件描述符、内存映射区域以及全局变量等。然而,每个线程拥有自己的栈空间寄存器状态[^3]。 #### 二、Pthreads API 创建与管理线程的方法 以下是使用 POSIX Threads (`pthreads`) 库来管理操作主线程子线程的一些基本方法: ##### 1. 创建新线程 要创建一个新的子线程,需调用 `pthread_create()` 函数: ```c #include <pthread.h> int pthread_create(pthread_t *thread, const pthread_attr_t *attr, void *(*start_routine)(void*), void *arg); ``` 其中参数说明如下: - `thread`: 返回生成的新线程 ID; - `attr`: 设置线程属性,默认传入 NULL 表示采用默认配置; - `start_routine`: 新线程执行的目标函数指针; - `arg`: 向目标函数传递的数据指针。 注意,在某些情况下快速终止的分离线程可能导致错误获取其实际 ID[^2]。 ##### 2. 控制线程退出方式 对于希望优雅地关闭某条线程的情形下,可通过调整取消行为实现更灵活的操作。具体来说有两种主要类型——延迟取消(`PTHREAD_CANCEL_DEFERRED`) 即时取消(`PTHREAD_CANCEL_ASYNCHRONOUS`) [^4]: - 延迟取消意味着只有在线程到达特定取消点时才会真正停止工作流程。 - 即时取消允许随时强制中断当前活动中的任何计算过程。 ##### 3. 发送信号至单个或全体成员 利用标准 C 提供的功能或者专门针对多线程环境设计接口均可达成向某个单独实体或者是整体组群传达消息的目的。比如借助于系统级命令 kill() 或者专用工具 pthread_kill()[^3]: ```c // 给定 pid 对应的整体实例投递通知 if(kill(getpid(), SIGUSR1)==0){ printf("Signal sent successfully.\n"); } // 针对指定 tid 实施精准打击 pthread_kill(thread_id,SIGTERM); ``` 另外值得注意的是关于条件变量同步机制方面存在局限性:假如没有任何监听方处于待命姿态接收到来自生产者的提示信息的话那么这些更新将会被完全丢弃掉而不会保留下来供后续使用者发现[5]. #### 总结 综上所述,Linux 下面围绕着主次角色之间存在着多样化的协作形式可供开发者依据实际需求选取最合适的解决方案.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值