进程

每个进程都可以通过系统调用fork来创建子进程,子进程复制父进程的数据段、堆、栈和代码段。全盘复制父进程的数据会很低效,Linux内核采用一种写时复制(Cpoy On Write)的机制来提高创建进程的效率。

子进程也可以通过系统调用exec来加载一个新程序,覆盖原先从父进程复制的数据段、代码段、堆和栈等。

进程的属性

进程描述符保存了进程相关的属性,包括优先级、状态、虚拟地址范围以及各种访问权限。进程描述符其实就是一种数据结构,在Linux系统中,每个进程都有一个唯一标识(也会保存在进程描述符中),就是进程ID,即PID,还有父进程ID,即PPID。

进程状态

image.png

进程的空间

用户进程存在于用户空间中,无法与硬件进行交互;内核进程存在于内核空间中,可以直接与硬件交互;

用户空间和内核空间都是操作系统对内存范围的划分,这里说的内存其实是虚拟内存,并不等同于物理内存。

image.png

用户进程只能通过内核提供的系统调用,来操作内核,达到和硬件交互的效果。

系统调用使用上跟普通的函数调用是一样的,但其实是两种东西,CPU在执行进程的时候,会有状态的概念-内核态和用户态,比如在执行用户进程的时候,CPU是没有权限访问内核空间的。因此,在进行系统调用的时候,还伴随着CPU状态的变换。

进程切换意味着需要做上下文的切换(其实就是CPU运行过程中寄存器状态的保存和切换),线程切换也会有这部分开销。

IPC-进程间通信

上述描述的是多进程不断的切换,获得CPU调度,相互独立的执行。
但其实大多数常见,都是需要多进程协同完成某些任务的,这就需要IPC的支持。

资源共享

多进程(或者是多线程、多协程等)访问统一资源,难免会相互干扰,这个干扰就成为竞态条件。
资源共享还引入了两个概念:

  • 原子操作:执行过程中不能被中断的操作成为原子操作。
  • 临界区:需要串行访问的资源或者代码段,成为临界区。

管道

管道是一种单向的通信方式。

信号

一种异步的通信方式,用软件来模拟硬件的中断机制,通知某个进程某个事件发生了。每个信号都是以“SIG”前缀的名字,本质上其实是正整数。
Linux支持62种信号,分为标准信号(131)和实时信号(3464)。

  • 标准信号:同一个进程,每种标准信号只会被记录和处理一次。
  • 实时信号:多个同种类的信号都可以被记录,并且按顺序被处理。

socket

实现分布式通信

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,482评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,377评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,762评论 0 342
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,273评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,289评论 5 373
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,046评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,351评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,988评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,476评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,948评论 2 324
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,064评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,712评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,261评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,264评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,486评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,511评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,802评论 2 345

推荐阅读更多精彩内容

  • 又来到了一个老生常谈的问题,应用层软件开发的程序员要不要了解和深入学习操作系统呢? 今天就这个问题开始,来谈谈操...
    tangsl阅读 4,088评论 0 23
  • 1 进程介绍 1.1 进程和程序 所谓进程是由正文段(text)、用户数据段(user segment)以及系统数...
    疯狂小王子阅读 1,225评论 0 7
  • 操作系统概论 操作系统的概念 操作系统是指控制和管理计算机的软硬件资源,并合理的组织调度计算机的工作和资源的分配,...
    野狗子嗷嗷嗷阅读 11,889评论 3 34
  • 1.进程组织结构 1. task_struct ,thread_info 和内核栈 在内核中通常current宏获...
    FlyingReganMian阅读 1,173评论 0 1
  • 一个人为什么想一个人?因为他或她曾经见到过她或他。这一见,心就开始抓取了、粘连了、贪恋了,爱染了所以就想了、念了、...
    骋祥阅读 855评论 0 1