什么是线程?为什么需要线程?和进程的区别?

简介: 什么是线程?为什么需要线程?和进程的区别?

前言

       在学习线程之前,必须了解什么是进程,线程借助进程的资源而实现的,也可以说是进程的子任务,是为了改进进程而出现的。进程的学习:http://t.csdn.cn/uHb93

一.线程是什么?

1.1.为什么需要线程

       在执行多个任务时,多进程就已经可以实现并发编程的效果了,可是却有一个明显的缺点。

缺点进程的创建都需要大量的资源(例如:PCB、硬盘资源等),因此开销就变大了;而且创建时需要大量的资源,也是需要更多的时间,因此导致速度变慢了。

解决方法:为了解决进程的缺点,于是提出了可共享 两字,先创建一个进程并且分配好资源,后续创建的进程创建时只需要分配一个简单PCB,然后 共享 第一个进程的文件描述表、内存硬盘等资源,从而使开销减小、速度更快。而后续的进程便是轻量级进程----线程


举例说明:四个人去餐厅吃饭,如果四个人在四张桌子上吃饭每张桌子3个菜,开销为:四个桌子、12个盘子。时间:炒12个菜以及洗12个碗的速度。但是如果四个人在同一张桌子吃饭,并且把菜合在一起,那么开销为:1个桌子、3个盘子。时间:炒3个菜以及洗3个碗的速度。


1.2线程的概念

       线程(thread)是操作系统能够进行运算调度的最小单位。线程被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一一个进程中可以并发多个线程,每条线程并行执行不同的任务。在Unix System V及SunOS中也被称为 轻量进程(lightweight processes),但轻量进程更多指内核线程(kernel thread),而把用户线程称为线程

特点:

  1. 线程与资源分配无关,它属于某一个进程,并与进程内的其他线程一起共享进程的资源。
  2. 线程只由相关堆栈(系统栈或用户栈)寄存器和线程控制表TCB组成。寄存器可被用来存储线程内的局部变量,但不能存储其他线程的相关变量。
  1. 通常在一个进程中可以包含若干个线程,它们可以利用进程所拥有的资源。

额外补充:在windows里不是PCB而是TCB,但是linux中依然采用的是PCB。

在linux中:一个PCB对应一个线程,而进程有多个线程(不是无上限的线程),因此多个PCB对应一个进程。

1.3线程和进程的区别

简单回忆一下进程的特点:

  1. 进程是资源分配的基本单。所有与该进程有关的资源,都被记录在进程控制块PCB中。以表示该进程拥有这些资源或正在使用它们。
  2. 进程也是抢占处理机的调度单位,它拥有一个完整的虚拟地址空间。当进程发生调度时,不同的进程拥有不同的虚拟地址空间,而同一进程内的不同线程共享同一地址空间。

因此线程和进程的主要区别有:

  1. 地址空间和其它资源(如打开文件):进程间相互独立,同一进程的各线程间共享。某进程内的线程在其它进程不可见。
  2. 通信:进程间通信IPC,线程间可以直接读写进程数据段(如全局变量)来进行通信——需要进程同步和互斥手段的辅助,以保证数据的一致性。
  3. 调度和切换:线程上下文切换比进程上下文切换要快得多。
  1. 在多线程OS中,线程不是一个可执行的实体。

结:进程是操作系统进行资源分配的基本单位线程是操作系统进行调度的基本单位。

二.线程的生命周期

       线程的生命周期分为了5个阶段,创建—>就绪—>运行—>死亡,运行的中途可能会有阻塞。

  1. 新建阶段:创建一个线程的对象,此时线程处于新建状态。
  2. 就绪阶段:线程对象调用start方法后,线程进入线程队列等待CPU时间片,具备了运行的条件。
  3. 运行阶段:当就绪的线程被调度且获得CPU资源时,进入运行状态,系统自动决定CPU分配,并执行获得CPU执行权的线程。
  4. 阻塞状态:在某些特殊情况下,如被挂起或执行输入输出操作时
  5. 死亡阶段:线程完成了全部工作、被提前强制终止或出现异常导致线程结束,线程执行结束,它的寄存器上下文以及堆栈内容等将被释放。

注: 以上的各种情况,是可以通过Java来实现的,各种阶段都有其对应的方法执行。


       一般情况下,父线程与子线程相互不影响,即子线程结束,父线程不一定结束;父线程结束,子线程不一定结束;父线程异常,子线程不一定异常;子线程异常,父线程不一定异常。但当设置守护线程等特殊操作时,父线程与子线程会发生相互影响。

三.认识多线程

       我们主要学习的是多线程,多线程是指从软件或者硬件上实现多个线程并发执行的技术。具有多线程能力的计算机因有硬件支持而能够在同一时间执行多于一个线程,进而提升整体处理性能。在一个程序中,这些独立运行的程序片段叫作“线程”,利用它编程的概念就叫作“多线程处理”。可以通过Java实现。

1.多线程的特点

  1. 每一个线程都是独立执行流
  2. 多个线程之间都是并发执行

2.Java创建多线程的方式:

  1. 继承Thread类
  1. 实现Runnable接口
  2. 使用lambda
  3. 使用线程池
  4. 使用Callable

注:方法1,2,5可以搭配匿名内部类实现

3.Java当中观察线程 方法

jdk文件夹--->bin文件夹--->jconsole调试工具

如果打不开,可以选择管理员打开


      在多线程当中,我们还会学到锁这个概念,因为有锁,所以才会有更多的操作空间,保证数据的准确性以及线程的等待执行。

总结

       线程学习是为了更好的理解多线程的操作,多线程中知识点很多,而其根本就是线程的生命周期,且加锁操作更为重要,保证数据的原子性,而加锁又会产生更多不明确的情况,因此需要耐心学习。

目录
相关文章
|
7月前
|
存储 Linux API
【Linux进程概念】—— 操作系统中的“生命体”,计算机里的“多线程”
在计算机系统的底层架构中,操作系统肩负着资源管理与任务调度的重任。当我们启动各类应用程序时,其背后复杂的运作机制便悄然展开。程序,作为静态的指令集合,如何在系统中实现动态执行?本文带你一探究竟!
【Linux进程概念】—— 操作系统中的“生命体”,计算机里的“多线程”
|
5月前
|
并行计算 Linux
Linux内核中的线程和进程实现详解
了解进程和线程如何工作,可以帮助我们更好地编写程序,充分利用多核CPU,实现并行计算,提高系统的响应速度和计算效能。记住,适当平衡进程和线程的使用,既要拥有独立空间的'兄弟',也需要在'家庭'中分享和并行的成员。对于这个世界,现在,你应该有一个全新的认识。
243 67
|
6月前
|
SQL 监控 网络协议
YashanDB进程线程体系
YashanDB进程线程体系
|
8月前
|
消息中间件 调度
如何区分进程、线程和协程?看这篇就够了!
本课程主要探讨操作系统中的进程、线程和协程的区别。进程是资源分配的基本单位,具有独立性和隔离性;线程是CPU调度的基本单位,轻量且共享资源,适合并发执行;协程更轻量,由程序自身调度,适合I/O密集型任务。通过学习这些概念,可以更好地理解和应用它们,以实现最优的性能和资源利用。
249 11
|
7月前
|
数据采集 Java 数据处理
Python实用技巧:轻松驾驭多线程与多进程,加速任务执行
在Python编程中,多线程和多进程是提升程序效率的关键工具。多线程适用于I/O密集型任务,如文件读写、网络请求;多进程则适合CPU密集型任务,如科学计算、图像处理。本文详细介绍这两种并发编程方式的基本用法及应用场景,并通过实例代码展示如何使用threading、multiprocessing模块及线程池、进程池来优化程序性能。结合实际案例,帮助读者掌握并发编程技巧,提高程序执行速度和资源利用率。
342 0
|
8月前
|
Java Linux 调度
硬核揭秘:线程与进程的底层原理,面试高分必备!
嘿,大家好!我是小米,29岁的技术爱好者。今天来聊聊线程和进程的区别。进程是操作系统中运行的程序实例,有独立内存空间;线程是进程内的最小执行单元,共享内存。创建进程开销大但更安全,线程轻量高效但易引发数据竞争。面试时可强调:进程是资源分配单位,线程是CPU调度单位。根据不同场景选择合适的并发模型,如高并发用线程池。希望这篇文章能帮你更好地理解并回答面试中的相关问题,祝你早日拿下心仪的offer!
177 6
|
9月前
|
算法 调度 开发者
深入理解操作系统:进程与线程的管理
在数字世界的复杂编织中,操作系统如同一位精明的指挥家,协调着每一个音符的奏响。本篇文章将带领读者穿越操作系统的幕后,探索进程与线程管理的奥秘。从进程的诞生到线程的舞蹈,我们将一起见证这场微观世界的华丽变奏。通过深入浅出的解释和生动的比喻,本文旨在揭示操作系统如何高效地处理多任务,确保系统的稳定性和效率。让我们一起跟随代码的步伐,走进操作系统的内心世界。
129 2
|
2月前
|
安全 算法 Java
Java 多线程:线程安全与同步控制的深度解析
本文介绍了 Java 多线程开发的关键技术,涵盖线程的创建与启动、线程安全问题及其解决方案,包括 synchronized 关键字、原子类和线程间通信机制。通过示例代码讲解了多线程编程中的常见问题与优化方法,帮助开发者提升程序性能与稳定性。
137 0
|
2月前
|
数据采集 监控 调度
干货分享“用 多线程 爬取数据”:单线程 + 协程的效率反超 3 倍,这才是 Python 异步的正确打开方式
在 Python 爬虫中,多线程因 GIL 和切换开销效率低下,而协程通过用户态调度实现高并发,大幅提升爬取效率。本文详解协程原理、实战对比多线程性能,并提供最佳实践,助你掌握异步爬虫核心技术。
|
3月前
|
Java 数据挖掘 调度
Java 多线程创建零基础入门新手指南:从零开始全面学习多线程创建方法
本文从零基础角度出发,深入浅出地讲解Java多线程的创建方式。内容涵盖继承`Thread`类、实现`Runnable`接口、使用`Callable`和`Future`接口以及线程池的创建与管理等核心知识点。通过代码示例与应用场景分析,帮助读者理解每种方式的特点及适用场景,理论结合实践,轻松掌握Java多线程编程 essentials。
233 5