程序级线程和硬件级线程不同

因为在远程控制的图片传输中遇到一个瓶颈:增加服务器端抓取和发送屏幕图片的线程数,并没有提高一秒的图片传送的帧数。所以,看了CPU的工作原理和程序设计中线程机制这两个方面东西,主要是在网上看的。

总结了很多,不过我只把容易误解和理解错的部分贴出来

1、关于java多线程降低CPU运行效率的问题:如果CPU的运行涉及非CPU使用的事件(如网络、部分I/O等),使

用多线程将提高CPU的利用效率。而如果CPU的运行都是关于CPU使用的事件,同时CPU的使用已经达到100%,就

只能降低整个程序的执行效率。

2、主频就是CPU时钟频率。主频代表数字脉冲脉冲信号震荡的速度。主频一定程度上取决于流水线级数,跟处

理指令的速度有关系,但主频并不是每秒执行指令数。指令周期包含若干CPU周期,而CPU周期又包含若干时钟

周期,所以指令周期和时钟周期是两回事,并且不存在正比关系。

扫描二维码关注公众号,回复: 1417238 查看本文章

3、提高CPU的运算速度:可以通过多CPU、多核、多线程、增加流水线线的级数等等级数来实现。主频可以再提

高,不过也会因为制作工艺和研发的架构限制。不过主频太高并没有什么意义了,因为主频过高,流水线中的

电子单元运行错了,要重新整个指令的执行流程,会是CPU执行效率降低。

4、当软件的CPU利用率达到100%,再增加线程数已经没有任何用处。此时,只能通过增加硬件级的线程数来实

现。具体做法是用多核、SMT(同步多线程)、粗粒度的多线程技术来提高CPU的速度。
HT(超线程)属于SMT中一个分支。这个技术会是将来CPU提高性能的一个突破点。

5、为什么线程作为轻量级进程上下文切换时速度更加快:线程本身的数据通常只有寄存器数据,以及一个程序

执行时使用的堆栈。

P:因为本人是初学者,所以有错误还请各位高人指正谢谢~~

猜你喜欢

转载自jiadongkai-sina-com.iteye.com/blog/775401