【JAVA学习之路 | 提高篇】进程与线程(Thread)

简介: 【JAVA学习之路 | 提高篇】进程与线程(Thread)

1.相关概念

(1). 程序(program) : 为完成特定任务,用某种语言编写的一组指令的集合.即指一块静态的代码.


(2). 进程(progress) : 程序的一次执行过程,或者是正在运行中的应用程序(如正在运行的QQ,正在运行的网易第五人格).


  • 每一个进程都有一份独立的内存空间,系统运行一个程序便是进程创建到运行到销毁的过程.
  • 程序是静态的,而进程是动态的.
  • 进程作为操作系统调度和分配资源的最小单位,系统在运行时会为每个线程分配内存.
  • 现代的操作系统,大多支持多进程的,支持同时运行多个程序.(比如你边玩着第五人格,边开着QQ聊天界面跟女朋友聊天).

(3). 线程(thread) : 进程可进一步细化为线程,是程序内部的一条执行路径.一个进程至少有一个线程,可以有很多线程.

  • 一个进程同一时间如果并行运行多个线程,就是支持多线程的(比如毒王360,点开360便创建了一个进程,而你同时使用杀毒,清理垃圾等功能时,便是一个进程执行多个线程).
  • 线程作为CPU调度和执行的最小单位.
  • 一个进程的多个线程可以共享相同的内存单元.他们从同一个堆中分配对象,可以访问相同的对象.使得线程间的通信更方便简洁高效.但多个线程操作内存单元可能会带来安全隐患.
  • 线程独享区域 : 虚拟机栈,本地方法栈,程序计数器.
  • 线程共享区 : 堆(Heap),方法区(Method Area).

注 :

  • 不同进程之间是不共享内存的.
  • 而不同进程之间可以通信,但通信成本可能较高.

2.线程调度

(1). 分时调度 : 所有线程轮流使用CPU的使用权,并且平均分配每个线程占用CPU的运行时间.

(2). 抢占式调度 : 让优先级高的线程较大概率的占用CPU调用时间,如果所有线程优先级相同,那么将随机选择一个线程.java使用的便是该种调度.

3.多线程程序的优点

背景 : 以单核CPU为例,只使用单个线程先后完成多个任务,肯定比多个线程完成的时间更短,那为什么要使用多线程程序呢.

  1. 提高程序响应效率,对图形化界面更有意义,可以同时做多个事情.
  2. 提高计算机CPU的利用率.
  3. 改善程序结构.将既长又复杂的程序分成多个线程独立运行,利于理解和修改.

4.单核CPU与多核CPU

(1). 单核CPU : 在一个时间单元内,只执行一个线程的任务.可以把CPU看作是医生的诊室,每个人只能进去一个人进去看病.代码进过一系列前导操作,到CPU运行时发现只有一个医生,所以只能排队一次看病.


这时如果要提升系统性能,有两种方法 : 要么多核处理(一个医生给一个病人看病,换为多个医生给多个病人看病),要么提升CPU性能(让医生看病快点).


问 : 那么多核的CPU是单核的整数倍吗.理论上是不可能的.至少两方面损耗.

  • 其他共有资源的限制 : 4核CPU对应的寄存器,内存并没有扩充为单核的四倍.(就像四个医生给四个病人看病,但医院的b超机器还只是原来的一台).
  • 多个CPU的协调管理损耗 : 多个核心同时运行两个相关的任务,可能需要考虑到任务同步,这就需要损耗额外的性能.

5.并行与并发

(1). 并行(parallel) : 指两个及以上的任务同时发生,即同一时刻,多个任务在多个CPU上同时进行.

------------------------

------------------------


------------------------


(2). 并发(concurrency) : 指两个及以上的任务在同一时间段发生.即一个时间段,多个任务在单个CPU上快速轮转,交替执行.宏观上表现为并行.


-------                         ------


       ----------                                    ------


                   -----------          -----------

相关文章
|
7月前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
390 1
|
7月前
|
JSON 网络协议 安全
【Java基础】(1)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
362 1
|
8月前
|
数据采集 存储 弹性计算
高并发Java爬虫的瓶颈分析与动态线程优化方案
高并发Java爬虫的瓶颈分析与动态线程优化方案
Java 数据库 Spring
350 0
|
7月前
|
Java 调度 数据库
Python threading模块:多线程编程的实战指南
本文深入讲解Python多线程编程,涵盖threading模块的核心用法:线程创建、生命周期、同步机制(锁、信号量、条件变量)、线程通信(队列)、守护线程与线程池应用。结合实战案例,如多线程下载器,帮助开发者提升程序并发性能,适用于I/O密集型任务处理。
714 0
|
7月前
|
Java
如何在Java中进行多线程编程
Java多线程编程常用方式包括:继承Thread类、实现Runnable接口、Callable接口(可返回结果)及使用线程池。推荐线程池以提升性能,避免频繁创建线程。结合同步与通信机制,可有效管理并发任务。
295 6
|
8月前
|
算法 Java
Java多线程编程:实现线程间数据共享机制
以上就是Java中几种主要处理多线程序列化资源以及协调各自独立运行但需相互配合以完成任务threads 的技术手段与策略。正确应用上述技术将大大增强你程序稳定性与效率同时也降低bug出现率因此深刻理解每项技术背后理论至关重要.
536 16
|
10月前
|
Java API 微服务
为什么虚拟线程将改变Java并发编程?
为什么虚拟线程将改变Java并发编程?
444 83
|
机器学习/深度学习 消息中间件 存储
【高薪程序员必看】万字长文拆解Java并发编程!(9-2):并发工具-线程池
🌟 ​大家好,我是摘星!​ 🌟今天为大家带来的是并发编程中的强力并发工具-线程池,废话不多说让我们直接开始。
424 0
|
Linux
Linux编程: 在业务线程中注册和处理Linux信号
本文详细介绍了如何在Linux中通过在业务线程中注册和处理信号。我们讨论了信号的基本概念,并通过完整的代码示例展示了在业务线程中注册和处理信号的方法。通过正确地使用信号处理机制,可以提高程序的健壮性和响应能力。希望本文能帮助您更好地理解和应用Linux信号处理,提高开发效率和代码质量。
320 17

热门文章

最新文章