[linux]--关于进程概念(下)

news2024/9/22 1:43:48

目录

孤儿进程

环境变量

将程序放到PATH路径下

设置PATH环境变量

设置别名

环境变量相关的命令

 环境变量的组织方式​编辑

通过系统调用获取环境变量

环境变量通常是具有全局属性的

进程优先级

查看系统进程

用top命令更改已存在进程的nice:

程序地址空间


我们上一篇讲了僵尸进程,知道如果子进程退出没有给到父进程返回码,子进程就会被系统维护,一直处于僵尸状态Z,那么,如果是我们的父进程提前退出了而不是休眠,子进程再退出,陷入Z状态,有没有处理方案呢?

孤儿进程

父进程如果提前退出,那么子进程后退出,进入Z之后,那该如何处理呢?

父进程先退出,子进程就称之为“孤儿进程”

孤儿进程被1号init进程领养,当然要有init进程回收喽。

#include <stdio.h>
 #include <unistd.h>
 #include <stdlib.h>
 
int main()
 {
    pid_t id = fork();
    if(id < 0){
        perror("fork");
        return 1;
    }
    else if(id == 0){//child
        printf("I am child, pid : %d\n", getpid());
        sleep(10);
    }else{//parent
        printf("I am parent, pid: %d\n", getpid());
        sleep(3);
        exit(0);
    }
    return 0;
 }

 

这段命令是一个简单的 Bash 脚本,让我来逐步解释一下:

  1. while :; do ... done:这是一个无限循环结构,其中 : 表示一个永远返回 true 的条件,因此这个循环会无限执行。

  2. ps axj | grep mytest | grep -v grep:这部分命令的作用是通过 ps 命令查看当前系统中所有进程的状态,并使用 grep 命令过滤出包含 "mytest" 字符串的进程。第二个 grep -v grep 的作用是去除含有 "grep" 字符串的行,避免误判。

  3. sleep 1:这是让脚本暂停 1 秒,然后再继续执行下一次循环。

  4. echo "##########":输出一行 ##########,用来做分隔符或者标记输出结果。

作用是不断地检查系统中是否存在名为 "mytest" 的进程,每隔 1 秒输出一次检查结果,并用分隔符标记不同的输出

 也就是说,当我们的父进程先退出了,操作系统会把子进程接管过来,避免产生内存泄漏。

跟上一篇讲的僵尸进程的原理是差不多的,只是父进程的状态差异。

环境变量

概念

环境变量(environment variables)一般是指在操作系统中用来指定操作系统运行环境的一些参数 如:我们在编写C/C++代码的时候,在链接的时候,从来不知道我们的所链接的动态静态库在哪里,但 是照样可以链接成功,生成可执行程序,原因就是有相关环境变量帮助编译器进行查找。 环境变量通常具有某些特殊用途,还有在系统当中通常具有全局特性

 怎么理解呢,我们linux下通常来讲就是一堆堆的文件,指令还有函数这些,都是一个个的文件,我们yum install从远程服务端口下载的指令,比如tree,也是被放在了系统下的一个路径里面

我给大家看一下,比如ls

一般来说系统级的指令都在/usr/bin路径下,大家可以自己看一下

所以说,我们的指令其实是一个个的文件,包括我们的下载的指令,那么,这跟环境变量有什么关系呢,环境变量,就是在我们的linux下,查找我们的指令以及文件所在的路径,然后给到操作系统去运行

常见环境变量

PATH : 指定命令的搜索路径

HOME : 指定用户的主工作目录(即用户登陆到Linux系统中时,默认的目录)

SHELL : 当前Shell,它的值通常是/bin/bash。

查看环境变量方法     echo $NAME    //NAME:你的环境变量名称

 我们先写个简单的代码看看path的作用

#include <stdio.h>

int main()

{

printf("hello world!\n");

return 0;

}

我们看看./hello 执行和直接  hello执行的区别

 

这里的报错是因为path没有找到我们文件的路径,在我们平时运行的时候,我们都是./加文件名运行的,而ls,touch这些指令则是可以直接运行

这是因为我们的path是系统的环境变量,而这些指令保存在我们的path环境变量下,path通过路径寻找到我们对应的指令,然后执行这个指令文件的功能,按照这个说法,我们的文件也是可以直接运行的,只要我们能够加载到path指定的路径下。

 大家有兴趣自己试一下,我装了半天,电脑有点小问题

将我们的程序所在路径加入环境变量PATH当中, export PATH=$PATH:hello程序所在路径

 echo $PATH查看我们的路径是否包含在下面

 对比./hello执行和之间hello执行

为什么有些指令可以直接执行,不需要带路径,而我们的二进制程序需要带路径才能执行? 将我们的程序所在路径加入环境变量PATH当中, export PATH=$PATH:hello程序所在路径

还有什么方法可以不用带路径,直接就可以运行呢?

将程序放到PATH路径下

第一种方法就是将我们自己的程序放到PATH中的路径中去,这样在shell输入hello时,也能找到,例如我们将其放在/bin目录下:

$ hello
hello world
$ whereis hello
hello: /bin/hello

也就是说,如果你的程序安装在了PATH指定的路径,就需要配置PATH环境变量,在命令行输入就可以直接找到了。

设置PATH环境变量

那么如果想在指定的目录能够直接运行呢?很简单,那就是添加环境变量,例如将当前路径加入到PATH中:

$ PATH=$PATH:./   #这种方式只在当前shell有效,所有shell生效可修改/etc/profile文件
$ hello
hello world
设置别名

例如:

$ alias hello="/temp/hello"
$ hello
hello world

以上三种方法都可以达到目的。

测试HOME

1. 用root和普通用户,分别执行 echo $HOME ,对比差异

2.执行 cd ~; pwd ,对应 ~ 和 HOME的关系 

 我们可以看到,两个其实是差不多的,取决于你在哪个用户环境下使用而已。

环境变量相关的命令

1.echo: 显示某个环境变量值
2. export: 设置一个新的环境变量
3. env: 显示所有环境变量
4. unset: 清除环境变量
5. set: 显示本地定义的shell变量和环境变量

 环境变量的组织方式

每个程序都会收到一张环境表,环境表是一个字符指针数组,每个指针指向一个以’\0’结尾的环境字符串 

通过代码如何获取环境变量

命令行第三个参数(就是环境参数)

#include <stdio.h>
 int main(int argc, char *argv[], char *env[])
 {
    int i = 0;
    for(; env[i]; i++){
        printf("%s\n", env[i]);
    }
    return 0;
 }

通过第三方变量environ获取,指向我们的环境表,相当于二级指针

#include <stdio.h>
 
int main(int argc, char *argv[])
 {
    extern char **environ;
    int i = 0;
    for(; environ[i]; i++){
        printf("%s\n", environ[i]);
    }
    return 0;
 }

 libc中定义的全局变量environ指向环境变量表,environ没有包含在任何头文件中,所以在使用时 要用extern声明。

通过系统调用获取环境变量

#include <stdio.h>
 #include <stdlib.h>
 
int main()
 {
    printf("%s\n", getenv("PATH"));
    return 0;
 }

常用getenv和putenv函数来访问特定的环境变量。

环境变量通常是具有全局属性的

环境变量通常具有全局属性,可以被子进程继承下去

#include <stdio.h>
 #include <stdlib.h>
 
int main()
 {
    char * env = getenv("MYENV");
    if(env){
        printf("%s\n", env);
    }
    return 0;
 }

这个时候我们直接查看,发现没有结果,说明该环境变量根本不存在

导出环境变量
export MYENV="hello world"
再次运行程序,发现结果有了!说明:环境变量是可以被子进程继承下去的!

如果只进行MYENV=“helloworld” ,不调用export导出,在用我们的程序查看,会有什么结果?为什 么? 

如果只是直接设置环境变量 MYENV="helloworld" 而没有使用 export 命令导出该环境变量,然后再运行程序查看环境变量的取值,结果可能会是程序无法获取到正确的环境变量值。这是因为在不使用 export 命令导出环境变量时,该环境变量只在当前 shell 进程中有效,而不会被传递给程序的执行环境。

具体来说,当你直接设置环境变量 MYENV="helloworld" 时,该环境变量只会存在于当前 shell 进程中,而不会被传递给程序的执行环境。因此,当你运行程序时,程序尝试通过 getenv("MYENV") 函数获取环境变量的值时,由于该环境变量并未在程序的执行环境中被正确设置,程序将无法获得正确的环境变量值,结果可能是空值或者 null。

为了让程序能够正确获取环境变量的值,需要使用 export 命令将环境变量导出,使其成为子进程可见的环境变量。只有通过 export 命令导出的环境变量才能被程序正确识别和获取。

进程优先级

概念

cpu资源分配的先后顺序,就是指进程的优先权(priority)。

优先权高的进程有优先执行权利。

配置进程优先权对多任务环境的linux很有用,可以改善系统性能。

还可以把进程运行到指定的CPU上,这样一来,把不重要的进程安排到某个CPU,可以大大改善系统整 体性能。

一般来说,我们现在的电脑环境下,所启动进行的进程优先级都是一样的,所以这个部分主要是理解为主。

查看系统进程

在linux或者unix系统中,用ps –l命令则会类似输出以下几个内容:

这几个信息跟我们的进程优先级可以说有直接的关系

UID : 代表执行者的身份

PID : 代表这个进程的代号

PPID :代表这个进程是由哪个进程发展衍生而来的,亦即父进程的代号

PRI :代表这个进程可被执行的优先级,其值越小越早被执行

NI :代表这个进程的nice值

PRI and  NI

PRI也还是比较好理解的,即进程的优先级,或者通俗点说就是程序被CPU执行的先后顺序,此值越小 进程的优先级别越高 那NI呢?就是我们所要说的nice值了,其表示进程可被执行的优先级的修正数值 PRI值越小越快被执行,那么加入nice值后,将会使得PRI变为:PRI(new)=PRI(old)+nice 这样,当nice值为负值的时候,那么该程序将会优先级值将变小,即其优先级会变高,则其越快被执行 所以,调整进程优先级,在Linux下,就是调整进程nice值 nice其取值范围是-20至19,一共40个级别。 

需要强调一点的是,进程的nice值不是进程的优先级,他们不是一个概念,但是进程nice值会影响到进 程的优先级变化。 可以理解nice值是进程优先级的修正修正数据

用top命令更改已存在进程的nice:

top          进入top后按“r”–>输入进程PID–>输入nice值 

比如说我要修改22进程的nice值,就是top进入我们的这歌页面,然后r一下,就会有命令窗口,输入22,然后回车,这个时候呢我写入一个60吧,方便我们学习

 我们的nice最大是19,我们原来是-20,所以60-40=20,那么pri是不是20+19=39呢?

并不是,pri每个人的峰值可能不太一样,我的是39最大,pri=之前的pri加nice值,之前的pri是0,加nice值应该是19啊!为什么呢,因为这里有一个bug,pri更改默认是20,所以我们才会看到39这个数值

我现在把60减掉再用40给大家演示一下,一样是39的pri

 

我们使用的时候注意一下就好了,一般也不会更改优先级

相关知识点

竞争性: 系统进程数目众多,而CPU资源只有少量,甚至1个,所以进程之间是具有竞争属性的。为了高 效完成任务,更合理竞争相关资源,便具有了优先级

独立性: 多进程运行,需要独享各种资源,多进程运行期间互不干扰

并行: 多个进程在多个CPU下分别,同时进行运行,这称之为并行

并发: 多个进程在一个CPU下采用进程切换的方式,在一段时间之内,让多个进程都得以推进,称之为 并发

程序地址空间

我们看一下c语言下的地址空间布局

可能我们对他并不理解!

#include <stdio.h>
 #include <unistd.h>
 #include <stdlib.h>
 
int g_val = 0;
 
int main()
 {
    pid_t id = fork();
    if(id < 0){
        perror("fork");
        return 0;
    }
    else if(id == 0){ //child
  printf("child[%d]: %d : %p\n", getpid(), g_val, &g_val);
    }else{ //parent
        printf("parent[%d]: %d : %p\n", getpid(), g_val, &g_val);
    }
    sleep(1);
    return 0;
 }

我们试一下从代码的角度去理解

有没有发现,地址是一样的啊

输出出来的变量值和地址是一模一样的,很好理解呀,因为子进程按照父进程为模版,父子并没有对变 量进行进行任何修改。

我们继续看,小改一下

我们发现,父子进程,输出地址是一致的,但是变量内容不一样!能得出如下结论:

变量内容不一样,所以父子进程输出的变量绝对不是同一个变量

但地址值是一样的,说明,该地址绝对不是物理地址!

在Linux地址下,这种地址叫做 虚拟地址

我们在用C/C++语言所看到的地址,全部都是虚拟地址!

物理地址,用户一概看不到,由OS统一管理

OS必须负责将 虚拟地址 转化成 物理地址 。

所以之前说‘程序的地址空间’是不准确的,准确的应该说成 进程地址空间

同一个变量,地址相同,其实是虚拟地址相同,内容不同其实是被映射到了 不同的物理地址!

 


写的不太好,表达能力确实不行,我会尽量除了我能看明白再写清楚的,阿里嘎都~

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

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

相关文章

mac下Appuim环境安装-持续更新中

参考资料 Mac安装Appium_mac电脑安装appium-CSDN博客 安卓测试工具&#xff1a;Appium 环境安装&#xff08;mac版本&#xff09;_安卓自动化测试mac环境搭建-CSDN博客 1. 基本环境依赖 1 node.js 2 JDK&#xff08;Java JDK&#xff09; 3 Android SDK 4 Appium&#x…

数据库系统概论-第14章 大数据管理

14.1 大数据概述 14.2 大数据的应用 14.3 大数据管理系统 14.4 小结

3D轻量引擎HOOPS SDK:EDA应用程序高效开发利器

电子设计自动化&#xff08;EDA&#xff09;软件在现代工程实践中扮演着至关重要的角色。随着技术的不断进步和市场的竞争加剧&#xff0c;开发高效、可靠的EDA应用程序成为了行业内的一项迫切需求。在这一背景下&#xff0c;Tech Soft 3D的HOOPS SDK&#xff08;Software Deve…

灵境矩阵平台x百度---智能体(一)

什么是数据插件 大模型插件:大语言模型插件是随着大语言模型发展而诞生的全新插件。大语言模型插件的核心是Web API独立于大语言模型&#xff0c;插件开发过程不受大语言模型的约束&#xff0c;同时没有开发语言的限制&#xff0c;更加通用&#xff0c;只要WebAPI遵循RESTfuI相…

步进电机驱动器的接线与使用(接线详细)

今天小编就来继续学习与使用步行电机的学习&#xff0c;如果位置对你有帮助&#xff0c;评论收藏&#xff0c;点赞一下 步进电机驱动器 步进电机驱动器是一种专用于控制步进电机的电子设备&#xff0c;用于控制步进电机的转动和位置。步进电机是一种将电信号转换为机械运动的电…

R包安装失败怎么办?(一)msigdbr

R包安装失败 如果是网络原因&#xff08;error connection&#xff09;&#xff0c;就使用本地安装的方法。如果是网络原因&#xff0c;通常会出现安装超时&#xff0c;或者网络无法连接的提示 当你把timeout 设置到1000之后还会报错&#xff0c;怎么办&#xff1f; options…

【jvm】jinfo使用

jinfo介绍 jinfo 是一个命令行工具&#xff0c;用于查看和修改 Java 虚拟机&#xff08;JVM&#xff09;的配置参数。它通常用于调试和性能调优。 使用 jinfo 命令&#xff0c;你可以查看当前 JVM 的配置参数&#xff0c;包括堆大小、线程数、垃圾回收器类型等。此外&#xf…

基于单片机的四旋翼飞行器的设计与实现

摘 要:四旋翼飞行器可以垂直升降,应用于军事和民用领域,在飞行器的设计中,结合单片机进行设计,可以提升整体性能。基于此,本文探究基于单片机的四旋翼飞行器设计与实现,探索飞行器的硬件设计和软件设计方案,并且对系统的角速度算法以及姿态控制算法进行测试,最后对系…

六大排序精解

排序概念 排序&#xff1a;所谓排序&#xff0c;就是使一串记录&#xff0c;按照其中的某个或某些关键字的大小&#xff0c;递增或递减的排列起来的操作。稳定性&#xff1a;假定在待排序的记录序列中&#xff0c;存在多个具有相同的关键字的记录&#xff0c;若经过排序&#x…

Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单实战案例 之四 简单复古怀旧照片效果

Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单实战案例 之四 简单复古怀旧照片效果 目录 Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单实战案例 之四 简单复古怀旧照片效果 一、简单介绍 二、简单复古怀旧照片效果实现原理 三、简单复古怀旧照片效果案例实现…

开源Thinkphp核心在线网页音乐播放php源码,附带系统搭建教程

安装教程 环境要求&#xff1a;apachePHP7.0Thinkphp伪静态 安装教程&#xff1a;修改Application目录下的database.php信息 导入根目录下的install.sql到数据库 修改Static目录下的player目录下的player.js文件的第140行的“域名”为你的域名 修改Static目录下的player2目录下…

Godot 学习笔记(4):一切以场景为中心

文章目录 前言场景搭建新建子场景最简单的按钮事件 手动控制场景手动加载场景添加多个场景对象更快速的获取脚本对象 删除多个场景对象脚本命名的问题 总结 前言 Godot的场景是C#与Godot最后的中间连接。我们解决了场景的加载&#xff0c;我们基本可以保证C#和godot之间的彻底…

ModbusRTU/TCP/profinet网关在西门子博图软件中无法连接PLC的解决方法

ModbusRTU/TCP/profinet网关在西门子博图软件中无法连接PLC的解决方法 在工业生产现场&#xff0c;ModbusRTU/TCP/profinet网关在与西门子PLC连接时&#xff0c;必须要使用西门子的博图软件来进行配置&#xff0c;博图v17是一个集成软件平台&#xff0c;专业版支持300、400、12…

【碳资产管理/精细化能源管控】Acrel-7000企业能源管控平台

工厂企业用能需求 能源管理 安科瑞薛瑶瑶18701709087 生产全过程用能数据监测和分析&#xff1b;完善并落实能源管理制度&#xff0c;使之更有效的运行&#xff1b;量化能效考核kpi&#xff0c;用数据说明问题。 用能安全 完善用能安全监测&#xff0c;保障人身与电气设备…

【计算机】——51单片机

单片机是一种内部包含CPU、存储器和输入/输出接口等电路的集成电路&#xff08;IC芯片&#xff09; 单片机是单片微型计算机&#xff08;Single Chip Microcomputer&#xff09;的简称&#xff0c;用于控制领域&#xff0c;所以又称为微型控制器&#xff08;Microcontroller U…

ubuntu20.04搭建nginx rtmp视频服务到指定位置解决权限不足

1.安装依赖 apt-get install build-essential libpcre3 libpcre3-dev libssl-dev2.建一个目录 mldir rtmp_nginx 3.源码下载 wget http://nginx.org/download/nginx-1.21.6.tar.gz wget https://github.com/arut/nginx-rtmp-module/archive/master.zip4.解压缩 tar -xf ng…

RabbitMQ--04--Spring Cloud Stream(消息驱动)

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 1.Spring Cloud Stream1. 基本介绍https://spring.io/projects/spring-cloud-stream#overview 2.Spring Cloud Stream 解决的痛点问题3.设计思想Stream为什么可以统…

游戏平台出海运营有难度吗?

随着全球互联网的飞速发展&#xff0c;游戏产业已经成为了文化娱乐领域的重要支柱。在这个背景下&#xff0c;越来越多的游戏平台开始寻求出海运营&#xff0c;以拓展海外市场&#xff0c;实现更大的商业价值。然而&#xff0c;游戏平台出海运营并非易事&#xff0c;其中涉及到…

【深度学习】最强算法之:深度神经网络(DNN)

深度神经网络 1、引言2、深度神经网络2.1 定义2.2 原理2.3 实现方式2.4 算法公式2.4.1 前向传播公式2.4.2 反向传播公式 2.5 代码示例 3、总结 1、引言 小屌丝&#xff1a;鱼哥&#xff0c;我遇到难题了 小鱼&#xff1a;然后呢 小屌丝&#xff1a;你帮我看看呗&#xff1f; 小…

sentinel热点参数流控

1、概念 热点参数限流会统计传入参数中的热点参数&#xff0c;并根据配置的限流阈值与模式&#xff0c;对包含热点参数的资源调用进行限流。热点参数限流可以看做是一种特殊的流量控制&#xff0c;仅对包含热点参数的资源调用生效。 2、示例 2.1、目的 对于如下的/get接口的参…