更新时间:2020-04-24 14:10:42 来源:极悦 浏览2019次
线程基础知识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(),staticinterrupted()来自己实现中断线程
interrupt():调用一个线程的interrupt()方法中断一个线程,并不是强行关闭这个线程,只是跟这个线程打个招呼,将线程的中断标志位置为true,线程是否中断,由线程本身决定。
isInterrupted():判定当前线程是否处于中断状态。
staticinterrupted():判定当前线程是否处于中断状态,同时中断标志位改为false。
thead.setPriority()方法
优先级的范围1~100,缺省为5,但线程的优先级不可靠,不建议作为线程开发时候的手段。
java线程是映射到系统的原生线程来实现的,所以线程的调度最终决定于操作系统。虽然现在很多操作系统提供了线程优先级的概念,但是不见得会与java线程的优先级一一对应,如果优先级比java线程多还好说,要是少的话,就不得不出现几个优先级相同的情况了。
不能太依赖优先级,优先级可能会被系统自行改变。在widows系统存在着一个“优先级推进器”,它的大致作用就是当前系统发现一个线程执行的特别“勤奋努力”的话,可能就会越过线程优先级给它分配时间。
以上就是极悦java培训机构的小编针对“编程入门视频:Java并发编程基础”的内容进行的回答,希望对大家有所帮助,如有疑问,请在线咨询,有专业老师随时为你服务。
0基础 0学费 15天面授
Java就业班有基础 直达就业
业余时间 高薪转行
Java在职加薪班工作1~3年,加薪神器
工作3~5年,晋升架构
提交申请后,顾问老师会电话与您沟通安排学习