关于启动线程位置的一点思考

最近看到两段相似的代码,第一段是

java 复制代码
public class Main {
    public static void main(String[] args) {
        new Thread(() -> {
            doWork();
        }).start();
    }
    
    static void doWork(){
        //执行耗时操作...
    }
}

第二段为

java 复制代码
public class Main {
    public static void main(String[] args) {
        doWork();
    }

    static void doWork() {
        new Thread(() -> {
            //执行耗时操作...
        }).start();
    }
}

两段代码的差别仅在启动线程的位置。

有时候写程序比较随意的时候,两种形式的代码都可以可能出现,下面记录下我对这种形式的一些想法。

第一种:由调用方来控制线程启动

这种对应上述在main方法中启动线程的情形。这种形式最初看到的时候是在Android的一个Activity的代码里,因为Activity的诸多方法运行在主线程中,如果执行耗时操作,那么就会导致ANR程序不响应,那么就会把一些认为是耗时的操作放在其他线程中,于是就有了类似的代码:

java 复制代码
public class DemoActivity extends Activity{

    @Override
    protected void onResume() {
        super.onResume();
        new Thread(() -> {
            xxManager.startDoWorks();
        }).start();
    }
}

第二种:由实现方来控制线程启动

这种对应上述第二种在doWork方法中启动线程的情形。这种代码最初是在一个Controller的代码中看到,因为这个类中包含了一些网络和文件访问的操作,所以接口方法都另起线程来执行:

java 复制代码
public class DemoController{

    public void doXXXWork(Callback callback){
        new Thread(() -> {
            //执行耗时操作...
        }).start();
    }
}

对比和思考

虽然两种代码我都写过,但我还是倾向于后者由实现方来控制线程启动。理由如下:

  1. 实现方知道内部代码的具体实现,可以决定内部代码在哪种类型的线程中执行。而调用方需要查看实现方的代码才能知道。
  2. 实现方对实现的代码有着控制权,可以变更代码实现,根据实现方式来调整线程的使用。
  3. 调用方去改变外部代码的线程上下文有点越权的感觉,这不应该是调用方的职责。
相关推荐
见青..几秒前
JAVA安全靶场环境搭建
java·web安全·靶场·java安全
一坨阿亮2 分钟前
Docker 离线部署
java·spring cloud·docker
techdashen4 分钟前
Rust 社区在 4 月做了什么:项目管理月报解读
开发语言·rust·mfc
十五年专注C++开发5 分钟前
QFluentKit: 一个基于 Qt Widgets 的 Fluent Design 风格 UI 组件库
开发语言·c++·qt·ui·qfluentkit
lly2024066 分钟前
PHP JSON 使用指南
开发语言
沐知全栈开发11 分钟前
jQuery 尺寸
开发语言
Byte Wizard13 分钟前
C语言指针深入浅出5
c语言·开发语言
LucaJu15 分钟前
一次 OOM 线上排查实录
java·jvm·oom·内存溢出
csbysj202016 分钟前
Vue.js 监听属性
开发语言
Hesionberger24 分钟前
LeetCode 101:对称二叉树(多语言解法)
开发语言·python