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

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

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. 调用方去改变外部代码的线程上下文有点越权的感觉,这不应该是调用方的职责。
相关推荐
zmzb010312 分钟前
C++课后习题训练记录Day47
开发语言·c++
村口张大爷18 分钟前
Spring Boot Validation Service层验证
java·spring boot·spring
北极糊的狐24 分钟前
报错java: 找不到符号符号: 类 XxxController位置: 程序包 com.ruoyi.xxx.xxx.service
开发语言·windows·python
云计算小黄同学25 分钟前
Java 服务从虚拟机迁移到 Kubernetes(K8s)集群
java·微服务·云原生·kubernetes
独自破碎E41 分钟前
如何用最短替换让字符串变平衡?
java·开发语言·算法·leetcode
老华带你飞1 小时前
宠物商城销售|基于Java+ vue宠物商城销售管理系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·宠物
电饭叔1 小时前
一个构建指定坐标轴在默认点(0,0)的构造方法《python语言程序设计》2018版--第8章17题第2部分
开发语言·笔记·python
qq_251533591 小时前
Python 查找元组中列表的数量
开发语言·python
papership1 小时前
【C++类的基本概念与定义】
开发语言·c++
计算机学姐1 小时前
基于Python的在线考试系统【2026最新】
开发语言·vue.js·后端·python·mysql·django·flask