您好,登录后才能下订单哦!
这篇文章主要讲解了“怎么理解Java并发编程中的线程”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么理解Java并发编程中的线程”吧!
1、线程基础概念
线程是指在一个单独进程中,对于CPU和内存而言的多个工作单位,所有线程在进程中的资源都是共享的,包括全局数据、执行代码等。
cpu核心数与线程数
核心数 : 线程数 = 1 : 1
如一个8核的cpu,该cpu会至少支持8个线程同时运行
intel引入了超线程技术后:
核心数 : 线程数 = 1 : 2
在编码过程中可以感觉到同时运行的线程远远不止这些。由于cpu的时间片轮转机制又称RR调度,简单点讲,操作系统会把已就绪的线程排成一个队列,给每个进程一个时间分片,该线程在cpu中执行完这个时间分片后,不论是否执行完都会让出cpu资源给另外的线程,这样在某一时间段内就好像有很多线程在同时运行。
操作系统和cpu在进行时间分片的任务切换时也是需要时间的,而且往往占用的时间比例又很大,所以在多线程开发时关注上下文切换对于多线程执行时间和性能的影响。
二、进程和线程区别
进程:程序运行进行资源分配的最小单位,进程中有多个线程,会共享这个线程的资源
线程:cpu调度的最小单位,必须依赖进程而存在
例子:启动的一个jar包程序就是一个进程,而可以通过启动参数配置它的内存大小,-xmx,-xms等。而每一个请求都是在线程上去进行的,cpu通过执行线程任务完成每个请求任务。
三、并行和并发
并行:同一时刻,可以同时处理事情的能力
并发:与单位时间有关,在单位时间内可以处理问题的能力
举个例子,假设不考虑超线程技术,一个4核cpu在任何一个时刻处理的是4个线程,并行数为4,而由于时间片轮转机制,它在1秒内可以支持处理100个线程,它在1秒内的并发数为100
四、高并发编程优势
充分利用cpu的资源。如果是单线程,只占用一个核,其它的空闲;加快响应时间。合理的设计多线程程序,使请求处理加快;程序模块化异步化
线程共享资源,会存在冲突、会存在死锁、启动线程太多,滥用线程,压垮服务器。线程方法,java线程是协作式的,而不是抢占式
五、线程终止的方法interrupt()
线程之前提供了stop(),resume(),suspend()方法来终止线程,但已不建议使用,stop()会导致线程不会正确的释放资源,suspend()会导致死锁。
要通过interrupt(),isInterrupted(),static interrupted()来自己实现中断线程
interrupt() :调用一个线程的interrupt() 方法中断一个线程,并不是强行关闭这个线程,只是跟这个线程打个招呼,将线程的中断标志位置为true,线程是否中断,由线程本身决定。
isInterrupted(): 判定当前线程是否处于中断状态。
static interrupted() :判定当前线程是否处于中断状态,同时中断标志位改为false。
thead.setPriority()方法
优先级的范围1~100,缺省为5,但线程的优先级不可靠,不建议作为线程开发时候的手段。
java线程是映射到系统的原生线程来实现的,所以线程的调度最终决定于操作系统。虽然现在很多操作系统提供了线程优先级的概念,但是不见得会与java线程的优先级一一对应,如果优先级比java线程多还好说,要是少的话,就不得不出现几个优先级相同的情况了。
不能太依赖优先级,优先级可能会被系统自行改变。在widows系统存在着一个“优先级推进器”,它的大致作用就是当前系统发现一个线程执行的特别“勤奋努力”的话,可能就会越过线程优先级给它分配时间。
感谢各位的阅读,以上就是“怎么理解Java并发编程中的线程”的内容了,经过本文的学习后,相信大家对怎么理解Java并发编程中的线程这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。