为了账号安全,请及时绑定邮箱和手机立即绑定
首页 手记 java线程池和关闭线程池中的线程

java线程池和关闭线程池中的线程

2016.04.20 23:54 14139浏览

如果线程经常喜欢去new的话是不对的,你需要一个池子管理。

newCachedThreadPool 这个一个带缓存的线程池,是个可以无限大的线程池,新建的线程放倒这个池子里,当线程停掉了的时候,下个个线程进来,可以复用这个线程。
newFixedThreadPool 是个有长度的线程池,与上一个不同的是,当线程超越某个长度的时候,新进来的线程就会排队。线程池的大小最好匹配系统资源。按照系统资源来设置大小最好。
newScheduledThreadPool 可以执行周期性任务的定长线程池
newSingleThreadExecutor 任务按照指定顺序(FIFO, LIFO, 优先级)执行

用线程池实现昨天写的那个例子

ExecutorService fixedThreadPool = Executors.newFixedThreadPool(3);

Future future = fixedThreadPool.submit(new Runnable() { @Override public void run() { 
new Runnable() {
            @Override
            public void run() {
                /*
                 * 确保线程不断执行不断刷新界面
                 */
                while (true&&(!Thread.currentThread().isInterrupted())) {
                    try {

                        Log.i("tag","线程运行中"+Thread.currentThread().getId());

                        // 每执行一次暂停40毫秒
                        //当sleep方法抛出InterruptedException  中断状态也会被清掉
                        Thread.sleep(40);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                        //如果抛出异常则再次设置中断请求
                        Thread.currentThread().interrupt();
                    }
                }
            }
        }
);
//触发条件设置中断
future.cancel(true);
点击查看更多内容
2人点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
移动开发工程师
手记
粉丝
81
获赞与收藏
3600

关注TA,一起探索更多经验知识

同主题相似文章浏览排行榜

风间影月说签约讲师

51篇手记,涉及Java、MySQL、Redis、Spring等方向

进入讨论

Tony Bai 说签约讲师

151篇手记,涉及Go、C、Java、Python等方向

进入讨论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消