cpu一个核心到底是不是对应一个线程?
星期五面了阿里二面,被这个问题搞蒙了。我的理解是我们虽然用户态会有很多线程,但是内核态中真正同一时刻处于运行中的线程一般是不多于cpu的核心数的。也就是说,我的理解是cpu中一个核心往往对应内核态中正在运行的一个线程。因此我们java线程池中的线程不是越多越好。面试官说我的理解是有问题的,也没和我说具体哪里有问题,我真的心态崩了......后面也没好好回答,直接挂了。求大神解答
星期五面了阿里二面,被这个问题搞蒙了。我的理解是我们虽然用户态会有很多线程,但是内核态中真正同一时刻处于运行中的线程一般是不多于cpu的核心数的。也就是说,我的理解是cpu中一个核心往往对应内核态中正在运行的一个线程。因此我们java线程池中的线程不是越多越好。面试官说我的理解是有问题的,也没和我说具体哪里有问题,我真的心态崩了......后面也没好好回答,直接挂了。求大神解答
全部评论
“cpu中一个核心往往对应内核态中正在运行的一个线程”这句话不对,用户态线程也是由cpu分配时间片才可以执行的。
“因此我们java线程池中的线程不是越多越好”这个东西要看线程是io密集、计算密集还是混合型,有对应的估算公式
四个核心,每个核心支持超线程,合计8个线程。同时支持8个任务,超线程的两个要共享很多资源(所以当某种情况必须独占的时候,超线程的两个线程也不能并发),所以你可以理解为至少可以并发4个任务,至多可以并发8个任务。根据任务对资源的使用情况,4-8之间。
如果一个核心对应一个线程,那CPU为什么有4核8线程,而不是4核4线程
周志明先生的深入了解JVM的最后几章有介绍线程的实现方式,一对一、一对多和多对多。Java中线程是直接一对一映射到内核线程的。我的理解是内核线程应该不超过CPU线程数吧,比如8核16线程的话最多同时运行16个内核线程。
4线程可并行,更多线程可并发。时间片轮转调度
intel的cpu有超线程技术,一核双线程,AMD的一核单线程
在一个cpu核心上,一条指令会被分为多个微指令执行,每种微指令有相应的器件运行,一个核心可以细分成多个组件,由于一条指令在这多个组件上顺序执行,所有组件存在冗余,于是有了超线程,相当于一个指令周期运行两个指令,宏观看起来同时运行了两个程序
超线程嘛
一个cpu可以对应很多个线程
一般n+1到2n+1,看io密集型还是计算
相关推荐
04-15 15:01
南京理工大学 C++ 点赞 评论 收藏
分享
05-23 20:59
湖南工商大学 Java 
点赞 评论 收藏
分享