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

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

前言

       在学习线程之前,必须了解什么是进程,线程借助进程的资源而实现的,也可以说是进程的子任务,是为了改进进程而出现的。进程的学习: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调试工具

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


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

总结

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

目录
相关文章
|
12天前
|
Go 调度 开发者
[go 面试] 深入理解进程、线程和协程的概念及区别
[go 面试] 深入理解进程、线程和协程的概念及区别
|
5天前
|
算法 Java
JUC(1)线程和进程、并发和并行、线程的状态、lock锁、生产者和消费者问题
该博客文章综合介绍了Java并发编程的基础知识,包括线程与进程的区别、并发与并行的概念、线程的生命周期状态、`sleep`与`wait`方法的差异、`Lock`接口及其实现类与`synchronized`关键字的对比,以及生产者和消费者问题的解决方案和使用`Condition`对象替代`synchronized`关键字的方法。
JUC(1)线程和进程、并发和并行、线程的状态、lock锁、生产者和消费者问题
|
20天前
|
消息中间件 程序员 调度
如何区分进程、线程和协程?看这篇就够了!
以下是内容摘要,已简化并保持在240字符以内: 嗨,我是小米!今天聊聊进程、线程和协程: - **进程**:资源分配基本单位,独立且隔离。 - **线程**:进程内执行单元,轻量级且共享资源。 - **协程**:比线程更轻量,适合I/O密集型任务。 每种都有独特特点和适用场景,选择合适可优化性能。希望对你有所帮助!更多内容,请关注我的公众号“软件求生”。
30 1
|
26天前
|
存储 缓存 NoSQL
Redis性能优化问题之优化 Redis fork 耗时严重的问题,如何解决
Redis性能优化问题之优化 Redis fork 耗时严重的问题,如何解决
|
16天前
|
数据采集 并行计算 程序员
Python中的并发编程:理解多线程与多进程
在Python编程中,理解并发编程是提升程序性能和效率的关键。本文将深入探讨Python中的多线程和多进程编程模型,比较它们的优劣势,并提供实际应用中的最佳实践与案例分析。
|
21天前
|
消息中间件 算法 Java
(十四)深入并发之线程、进程、纤程、协程、管程与死锁、活锁、锁饥饿详解
本文深入探讨了并发编程的关键概念和技术挑战。首先介绍了进程、线程、纤程、协程、管程等概念,强调了这些概念是如何随多核时代的到来而演变的,以满足高性能计算的需求。随后,文章详细解释了死锁、活锁与锁饥饿等问题,通过生动的例子帮助理解这些现象,并提供了预防和解决这些问题的方法。最后,通过一个具体的死锁示例代码展示了如何在实践中遇到并发问题,并提供了几种常用的工具和技术来诊断和解决这些问题。本文旨在为并发编程的实践者提供一个全面的理解框架,帮助他们在开发过程中更好地处理并发问题。
|
2天前
|
Java
多线程线程同步
多线程的锁有几种方式
|
9天前
|
调度 Python
|
11天前
|
安全 算法 Java
17 Java多线程(线程创建+线程状态+线程安全+死锁+线程池+Lock接口+线程安全集合)(下)
17 Java多线程(线程创建+线程状态+线程安全+死锁+线程池+Lock接口+线程安全集合)
51 6
|
11天前
|
存储 安全 Java
17 Java多线程(线程创建+线程状态+线程安全+死锁+线程池+Lock接口+线程安全集合)(中)
17 Java多线程(线程创建+线程状态+线程安全+死锁+线程池+Lock接口+线程安全集合)
53 5

相关实验场景

更多