答案是否定的,因为频繁的创建和销毁线程,会耗费一定的CPU资源的。而且CPU在执行线程中的指令时,涉及到了线程的上下文切换,这也是一定的开销的。CPU在固定时间执行了一个线程中的指令后,会切换到下一个任务。但是在切换前,会保存当前任务的执行状态,以便下次切换会这个任务时可以加载这个任务的状态。程序计数器,就是起到了这个作用。
今天我们就主要来聊一聊这个问题。我们通过实例来验证这个说法。
我们通过创建一个FixThreadPool并指定它的核心线程数来执行我们的任务。对Java线程池有一定了解的同学都知道,FixThreadPool是Java为我们内置的四种线程池种的一中。
它只配置了核心线程数,数量由开发者指定。如果线程池内的核心线程数,达到了核心线程数量,我们的任务就会被放在一个阻塞队列BlockingQueue中,等待空闲的线程去取出队列中的任务并执行。
下面我们上代码:
//创建一个原子类,记录当前任务的完成数量。
AtomicInteger atomicInteger = new AtomicInteger(0);
//创建核心线程数量为10的FixThreadPool
ExecutorService mFixThreadPool = Executors.newFixedThreadPool(20);
//记录任务的开始时间
private long start = 0;
//记录任务的结束时间
private long end = 0;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
//记录任务开始时间
start = System.currentTimeMillis();
//向线程池中提交20个任务,并执行
for(int i = 0 ; i < 20;i++){
Runnable runnable = new MyRunnable(i,AsyncActivity.this);
mFixThreadPool.submit(runnable);
}
}
private static class MyRunnable implements Runnable{
private final WeakReference mActivity;
private int i = 0;
MyRunnable(int i, AsyncActivity mActivity) {
this.i = i;
this.mActivity = new WeakReference(mActivity);
}
@Override
public void run() {
while (i<100000){
i++;
}
int g = mActivity.get().atomicInteger.addAndGet(1);
if(g == 10){
mActivity.get().end = System.currentTimeMillis();
Log.v(“AsyncActivity”,mActivity.get().end - mActivity.get().start+“ms”);
}
}
}
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
资料的朋友可以戳我获取!!**](https://bbs.csdn.net/topics/618165277)
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!