Java线程池使用引起的一点思考

今天遇到这样一段代码,具体业务代码略掉,只留框架

    ThreadPoolExecutor executor = new ThreadPoolExecutor(10, 20, 60L, TimeUnit.SECONDS, new LinkedBlockingQueue());
    Thread task = new Thread(new Runnable(){
        public void run(){
            //业务代码,略
        }
    });
    executor.execute(task);

因为创建线程的成本较高,所以我们使用ThreadPoolExecutor线程池重用线程。上面代码task每次创建一个线程,这样不是我们违背使用线程池的初衷,造成资源浪费吗?

这段代码引起我的一个思考:Java程序是在new Thread(**)的时候创建线程吗?

查看JDK源码,Thread的构造函数没有创建线程,而是start方法调用一个native的start0方法让JVM去创建操作系统线程。

    private native void start0();

所以上面的代码虽然不太优雅,但并不会浪费资源创建线程,最多浪费的是Thread对象占用的资源。

不过,我们写代码时还是通过实现Runnable接口来创建task比较好,这样代码清晰,不会让人疑惑。

因为我们的代码除了给机器看,更重要的是给人看。

你可能感兴趣的:(JAVA基础)