首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux进程概念(二.查看进程进程进程进程状态详解)

1.4通过 /proc 系统文件夹看进程Linux系统中,/proc文件系统提供关于运行中进程的详细信息。你可以通过查看/proc文件系统中的特定目录和文件来获取有关进程的信息。...资源继承进程继承进程的大部分属性和资源,包括内存映像、文件描述符、信号处理器等。 进程在创建时拥有进程的副本,但在其生命周期中可以独立修改这些副本。...下面是对这两个返回值的解释: 给进程返回进程的 PID:在进程中,fork 返回新创建进程进程 ID(PID),这个 PID 是进程的标识符,进程通过这个 PID 可以识别并操作进程。...这是因为在 Unix-like 系统中,进程是通过复制进程的地址空间而创建的,因此进程从父进程继承大部分的内存布局和数据。...fork函数为什么会返回两次:fork 函数在调用后会创建一个新的进程(在return之前就已经创建好进程),新的进程拥有进程的副本。

1.1K10

探索进程进程

进程进程 这个进程PID到底是什么?...先来认识一下fork函数: fork函数会以调用该函数的进程作为进程创建一个进程 创建成功时,会在进程中返回进程的PID,在进程中返回0;如果失败,在进程中返回-1,没有进程创建。...也就是说明,这里有两个程序在同时运行,即myprocess.exe进程和myprocess.exe进程创建的进程,从而实现fork函数创建进程后,会从原来的一个执行流变成两个执行流。...一个进程可以创建多个子进程,为了区分这些进程,fork函数在创建进程后,会给进程返回进程的pid。进程只需调用getppid()函数即可找到进程。...在任何平台,进程在运行的时候都是具有独立性的。也就是说一个进程退出、失败、崩溃,都不会影响其他进程

11910
您找到你想要的搜索结果了吗?
是的
没有找到

进程退出时如何确保进程退出?

前言 进程退出的时候,进程能够收到进程退出的信号,便于管理,但是有时候又需要在进程退出的时候,进程也退出,该怎么办呢? 进程退出时,进程会如何?...一般情况下,进程退出后,是不会通知进程的,这个时候进程会成为孤儿进程,最终被init进程收养。我们先来看一下这种情况。...\n"); sleep(1); } return 0; } 在这个程序中,我们为了让进程先退出,进程sleep10秒。...另外还可以观察到,该进程也是其他系统进程进程。 如何确保进程退出的同时,进程也退出? 既然如此,如何确保进程退出的同时,进程也退出呢?...总结 有些情况下,我们常常需要父子进程共存亡,进程退出时,进程可以通过wait捕捉进程的退出状态,但是进程退出时,进程却难以得知。

12K21

关于进程进程的关系(UAC 绕过思路)

大家好,又见面,我是全栈君。 表面上看。在windows中。 假设是a进程创建了b进程,那么a进程就是b进程进程。...,假设我们利用一下该API,我们就能够将自己的进程的的进程设置为随意进程(要提权绕过UAC的鸽子注意),假设把木马进程进程设置为 杀软 的ID或者csrss.exe ,notepad.exe 等可信进程...这里通常是逆向一些小游戏的时候常见滴,好吧,不卖关子。根据上面的介绍,我调试的时候把他的进程从 ollydbg直接改成他要求的explorer.exe 就Ok。 有木有? 呵呵。...所以说进程进程不一定是进程的创建者,所以那一群依据进程来看进程是否可信的杀软就呵呵。 可是这里说下 360 这个绕只是,原因是啥哪? 记得我开篇时说过道高一尺,魔高一丈吗?...用这样的办法推断进程才是真正的进程。 这里參考文献是杂志《黑客防线》。我也不想学习知识装起来。所以学习始终是学无止境!

1.6K30

Linux系统进程编程之回收进程(三)

在上一篇文章中,我们介绍“僵尸进程”和“孤儿进程”的基本用法。但是我们还没有意识到出现“僵尸进程”的危害。...wstatus用来返回进程结束时的状态,进程通过wait得到wstatus后就可以知道子进程的一些结束状态信息。...返回值是进程的ID,当前进程有可能有多个子进程,wait函数阻塞直到其中一个进程结束wait就会返回,wait的返回值就可以用来判断到底是哪一个进程本次被回收了: wait(): on success...二、第二招:发送SIGCHILD信号: 1、我们还可以发送SIGCHILD信号来防止产生僵尸进程,当进程退出时向进程发送SIGCHILD信号,进程处理SIGCHILD信号,然后用上面信号处理函数中调用...此时如果进程执行waitpid时进程已经先结束等待回收则waitpid直接回收成功,返回值是回收的进程的PID; 如果进程waitpid时进程尚未结束则进程立刻返回(非阻塞),但是返回值为

3.3K20

Linux进程控制】五、wait()函数——进程回收

僵尸进程与孤儿进程 孤儿进程进程结束,进程被init进程收养。 僵尸进程进程结束,进程没有回收进程的资源(PCB),这个资源必须要由进程回收,否则就形成僵尸进程。...僵尸进程是不能用kill杀死的,因为kill命令是终止进程,而僵尸进程已经终止。我们知道僵尸进程的资源需要由进程去回收,那么我们在这种情况下如何回收僵尸进程的资源呢?...方法就是杀死进程进程被杀死后,由init接管子进程并回收进程资源。...如果设置WNOHANG选项,并且没有进程退出则返回0,如果有进程退出则返回退出进程的pid。 On error, -1 is returned....比如说没有进程进程早就全部结束,可能就会出错返回-1。 下面通过例子演示waitpid()函数的用法。

7410

进程欺骗实践

文章前言 监控进程进程之间的关系是威胁检测团队检测恶意活动的常用技术,例如,如果powershell是进程,而Microsoft Word是进程,这是一种折中的行为,各种EDR可以很容易地检测到这种异常活动...,这时红队可以考虑使用进程PID欺骗作为逃避方法,Windows API调用"CreateProcess"允许用户传入一个用于分配PID的参数,它可以用于指定当前进程进程。...项目介绍 https://github.com/Al1ex/SelectMyParent image.png 进程欺骗 Step 1:选择进程并确定其PID image.png Step 2:之后执行以下命令进行进程欺骗...SelectMyParent.exe notepad 928 image.png Step 3:使用process Explor查看进程树,可以看到成功欺骗 image.png 参考链接 https

1.4K20

Linux进程为何要苦苦地知道子进程的死亡原因?

白发人送黑发人 一个普遍的常识是,在Linux里面总是“白发人送黑发人”,进程死亡,进程透过wait()等待进程死亡,并清理进程僵尸,当然进程也可以因此而获得进程的死亡原因。...上述代码中,进程在第18行通过pause()等待信号,进程在代码的第22行通过waitpid()等待进程的结束。其中的参数status是一个输出参数,可以获得进程死亡的原因。...则进程探测到进程死亡后,可打印它的退出状态: $ ....在wait_task_zombie()中,进程会透过进程的僵尸分析获得进程的exit_code组合,并进一步拼装status。 事出必有因 那么,进程为什么必须知道子进程的死亡呢?...所以,这个过程应该由Linux的某种机制自动完成,比如如果init知道httpd死亡的话,它可以内在地自动重新启动一个httpd进程

2K20

如何在进程中读取(外部)进程的标准输出和标准错误输出结果

依稀记得去年年中时,有个同事也问过我如何获取被调用进程的输出结果,当时还研究一番,只是没有做整理。今天花点时间,将该方法整理成文。...它是我们启动进程时,控制进程启动方式的参数。...我们之后将hWrite交给我们创建的进程,让它去将信息写入管道。而我们进程,则使用hRead去读取进程写入管道的内容。...也就是说,我们设置的这些句柄要有可继承性。这就解释我们之前为什么在创建管道时要将句柄可继承性设置为TRUE的原因。         一般来说,我们要代理的程序已经输入好信息。...delete [] pBuffer; wprintf(L"%s", cstrBuffer); } return 0; }         这样,我们就可以拿到进程输出结果并加以分析

3.8K10

LinuxLinux进程控制>进程创建&&进程终止&&进程等待&&进程程序替换

进程进程,而原进程进程 #include pid_t fork(void); 返回值:自进程中返回0,进程返回进程id,出错返回-1 进程调用fork,当控制转移到内核中的...fork代码后,内核做: 分配新的内存块和内核数据结构给进程进程部分数据结构内容拷贝至进程 添加进程到系统进程列表当中 fork返回,开始调度器调度 当一个进程调用fork之后,就有两个二进制代码相同的进程...具体见下图: 1.3 fork常规用法 一个进程希望复制自己,使父子进程同时执行不同的代码段。例如,进程等待客户端请求,生成进程来处理请求 一个进程要执行一个不同的程序。...最后,进程派给进程的任务完成的如何,我们需要知道。...); 返回值: 当正常返回的时候waitpid返回收集到的进程进程ID; 如果设置选项WNOHANG,而调用中waitpid发现没有已退出的进程可收集,则返回0; 如果调用中出错,则返回-

13410

Linux进程——Linux进程进程优先级

所以,只要子进程退出,进程还在运行,但进程没有读取进程状态,进程进入Z状态 僵尸状态就是Linux状态中的X死亡状态!...,进程没有回收退出信息时,进程会进入僵尸状态 1.4 僵尸进程的危害 僵尸进程危害 进程的退出状态必须被维持下去,因为他要告诉关心它的进程进程),你交给我的任务,我办的怎么样。...可进程如果一直不读取,那进程就一直处于Z状态!...开个玩笑,孤儿进程进程进程退出之前就先退出了,此时的进程就称为“孤儿进程” 但是前面刚刚讲过一个进程在死亡时,PCB的死亡信息必须被读取后,才会释放PCB,但是如果进程已经退出了,进程的...进程进程退出了,进程要被领养,变成孤儿进程,而通过视频我们发现孤儿进程全部被1号进程统一领养了。

8910

C语言Linux系统编程-等待终止的进程(僵死进程

1.等待终止的进程(僵死进程): 如果一个进程进程之前结束,内核会把子进程设置为一个特殊的状态,处于这种状态的进程称为僵死进程进程获取了进程的信息后,进程才会消失。...pid_t wait(int *status); 进程调用这个方法会被阻塞住,如果子进程终止的时候,此方法会调用并且返回终止进程的pid #include #include <unistd.h...=wait(&status); printf("我的进程,pid=%d,终止\n",sonPid); }else if(ret==0){...,pid=22315 , ppid=12479 ,我新建的进程pid=22316 我是进程,pid=22316 , ppid=22315 我的进程,pid=22316,终止 2.如果进程进程之前终止...,那么系统会把子进程设置给init进程(pid为1),init进程会周期性的等待所有的进程,确保没有长时间的僵死进程

3.5K20

LinuxLinux进程控制——进程创建、进程终止及进程等待详解

进程创建 fork函数初识 在Linux中fork函数时非常重要的函数,它从已存在进程中创建一个新进程。新进程进程,而原进程进程。..._exit(int status); 参数: status 定义进程的终止状态,进程通过 wait 来获取该值 说明:虽然status是int,但是仅有低8位可以被进程所用...⭐进程等待 进程等待的必要性 在Linux进程提到过,进程退出,进程如果不管不顾,不读取进程的退出信息,就可能造成“僵尸进程”的问题,进而造成内存泄漏。...如,进程运行完成,结果对还是不对, 或者是否正常退出。 进程通过进程等待的方式,回收进程资源,获取进程退出信息。..., int options); 返回值: 当正常返回的时候waitpid返回收集到的进程进程ID; 如果设置选项WNOHANG,而调用中waitpid发现没有已退出的进程可收集

9310
领券