博客
关于我
3分钟搞清楚进程与线程的区别
阅读量:366 次
发布时间:2019-03-05

本文共 955 字,大约阅读时间需要 3 分钟。

工厂车间与进程的类比

进程(process)和线程(thread)是操作系统的基础概念,但它们的抽象性让很多人感到难以理解。为了让这些概念更直观,我尝试用一个工厂车间的场景来进行类比。

CPU是工厂的核心,始终在运行。它就像工厂的生产线,24小时不停地加工各种产品。就像生产线一样,CPU一次只能处理一个任务,也就是一个进程。就像车间的生产线一样,其他车间的生产活动必须暂停,直到当前车间完成生产任务。

进程就像工厂的车间。每个车间都有自己的生产任务,且在任何时候都只有一间车间在运行。CPU就像车间的负责人,负责监督整个生产流程。就像车间的生产任务一样,进程也需要独占CPU的资源。

线程与进程的关系就像车间里的工人。一个车间可以有多个工人协同工作,但每个工人都属于同一个车间。同样,一个进程可以包含多个线程。这些线程就像工厂车间里的工人,他们可以同时执行不同的任务,但每个任务都属于同一个车间。

内存的共享就像车间的办公桌。每个车间都有自己的办公桌,所有工人都可以使用这些共享资源。就像内存一样,进程的内存空间是共享的,所有线程都可以访问这些共享内存。

为了防止多个线程同时访问同一块内存,车间可以设置一些限制。最简单的方法是设置门卫,先进入的人拿取钥匙,等待的人就在门口排队。这种机制就像互斥锁(Mutex),它确保了同一块内存只能被一个线程访问。

有些车间的空间有限,只能容纳固定数量的人。比如说厨房,它可以容纳5个人,超过5个人的人就需要在外面等待。这就像某些内存区域只能供给固定数量的线程使用。为了避免资源冲突,这些车间可以设置门卫,挂上特定的钥匙,确保只有预定数量的人能够进入。

为了更好地管理这些车间,工厂可以设置钥匙架。每个车间都有自己的钥匙,进去时取钥匙,出来时还要归位。这种机制就像信号量(Semaphore),它确保了多个线程不会互相冲突。信号量是一种更灵活的资源管理机制,它可以支持不同的车间容量需求。

总体来说,操作系统的设计可以归结为以下几点:

  • 允许多进程形式,多个任务可以同时运行
  • 允许多线程形式,一个任务可以分成多个部分同时运行
  • 提供协调机制,防止进程和线程之间的冲突,同时允许资源共享
  • 希望这些类比能够帮助大家更好地理解进程和线程的概念。如果对某些内容有疑问,欢迎随时交流!

    转载地址:http://dlvg.baihongyu.com/

    你可能感兴趣的文章
    mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
    查看>>
    Mysql8 数据库安装及主从配置 | Spring Cloud 2
    查看>>
    mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
    查看>>
    MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
    查看>>
    MYSQL8.0以上忘记root密码
    查看>>
    Mysql8.0以上重置初始密码的方法
    查看>>
    mysql8.0新特性-自增变量的持久化
    查看>>
    Mysql8.0注意url变更写法
    查看>>
    Mysql8.0的特性
    查看>>
    MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
    查看>>
    MySQL8修改密码的方法
    查看>>
    Mysql8在Centos上安装后忘记root密码如何重新设置
    查看>>
    Mysql8在Windows上离线安装时忘记root密码
    查看>>
    MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
    查看>>
    mysql8的安装与卸载
    查看>>
    MySQL8,体验不一样的安装方式!
    查看>>
    MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
    查看>>
    Mysql: 对换(替换)两条记录的同一个字段值
    查看>>
    mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
    查看>>
    MYSQL:基础——3N范式的表结构设计
    查看>>