Alchemist66
Alchemist66
采纳率100%
2018-09-05 06:10

Java多线程和其创建对象的内存使用机制?

5

1.

 public void addActionRecord(Object oldEntity, Object newEntity,String applicationName) {
        try {
            ActionVo actionVo = BorpUtil.getActionRecord(oldEntity, newEntity,applicationName);
            Executors.newFixedThreadPool(1).submit(() -> {
                try {
                    addAction(actionVo);
                } catch (Exception var3) {
                    System.out.println(var3.getMessage());
                }
            });
        } catch (Exception var4) {
            System.out.println(var4.getMessage());
        }
    }

主要问题是:是不是每次执行上面这段代码的时候都会创建一个线程?然后用这种线程池创建出的核心线程是不是一直不会被回收?如果这里执行多次的话是不是会创建出许多回收不掉的线程。
PS:addAction(actionVo);这里只是一个业务方法
2.在Linux环境下,每个线程资源共享还是会给每个线程单独分配内存?
3.如果是单独分配内存,当非主线程空闲被回收时,这个线程之前创建的对象会立即被回收吗?还是等垃圾回收的时候才会去回收?

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享
  • 邀请回答

2条回答

  • zhaomin_g _zming 3年前
     public static ExecutorService newFixedThreadPool(int nThreads) {
            return new ThreadPoolExecutor(nThreads, nThreads,
                                          0L, TimeUnit.MILLISECONDS,
                                          new LinkedBlockingQueue<Runnable>());
        }
    

    newFixedThreadPool会创建一个线程池,此线程池只有一个工作线程。并且此工作线程没有超时时间,这意味着,除非调用pool.showdownnow,否则
    此工作线程将永远不会回收,最终内存泄漏,所以要么把线程创建放到全局范围,要么线程池用完进行关闭

    点赞 1 评论 复制链接分享
  • xcgh xcgh 3年前

    Executors.newFixedThreadPool(1),是会创建一个线程池,线程池里有一个线程,建议把Executors.newFixedThreadPool放在外面,线程放在池里运行

    点赞 评论 复制链接分享

为你推荐