因为在远程控制的图片传输中遇到一个瓶颈:增加服务器端抓取和发送屏幕图片的线程数,并没有提高一秒的图片传送的帧数。所以,看了CPU的工作原理和程序设计中线程机制这两个方面东西,主要是在网上看的。
总结了很多,不过我只把容易误解和理解错的部分贴出来:
1、关于java多线程降低CPU运行效率的问题:如果CPU的运行涉及非CPU使用的事件(如网络、部分I/O等),使
用多线程将提高CPU的利用效率。而如果CPU的运行都是关于CPU使用的事件,同时CPU的使用已经达到100%,就
只能降低整个程序的执行效率。
2、主频就是CPU时钟频率。主频代表数字脉冲脉冲信号震荡的速度。主频一定程度上取决于流水线级数,跟处
理指令的速度有关系,但主频并不是每秒执行指令数。指令周期包含若干CPU周期,而CPU周期又包含若干时钟
周期,所以指令周期和时钟周期是两回事,并且不存在正比关系。
3、提高CPU的运算速度:可以通过多CPU、多核、多线程、增加流水线线的级数等等级数来实现。主频可以再提
高,不过也会因为制作工艺和研发的架构限制。不过主频太高并没有什么意义了,因为主频过高,流水线中的
电子单元运行错了,要重新整个指令的执行流程,会是CPU执行效率降低。
4、当软件的CPU利用率达到100%,再增加线程数已经没有任何用处。此时,只能通过增加硬件级的线程数来实
现。具体做法是用多核、SMT(同步多线程)、粗粒度的多线程技术来提高CPU的速度。
HT(超线程)属于SMT中一个分支。这个技术会是将来CPU提高性能的一个突破点。
5、为什么线程作为轻量级进程上下文切换时速度更加快:线程本身的数据通常只有寄存器数据,以及一个程序
执行时使用的堆栈。
P:因为本人是初学者,所以有错误还请各位高人指正谢谢~~