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

如果线程经常喜欢去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);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java线程池是一种用于管理和复用线程的机制。它可以在需要执行任务时,从线程池获取可用的线程来执行任务,而不是每次都创建新的线程。这样可以减少线程创建和销毁的开销,提高系统的性能和资源利用率。 Java线程池通常由一个线程池管理器、工作队列和一组工作线程组成。线程池管理器负责创建、初始化和释放线程池,工作队列用于存储待执行的任务,工作线程则负责从队列取出任务并执行。 使用线程池可以带来以下好处: 1. 提高系统性能:通过复用线程,降低了线程创建和销毁的开销,提高了系统的响应速度。 2. 控制资源消耗:通过限制线程的数量,可以控制系统同时运行的线程数量,避免资源过度消耗。 3. 提高系统稳定性:通过合理配置线程池参数,可以避免因为系统资源耗尽而导致系统崩溃。 在Java,可以使用java.util.concurrent包的Executor框架来创建和管理线程池。常用的线程池类型有FixedThreadPool、CachedThreadPool、SingleThreadExecutor等,每种类型适用于不同的场景和需求。 要使用线程池,通常需要以下步骤: 1. 创建线程池对象,并指定线程池的类型和参数。 2. 创建任务(Runnable或Callable对象)并提交给线程池。 3. 线程池会根据任务的类型和当前线程池状态,决定是创建新线程、复用现有线程,还是将任务加入到工作队列。 4. 线程池的工作线程会不断从队列获取任务,并执行任务的run方法。 5. 当不再需要执行任务时,需要关闭线程池,释放资源。 通过合理使用线程池,可以有效管理线程,提高系统的性能和稳定性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值