比如,如果一个线程正在迭代某非线程安全集合.
另外一个集合却修改了这个集合.
则会跑出modify什么的.
如果一个线程取了某个对象做 *** 作.另外一个线程却将对象里的内容置空,则会空指针
再比如说.一个线程需要判断某个集合是否为空.如果为空则new一个新的放进去,并在集合里添加一个元素.当他判断到这个集合为空了之后,在new集合的时候,另外一个线程判空,new 集合,并添加了一个元素,
那么第一个线程继续 *** 作,会把第二个线程的元素给抹杀掉.数据袭漏液丢失.
这样的例子有很多很多.
程序搜型崩溃是轻的.
数据异常会让人崩溃.运行一个程序,每次都得到不同的结果你会是什么表情....
楼上的也说了,线程不宜过多.这是真的.毕竟,线程都是要占用cpu资源.一万个人吃一块冰糕....这个冰糕肯定瞬间就被吃没了.而且,这一万个人基本都吃不着.
Java多线程分类中写了21篇多线程的文章,21篇文章的内容很多,个人认为,学习,内容越多、越杂的知识,越需要进行深刻的总结,这样才能记忆深刻,将知识变成自己的。java课程培训机构认为这篇文章主要是对多线程的问题进行总结的,因此罗列了多个多线程的问题。
这些多线程的问题,有些来源于各大网站、有些来源于自己的思考。
(1)发挥多核CPU的优势
随着工业的进步,现在的笔记本、台式机乃至商用的应用服务器至少也都是双核的,4核、8核甚至16核的也冲行培都不少见,如果是单线程的程序,那么在双核CPU上就浪费了50%,在4核CPU上就浪费了75%。单核CPU上所谓的”多线程”那是假的多线程,同一时间处理器只会处理一段逻辑,只不过线程之间切换得比较快,看着像多个线程”同时”运行罢了。多核CPU上的多线程才是真正的多线程,它能散唯让你的多段逻辑同时工作,多线程,可以真正发挥出多核CPU的优势来,达到带念充分利用CPU的目的。
(2)防止阻塞
从程序运行效率的角度来看,单核CPU不但不会发挥出多线程的优势,反而会因为在单核CPU上运行多线程导致线程上下文的切换,而降低程序整体的效率。但是单核CPU我们还是要应用多线程,就是为了防止阻塞。试想,如果单核CPU使用单线程,那么只要这个线程阻塞了,比方说远程读取某个数据吧,对端迟迟未返回又没有设置超时时间,那么你的整个程序在数据返回回来之前就停止运行了。多线程可以防止这个问题,多条线程同时运行,哪怕一条线程的代码执行读取数据阻塞,也不会影响其它任务的执行。
(3)便于建模
这是另外一个没有这么明显的优点了。假设有一个大的任务A,单线程编程,那么就要考虑很多,建立整个程序模型比较麻烦。但是如果把这个大的任务A分解成几个小任务,任务B、任务C、任务D,分别建立程序模型,并通过多线程分别运行这几个任务,那就简单很多了。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)