线程

作者: 温情小武 | 来源:发表于2016-12-26 12:39 被阅读0次

进程的概念

  • 进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。
  • 在早期面向进程设计的计算机结构中,进程是程序的基本执行实体;在当代面向线程设计的计算机结构中,进程是线程的容器。程序是指令、数据及其组织形式的描述,进程是程序的实体。

引用百度百科 进程


线程的概念

  • 线程:thread
  • 一个进程想要执行任务,必须要有线程(每个进程至少需要有一条线程)。
  • 一个进程中的所有任务均是在线程中执行的。

线程的串行

  • 一个线程中的任务是串行的。
  • 同一时间下,同一线程只能执行一个任务。

task 1 > task 2 > task 3
因此,可以认为线程是进程中的一条执行路径

线程与进程的关系

  • 线程是CPU调用执行任务的最小的单位。
  • 线程是CPU分配资源和调度的单位。
  • 一个程序可以对应多个进程,每个进程中有可以对应有多个线程,但每个进程至少要有一条线程。
  • 同一个进程中的线程共享进程的资源。
进程如同工厂 线程如同工人

多线程概念

  • 一个进程中可以开启多条线程,每条线程可以并行(同时)执行不同的任务。
  • 多线程技术可以大大提高程序的运行效率。

线程1 > task 1
线程2 > task 2
线程3 > task 3

多线程的原理

  • 实际上在同一时间,CPU只能处理一条线程,只有一条线程在工作(执行)。
  • 多线程的并发同时执行,其实是CPU快速地在多个线程之间来回调度。因此,如果CPU调度的速度足够快,就形成了多个线程并发执行的假象。
多线程原理示意图

如图所示,CPU不停在线程间切换调度,其中序号并不能代表CPU调度的顺序,仅作示意。

多线程的优点

  • 能够适当提高程序的执行效率
  • 能够适当提高资源的利用率(CPU和内存)

多线程的缺点

  • 线程的创建是有开销的,需要消耗资源
  • 开启大量的线程会降低程序的性能
  • 线程越多,CPU在线程之间的调度花费的时间会更长
  • 程序的设计相对会更加复杂:涉及到线程之间的通讯和线程间的数据共享

相关文章

  • Android

    线程间通信 主线程和工作线程主线程和工作线程 工作线程与工作线程工作线程与工作线程 为什么主线程Looper.lo...

  • 三、操作系统之线程

    前言 什么是线程 引入线程的原因 线程的概念 线程和进程的关系 线程结构 线程有点 多线程模型 用户线程和内核线程...

  • Thread

    队列 线程锁 多线程,线程池 队列 多线程爬虫示例 多线程 自定义线程 线程池

  • 总结多线程与设计模式+synchronized+性能+高吞吐+死

    Java线程 Java语言的线程 何谓线程 线程启动 线程的暂时停止 线程的共享互斥 线程的协调 线程的状态转移 ...

  • 多线程编程

    摘要 线程概念,线程与进程的区别与联系学会线程控制,线程创建,线程终止,线程等待了解线程分离与线程安全学会线程同步...

  • java线程池

    线程VS线程池 普通线程使用 创建线程池 执行任务 执行完毕,释放线程对象 线程池 创建线程池 拿线程池线程去执行...

  • java并发之守护线程

    java中有两种线程,用户线程和守护线程用户线程:主线程停止时,用户线程不会停止守护线程:主线程停止时,守护线程也...

  • Java线程池的使用

    线程类型: 固定线程 cached线程 定时线程 固定线程池使用 cache线程池使用 定时调度线程池使用

  • 线程基础知识

    线程学习 线程的基础知识 线程是什么? 线程和进程的关系 线程的6个状态 线程优先级 主线程、多线程、后台线程的概...

  • 多线程介绍

    一、进程与线程 进程介绍 线程介绍 线程的串行 二、多线程 多线程介绍 多线程原理 多线程的优缺点 多线程优点: ...

网友评论

      本文标题:线程

      本文链接:https://www.haomeiwen.com/subject/yjqkvttx.html