多线程的代价
来源:互联网 发布:麒麟啤酒 中国 知乎 编辑:程序博客网 时间:2024/06/05 17:40
原文链接:http://tutorials.jenkov.com/java-concurrency/costs.html
从一个单线程的应用到一个多线程的应用并不仅仅带来好处,它也会有一些代价。不要仅仅为了使用多线程而使用多线程。而应该明确在使用多线程时能多来的好处比所付出的代价大的时候,才使用多线程。如果存在疑问,应该尝试测量一下应用程序的性能和响应能力,而不只是猜测。
设计更复杂
虽然有一些多线程应用程序比单线程的应用程序要简单,但其他的一般都更复杂。在多线程访问共享数据的时候,这部分代码需要特别的注意。线程之间的交互往往非常复杂。不正确的线程同步产生的错误非常难以被发现,并且重现以修复。
上下文切换的开销
当CPU从执行一个线程切换到执行另外一个线程的时候,它需要先存储当前线程的本地的数据,程序指针等,然后载入另一个线程的本地数据,程序指针等,最后才开始执行。这种切换称为“上下文切换”(“context switch”)。CPU会在一个上下文中执行一个线程,然后切换到另外一个上下文中执行另外一个线程。
上下文切换并不廉价。如果没有必要,应该减少上下文切换的发生。
你可以通过维基百科阅读更多的关于上下文切换相关的内容:
http://en.wikipedia.org/wiki/Context_switch
增加资源消耗
线程在运行的时候需要从计算机里面得到一些资源。除了CPU,线程还需要一些内存来维持它本地的堆栈。它也需要占用操作系统中一些资源来管理线程。我们可以尝试编写一个程序,让它创建100个线程,这些线程什么事情都不做,只是在等待,然后看看这个程序在运行的时候占用了多少内存。
原创文章,转载请注明: 转载自并发编程网 – ifeve.com本文链接地址: 多线程的代价
- 多线程的代价
- 【java多线程的代价】
- 多线程的代价
- 多线程的代价
- 引入多线程的代价
- 多线程的代价
- 多线程的代价
- 多线程的代价
- 多线程的代价及上下文切换
- Java 并发 教程 - 多线程的代价
- Java并发系列-3、多线程的代价
- 3.多线程代价
- Java并发编程系列之三十:多线程的代价
- Java并发编程系列之六:多线程的代价
- 【Java.Concurrency】多线程的代价 & Why Threads Are A Bad Idea (for most purposes)
- Java并发编程(Java Concurrency)(3)- 多线程的代价
- 三无的代价
- 成熟的代价
- nyoj--814--又见拦截导弹
- 网络协议篇之SNMP协议(三)—— 不同版本(SNMPv1、v2c、v3)报文区别
- 编程规范
- Dome of Circus POJ
- hdu6112 今夕何夕
- 多线程的代价
- Linux 日志文件
- 极验验证码破解
- DFS之P2089 烤鸡
- Java.Swing
- 字符串分割—String.split(String regex)用法
- HDU-6113 度度熊的01世界
- 【floor函数】【ceil函数】
- Hdu6113度度熊的01世界(2017"百度之星"程序设计大赛