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

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

PID关系: 进程的PID(进程标识符)是由进程调用fork()或类似系统调用创建的。 进程的PPID(进程标识符)与创建它的进程的PID相同。...下面是对这两个返回值的解释: 给进程返回进程的 PID:在进程中,fork 返回新创建进程进程 ID(PID),这个 PID 是进程的标识符,进程通过这个 PID 可以识别并操作进程。...为了区分进程进程,fork 在进程中返回 0,表示这是进程执行的代码路径。...(uninterruptible sleep),在这个状态的进程通常会等待IO的结束。...也是才结束51假期,希望51数学建模能拿个不错的奖项吧 感谢大家支持

1.4K10

探索进程进程

进程进程 这个进程PID到底是什么?...先来认识一下fork函数: fork函数会以调用该函数的进程作为进程创建一个进程 创建成功时,会在进程中返回进程的PID,在进程中返回0;如果失败,在进程中返回-1,没有进程创建。...一个进程可以创建多个子进程,为了区分这些进程,fork函数在创建进程后,会给进程返回进程的pid。进程只需调用getppid()函数即可找到进程。...进程进程也是两个进程,也具有独立性,父子进程不能访问同一份数据,数据在代码执行过程中可能会被修改。所以进程要把进程的数据单独拷贝一份,这个过程是由操作系统来完成的。...进程可以把进程的数据全被拷贝一份,但是大部分数据对于进程来说可能都是没用的,这就造成了浪费,所以操作系统只是把进程中数据层面的代码临时拷贝一份给进程,即进程创建后,会共享进程的代码和数据,

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

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

    前言 进程退出的时候,进程能够收到进程退出的信号,便于管理,但是有时候又需要在进程退出的时候,进程也退出,该怎么办呢? 进程退出时,进程会如何?...一般情况下,进程退出后,是不会通知进程的,这个时候进程会成为孤儿进程,最终被init进程收养。我们先来看一下这种情况。...另外还可以观察到,该进程也是其他系统进程进程。 如何确保进程退出的同时,进程也退出? 既然如此,如何确保进程退出的同时,进程也退出呢?...内容很多,主要意思为:设置一个信号,当进程退出的时候,进程将会收到该信号。 那么根据这个,我们完全可以在进程退出时,也给进程一个退出的信号。...总结 有些情况下,我们常常需要父子进程共存亡,进程退出时,进程可以通过wait捕捉进程的退出状态,但是进程退出时,进程却难以得知。

    12.2K21

    linux命令行怎么结束进程,linux结束进程命令「建议收藏」

    linux进程的开启与结束都可以通过命令来控制,下面由学习啦小编为大家整理了linux结束进程命令的相关知识,希望对大家有所帮助。...linux结束进程命令1.kill kill [信号代码] 根据PID向进程发送信号,常用来结束进程,默认信号为 -9 信号代码,可取值如下: -l [信号数字] 显示、翻译信号代码 -9 , -KILL...,但不结束 -CONT 继续运行已停止的进程 -9 -1 结束当前用户的所有进程 linux结束进程命令2.pkill pkill 结束进程族。...如果结束单个进程,请用 kill linux结束进程命令3.killall killall killall和pkill 应用方法差不多,也是直接杀死运行中的程序;如果您想杀掉单个进程,请用kill 来杀掉...linux结束进程4.xkill 在图形界面中点杀进程。 当xkill运行时鼠标指针变为骷髅图案,哪个图形程序崩溃一点就OK了。如果您想终止xkill ,就按右键取消。

    6.7K61

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

    假设是a进程创建了b进程,那么a进程就是b进程进程。...,假设我们利用一下该API,我们就能够将自己的进程的的进程设置为随意进程(要提权绕过UAC的鸽子注意了),假设把木马进程进程设置为 杀软 的ID或者csrss.exe ,notepad.exe 等可信进程...假设你调试的程序检測进程,直接用以上的办法启动它,当然进程就是他检測同意的进程喽, 这里启动时要注意的是设置CREATE_SUSPEND 就是创建挂起,然后在创建后使用ResumeThread恢复就能够顺利调试了...所以说进程进程不一定是进程的创建者,所以那一群依据进程来看进程是否可信的杀软就呵呵了。 可是这里说下 360 这个绕只是,原因是啥哪? 记得我开篇时说过道高一尺,魔高一丈吗?...用这样的办法推断进程才是真正的进程。 这里參考文献是杂志《黑客防线》。我也不想学习了知识装起来。所以学习始终是学无止境!

    1.6K30

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

    那么说了这么多,我们该怎么样来回收Linux系统的僵尸进程呢?...wstatus用来返回进程结束时的状态,进程通过wait得到wstatus后就可以知道子进程的一些结束状态信息。...返回值是进程的ID,当前进程有可能有多个子进程,wait函数阻塞直到其中一个进程结束wait就会返回,wait的返回值就可以用来判断到底是哪一个进程本次被回收了: wait(): on success...二、第二招:发送SIGCHILD信号: 1、我们还可以发送SIGCHILD信号来防止产生僵尸进程,当进程退出时向进程发送SIGCHILD信号,进程处理SIGCHILD信号,然后用上面信号处理函数中调用...此时如果进程执行waitpid时进程已经先结束等待回收则waitpid直接回收成功,返回值是回收的进程的PID; 如果进程waitpid时进程尚未结束进程立刻返回(非阻塞),但是返回值为

    3.4K20

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

    僵尸进程与孤儿进程 孤儿进程进程结束进程被init进程收养。 僵尸进程进程结束进程没有回收进程的资源(PCB),这个资源必须要由进程回收,否则就形成僵尸进程。...ID在3秒后变成了1,这说明进程结束后,它变成了孤儿进程,并被init进程收养,使用kill命令基于可以杀死孤儿进程。...方法就是杀死进程进程被杀死后,由init接管子进程并回收进程资源。...,这是因为在waitpid()函数中使用了选项参数WNOHANG,而进程中有一个睡眠函数,进程睡眠的时候,进程中waitpid()语句没有等到进程结束就执行了,由于WNOHANG选项参数的存在,...当waitpid()返回进程中后,进程结束,但是waitpid()已经执行完了,所以并没有回收进程进程因此变成僵尸进程

    8310

    进程欺骗实践

    文章前言 监控进程进程之间的关系是威胁检测团队检测恶意活动的常用技术,例如,如果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

    Nodejs进程

    默认情况下, stdin、 stdout 和 stderr 的管道会在 Node.js 进程和衍生的进程之间建立,这些管道的容量是有限的。...child_process.fork(): 衍生新的 Node.js 进程,并调用指定的模块,该模块已建立了 IPC 通信通道,可以在进程进程之间发送消息。...cluster cluster模块是基于child_process.fork方法创建的,它可以使用IPC和进程进行通信。...process.pid} is running`) for( let i = 0; i < numsCPUS.length; i++) { cluster.fork() // fork出来的进程拥有和进程一致的...master进程创建一个socket,并绑定监听到该目标端口,通过与进程之间建立IPC通道,调用进程的send方法,将socket(链接句柄)传递给进程,大致实现如下。

    1.3K20

    Linux内核内幕:深入解析进程结束过程

    引 天下没有不散的宴席,有进程的创建就会有进程的消亡。那么内核是如何处理进程自身的消亡的,又是如何处理它的进程进程的呢?...让我们来结合《Linux内核设计与实现》以及Linux v6.3版本进行学习与了解。 进程终结的原因 一般来说,进程结束是尤其自身引起的。...(tsk); // 开启一个RCU临界区 exit_tasks_rcu_start(); // 通知进程已经退出,给进程寻找新的养父,并把进程的状态设置为僵尸状态 exit_notify(tsk...小结 总结一下,除去安全等防御性编程外,进程的exit大概做了以下的三件事: 释放资源 通知其他组件该进程已经结束,将进程等资源托付给其他进程 这其中自然释放资源是占很大的比重的,可以看到我们释放了数十种进程的资源...,这个函数才结束

    50510
    领券