在线客服
扫描二维码
下载博学谷APP扫描二维码
关注博学谷微信公众号
线程基础知识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系统存在着一个“优先级推进器”,它的大致作用就是当前系统发现一个线程执行的特别“勤奋努力”的话,可能就会越过线程优先级给它分配时间。
— 申请免费试学名额 —
在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!
相关推荐 更多
Kotlin与Java相比的优缺点有哪些?
Kotlin语言被谷歌公开作为Android官方开发语言之后,就有传言,kotlin会取代Java。然而即使到了现在还是有很多人并不了解kotlin是什么。所以今天小编给大家科普一下关于kotlin的一些问题。
14647
2019-08-09 18:03:46
Java有什么优点?Java开发优势
Java有什么优点?Java作为目前各大互联网公司和编程语言中非常重要和常见的编程语言之一,被许多行业所运用
6577
2020-05-26 10:11:30
Java学习技巧和方法有哪些?
Java的方法和经验,文法初始化阶段,必须首先学习如何操作对象,如何操作 if和 for,如何操作 list set map,然后是如何处理线程、 IO和 jdbc等,其余部分,如果暂时还不了解,可以以后再学习。这一步就到了,你可以写一些小程序,打印在控制台上,练习逻辑思维。再一次被称为 JAVASE毕业,实际上只是入门,如果要向 WEB方向发展,这些已经基本足够了。
4171
2020-06-22 16:27:34
Java程序的开发与运行原理解析
可能刚刚接触编程的初学者会发现,编写一个Java程序其实很简单,但是Java程序的运行过程却是非常复杂的。关于Java程序工作原理这部分知识,虽然不要求编程学习者完全掌握,你但是至少需要了解它的大致过程。下面小编将好好介绍一下Java程序的开发与运行原理,大致分为以下三步:编写源文件、编译以及运行。
4949
2020-08-12 16:59:55
Java多线程遇到死锁三招彻底解决
在多线程环境中,多个进程可以竞争有限数量的资源。当一个进程申请资源时,如果这时没有可用资源,那么这个进程进入等待状态。有时,如果所申请的资源被其他等待进程占有,那么该等待进程有可能再也无法改变状态。这种情况称为死锁。
3963
2022-06-22 15:00:01