【Linux】进程概念一

news2025/1/13 17:30:34

进程概念一

冯诺依曼体系结构

我们常见的计算机,如笔记本。我们不常见的计算机,如服务器,大部分都遵守冯诺依曼体系。

image-20230120200954706

截止目前为止, 我们所认识的计算机,都是一个个的硬件组成

  • 输入设备:包括键盘,鼠标,网卡,磁盘,话筒
  • 输出设备:显示器,磁盘,网卡,声卡,音响

输入设备,输出设备称之为外围设备,外围设备一般都比较慢一些,以磁盘为例相对于内存,磁盘是比较慢的。

这里我们可以思考一下,为什么不设计如下图所示的样子呢?

image-20230120201927641

这里我们可以想到木桶原理,外设的效率非常低,但是CPU效率很高,整体效率就是以外设为主的。

所以因为有了内存的存在,我们可以对数据进行预加载,CPU以后在进行数据计算的时候,根本不需要访问外设了,而是直接访问内存就可以了。

但是这里我们怎么知道哪些内容需要预加载进CPU当中,通过大量的测试发现,预加载的内容一般都是加载内容旁边的内容。

关于冯诺依曼体系的几点

  • 这里的存储器指的是内存
  • 不考虑缓存情况,这里的CPU能且只能对内存进行读写,不能访问外设(输入设备或输出设备)
  • 外设(输入或输出设备)要输入或者输出数据,也只能写入内存或者从内存读取
  • 所有的外围设备只能和内存打交道

理解:可执行程序是不是一个文件?是 -> 磁盘 -> 外设。必须先加载到内存中。

在硬件层面单机和跨机之间数据是如何流向的。

你和朋友,聊qq,你发送了一个在吗?整个信息如何在体系结构中流动的

image-20230120203805368

结论:

  1. 在数据层面,一般CPU不和外设直接沟通,而是直接和内存打交道
  2. 外设只会和内存打交道

操作系统

概念

任何计算机系统都包含一个基本的程序集合,称为操作系统(OS)。笼统的理解,操作系统包括:

  • 内核(进程管理,内存管理,文件管理,驱动管理)
  • 其他程序(例如函数库,shell程序等等)

设计OS的目的

  • 与硬件交互,管理所有的软硬件资源
  • 为用户程序(应用程序)提供一个良好的执行环境

操作系统为什么对软硬件资源进行管理呢?

操作系统对下通过管理好软硬件资源(手段),对上给用户提供(安全、稳定、高效、功能丰富等)执行环境(目的)

定位

在整个计算机软硬件架构中,操作系统的定位是:一款纯正的“搞管理”的软件

操作系统,一款进行软硬件资源管理的软件

如何理解“管理”

  • 管理者和被管理者是不需要直接沟通的。对管理做建模
  • 管理的本质:对被管理对象的数据做管理

管理的本质:先描述,在组织

操作系统给我们提供良好的服务,并不代表操作系统相信我们,反而操作系统不相信任何人!

我们并不能进入操作系统来随心所欲的访问数据。

系统调用接口,其实就是操作系统设计的C函数,这里的操作系统就像银行的柜台一样,我们只能去做规定的操作。

image-20230120210439293

系统调用和库函数概念

  • 在开发角度,操作系统对外会表现为一个整体,但是会暴露自己的部分接口,供上层开发使用,这部分由操作系统提供的接口,叫做系统调用
  • 系统调用在使用上,功能比较基础,对用户的要求也比较高。所以有心的开发者可以对部分系统调用进行适度封装,从而形成了库,有了库就很利于更上层的用户或者开发者进行二次开发

承上启下

那在还没有学习进程之前,操作系统是怎样进行进程管理的呢?很简单,先把进程描述起来,再把进程组织起来!

进程

基本概念

  • 课本概念:程序的一个实例,正在执行的程序等
  • 内核观点:担当分配系统资源(CPU时间,内存)的实体

什么是进程?内核关于进程的相关数据结构和当前进程的代码和数据

描述进程-PCB

  • 进程信息被放在一个叫做进程控制块的数据结构中,可以理解为进程属性的集合
  • 课本上称之为PCBLinux操作系统下的PCB是:task_struct

task_struct-PCB的一种

  • Linux当中描述进程的结构叫做task_struct
  • task_structLinux内核的一种数据结构,它会被装载到RAM(内存)里并且包含着进程的信息

task_struct内容分类

  • 标识符:描述进程的唯一标识符,用来区别其他进程
  • 状态:任务状态,退出代码,退出信号灯
  • 优先级:相对于其他进程的优先级
  • 程序计数器:程序中即将被执行的下一条指令的地址
  • 内存指针:包括程序代码和进程相关数据的指针,还有和其他进程共享的内存块的指针
  • 上下文数据:进程执行时处理器的寄存器中的数据
  • I/O状态信息:包括显示的I/O请求,分配给进程的I/O设备和被进程使用的文件列表
  • 记账信息:可能包括处理器时间总和,使用的时钟总和,时间限制,记账号等

组织进程

可以在内核源码里找到它。所有运行在系统里的进程都以task_struct链表的形式存在内核里。

查看进程

  1. 进程的信息可以通过/proc系统文件夹查看

如果需要查看pid为1的进程可以通过这种手段来查看

/proc/1

  1. 大多数信息可以通过topps这些用户工具来获取

如下代码:

image-20230123193435022

我们可以通过这个代码来查看有关这个进程的信息。

ps ajx | grep test | grep -v grep

image-20230123193723666

通过系统调用获取进程标识符

  • 进程id(PID)
  • 父进程id (PPID)

bash本质上也是一个进程

命令行启动的所有程序,最终都会变成进程,而该进程对应的父进程都是bash

如何创建子进程的呢?

  1. fork之后,执行流会变成2个执行流
  2. fork之后,谁先运行由调度器决定
  3. forkfork之后的代码共享,通常通过ifelse if来进行执行流分流

通过系统调用创建进程fork

关于fork介绍

  1. 在父进程当中fork会返回新创建子进程的id
  2. 在子进程当中fork会返回0
  3. 如果出现错误,返回一个负值
  • fork会有两个返回值
  • 父子进程共享代码,数据各自开辟空间,私有一份(采用临时拷贝)
  • fork通过用if来分流

使用例子:

#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
int main()
{
	int ret = fork();
	if (ret < 0) {
		perror("fork");
		return 1;
	}
	else if (ret == 0) { //child
		printf("I am child : %d!, ret: %d\n", getpid(), ret);
	}
	else { //father
		printf("I am father : %d!, ret: %d\n", getpid(), ret);
	}
	sleep(1);
	return 0;
}

进程在运行的时候,是具有独立性的!父子进程,运行的时候,也是一样的都是具有独立性的

进程 = 内核数据结构 + 进程的代码和数据

数据:当有一个执行流尝试修改数据的时候,操作系统会自动给我们当前进程触发写时拷贝

fork如何理解两个返回值的问题?

fork本质是操作系统提供的一个函数,当这个函数执行的时候会创建出一个执行流,此时就会有两个执行流,然后就会有两条return语句。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/176732.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何使用JDBC操作数据库?JDBC API的使用详细解读

文章目录1. DriverManager1.1 注册驱动1.2 获取连接2. Connection2.1 获取执行sql的对象2.2 事务管理3. Statement4. ResultSet5. PreparedStatement5.1 sql注入问题5.2 preparedStatement 原理6. 总结Java编程基础教程系列1. DriverManager DriverManager &#xff0c;驱动管…

C++模板不支持分离编译的问题

目录前言分离编译模式普通函数的分离编译(正常)模板函数的分离编译(出错)分析解决方式拓展--extern关键字extern"C"extern变量extern模板--控制实例化前言 分离编译模式 一个项目如果有多个源文件.c组成&#xff0c;每个源文件单独编译&#xff0c;形成目标文件。最…

Kubernetes:分享一个可以展示资源视图的 K8s开源 Web/桌面 客户端工具 Octant

写在前面 博文内容主要为 Octant 介绍以及 桌面/Web 端的安装教程涉及 Linux/Windows 的安装。理解不足小伙伴帮忙指正 其实当你什么都经历了&#xff0c;会发现&#xff0c;人生无论你怎么精心策划都抵不过一场命运的安排。 Octant 不是仪表板&#xff0c;Octant 是一个带有仪…

数据结构 最短路径课设(源码+实验报告+视频讲解)(不要钱、用了自取)

XIAN TECHNOLOGICAL UNIVERSITY 课程设计报告 实验课程名称 算法与数据结构 专 业&#xff1a; 班 级&#xff1a; 姓 名&#xff1a; 学 号&#xff1a; 实验学时&#xff1a; 指导…

Linux Debian11安装QT6开发环境

从Qt5.14开始&#xff0c;官方不提供离线安装包&#xff0c;只提供源码包和在线安装器。但是清华为我们提供了快速的在线安装方式。 一.下载清华提供的在线安装器 在线安装器下载链接 二、给在线安装器文件赋予执行权限 三、配置镜像地址运行安装器 清华源&#xff1a; ./…

7.Java判断和循环+面试相关力扣算法题详解

提示&#xff1a; 文章目录前言一、顺序结构二、分支语句(1)if语句(2)switch语句*default的位置和省略:*case穿透*switch新特性*switch和if的第三种格式各自的使用场景三、循环结构1.分类2.for循环3.while循环4.for和while的对比:5.for和while循环的区别:6.练习:四、面试时的两…

【安卓】zoo for zotero WebDAV 自动论文同步笔记

前言 前言是我写这篇博客的动机&#xff0c;可以跳过直接从“准备”开始看 之前使用mendeley管理文献&#xff0c;它不仅可以同步文件&#xff0c;还跨平台&#xff08;win、安卓等&#xff09;。但是后面&#xff0c;mendeley停止了移动平台的支持&#xff0c;导致我不能用我…

JQUERY案例

电梯导航 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" content"widthdevice-width, i…

一、pyhon准备工作篇(黑马程序猿-python学习记录)

黑马程序猿的python学习视频&#xff1a;https://www.bilibili.com/video/BV1qW4y1a7fU/ 目录 1. python官网 2. 检查是否安装完毕 3. pycharm官网 5. phcharm更换主题 6. 新建第一个python文件 7. pycharm字体大小设置 ​​​​​​​8. 设置快捷键 设置字体大小 ​​​​​​…

AJAX 简介

AJAX 是一种在无需重新加载整个网页的情况下&#xff0c;能够更新部分网页的技术。 AJAX 是什么&#xff1f; AJAX Asynchronous JavaScript and XML. AJAX 是一种用于创建快速动态网页的技术。 AJAX 通过在后台与服务器进行少量数据交换&#xff0c;使网页实现异步更新。这…

第三章 关系数据库标准语言SQL

第三章 关系数据库标准语言SQL 目录第三章 关系数据库标准语言SQL3.1 SQL概述3.1.1 产生与发展3.1.2 SQL的特点3.1.3 SQL的基本概念3.2 数据库实例3.3 数据定义3.3.1 模式的定义和删除3.2.2基本表的定义、删除和修改1.常见数据类型2.定义基本表3.修改基本表4.删除基本表5.模式和…

2. 返回传播计算方法|神经网络整体架构|神经元个数对结果的影响|正则化与激活函数|神经网络过拟合解决方法

文章目录返回传播计算方法神经网络整体架构&#xff08;暂时留存&#xff0c;等后面补&#xff09;神经元个数对结果的影响正则化与激活函数神经网络过拟合解决方法返回传播计算方法 实际上计算L&#xff08;损失值&#xff09;的时候并不是只是拿一组w来进行计算&#xff0c;…

用过MyBatis-Plus,我再也不想用mybatis了——MyBatis-Plus快速入门加常见注解总结,一文快速掌握MyBatis-Plus

相比与mybatis只做增强&#xff0c;不做修改 MyBatis-Plus学习笔记一&#xff0c;是什么二&#xff0c;入门案例1.建库建表2.创建spring Boot工程3.配置相关包及类4.测试三&#xff0c;基本的curd1.BaseMapper2.通用Service四.常用注解1.TableName2.TableId3TableField4.TableL…

【python】面向对象编程

文章目录一、函数大全1.1 匿名函数 lambda1.2 过滤函数 filter1.3 format1.4 try和except1.5 位置参数和关键字参数二、类与对象2.1创建对象2.2 封装的实现方式2.3 继承2.4方法重写2.5 object 类2.5.1 __str()__2.5.2 dict()2.5.3 len()2.5.4 add()2.5.5 new()init()2.6 多态的…

初识C语言(下)

写在前面 好了,现在我们开始C语言的第二个部分.今天我们需要看下面几个知识点,都是非常简单的,我们主要认识一下. 数组 我们知道一个一个属性可以用一个类型去表示,那么我想问的是如果是一个属性的多个呢?也就是多个一样的东西,此时我们就要使用数组来进行表示,所谓的数组就…

22. 输入和输出

1. 输出格式美化 (1) 如果你希望输出的形式更加多样&#xff0c;可以使用 str.format() 函数来格式化输出值。 (2) 如果你希望将输出的值转成字符串&#xff0c;可以使用 repr() 或 str() 函数来实现。   str()&#xff1a; 函数返回一个用户易读的表达形式。   repr()&am…

产品原型设计方法

产品原型设计方法1. 色彩选择与按钮设计1.1色彩选择1.2 按钮设计2. 使用原型设计中的基础元素2.1 使用文字元素2.2 使用图标元素3. 设计导航菜单栏和卡片式布局3.1设计导航菜单栏4.3 设计卡片式布局4. 使用UI框架4.1 使用UI框架的好处4.2 常用的UI框架1. 色彩选择与按钮设计 1…

K8s:通过 kubectl 插件 Kubepug 实现集群升级检查(废弃API资源检查)

写在前面 分享一个小工具&#xff0c;可用于 版本升级的 废弃 API 对象检查博文内容涉及&#xff1a; kubepug 离线安装&#xff0c;配置 kubectl 插件kubepug 两种方式离线使用 Demo 理解不足小伙伴帮忙指正 昔我往矣&#xff0c;杨柳依依。今我来思&#xff0c;雨雪霏霏。 —…

【HBase入门】1. HBase基础

简介 Hadoop 从 1970 年开始&#xff0c;大多数的公司数据存储和维护使用的是关系型数据库大数据技术出现后&#xff0c;很多拥有海量数据的公司开始选择像Hadoop的方式来存储海量数据Hadoop使用分布式文件系统HDFS来存储海量数据&#xff0c;并使用 MapReduce 来处理。Hadoo…

【Ajax】同源策略、跨域和JSONP

一、同源策略什么是同源如果两个页面的协议&#xff0c;域名和端口都相同&#xff0c;则两个页面具有相同的源。例如&#xff0c;下表给出了相对于 http://www.test.com/index.html 页面的同源检测&#xff08;如果没有写端口号&#xff0c;默认是80&#xff09;&#xff1a;UR…