Linux--进程控制

简介: Linux--进程控制

进程终止

进程终止是指一个正在运行的进程结束其执行并释放占用的系统资源的过程。进程可以通过以下几种方式终止:

正常终止:进程完成了它的任务,或者遇到了终止条件,例如调用了exit()函数或主函数执行完毕。

异常终止:进程可能会遇到一些异常情况,例如访问非法内存、发生除零错误等。操作系统会接收到这些异常,并强制终止进程。

被其他进程终止:另一个进程可以发送信号给目标进程,要求其终止。例如,在命令行中使用kill命令终止特定进程。

系统终止:操作系统可能需要终止某些进程以保护系统的稳定性,例如当系统资源不足时。

在进程终止时,操作系统会回收已分配给该进程的内存空间、文件描述符、打开的文件等资源,并将进程的退出状态返回给父进程。

自定义退出码

enum{
   success=0,
  open_err,                                                                                                   
  malloc_err 
};
const char* errorToDesc(int code)
{
  switch(code)
  {
    case success:
      return "success";
    case open_err:
      return "file open error";
    case malloc_err:
      return "malloc error";
    default:
      return "unknown error";
                                                                                                              
  }
}
 int Print()
{
  printf("hello Linux\n");
  printf("hello Linux\n");
  printf("hello Linux\n");
  printf("hello Linux\n");
  return 0;
}
int main()
{
 int n=Print();
  printf("n=%d\n",n);
  int code=malloc_err;
  printf("%s\n",errorToDesc(code));
  return 0;
}

打印出退出码表示的含义

举例:

exit()和_exit()

exit()和_exit()都是用于正常终止进程的函数

进程等待

进程等待指的是一个进程暂停其执行,直到满足某个条件或事件发生后才会继续执行。在操作系统中,进程可以通过等待来同步和协调与其他进程的操作。

wait

在Linux中,wait()是一个系统调用,是父进程在等待子进程执行完毕之前挂起自身,并等待子进程的终止状态

父进程可以使用wait()等待子进程的终止。当父进程调用wait()时,如果子进程已经终止,则父进程会立即返回,并可以通过子进程的终止状态来了解子进程终止的 原因和状态。

下面来看例子:

waitpid()

waitpid()是Linux中的一个系统调用,用于等待指定子进程的终止并获取其终止状态。它可以用来在父进程中等待一个特定的子进程或者等待任何子进程的终止。

waitpid()函数的原型如下:

#include <sys/types.h>
#include <sys/wait.h>
pid_t waitpid(pid_t pid, int *status, int options);

其中,参数pid指定要等待的子进程的PID,可以有以下几种取值:

-1:等待任意子进程终止。

0:等待与调用进程在同一进程组的任意子进程终止。

大于0:等待指定PID的子进程终止。

参数status是一个指向整型变量的指针,用于存储子进程的终止状态。

参数options用于指定附加的选项,如WNOHANG表示非阻塞方式等待,即如果没有子进程终止立即返回。

例子:

WIFEIERED

非阻塞等待

进程替换

进程替换是指在操作系统中将一个正在运行的进程替换为一个新的进程的过程。这个过程包括终止当前进程并加载新的程序代码、数据和资源,使新的进程开始执行。

在Linux中,常用exec()函数族来实现。

包括:

#include <unistd.h>`
int execl(const char *path, const char *arg, ...);
int execlp(const char *file, const char *arg, ...);
int execle(const char *path, const char *arg, ...,char *const envp[]);
int execv(const char *path, char *const argv[]);
int execvp(const char *file, char *const argv[]);

命名理解:

l(list) : 表示参数采用列表

v(vector) : 参数用数组

p(path) : 有p自动搜索环境变量PATH

e(env) : 表示自己维护环境变量

接下来看它们的使用

多进程替换

相关文章
|
3天前
|
消息中间件 算法 Linux
【Linux】详解如何利用共享内存实现进程间通信
【Linux】详解如何利用共享内存实现进程间通信
|
3天前
|
Linux
【Linux】命名管道的创建方法&&基于命名管道的两个进程通信的实现
【Linux】命名管道的创建方法&&基于命名管道的两个进程通信的实现
|
3天前
|
Linux
【Linux】匿名管道实现简单进程池
【Linux】匿名管道实现简单进程池
|
3天前
|
Linux
【Linux】进程通信之匿名管道通信
【Linux】进程通信之匿名管道通信
|
3天前
|
存储 Linux Shell
Linux:进程等待 & 进程替换
Linux:进程等待 & 进程替换
30 9
|
3天前
|
存储 Linux C语言
Linux:进程创建 & 进程终止
Linux:进程创建 & 进程终止
27 6
|
3天前
|
Linux 数据库
linux守护进程介绍 | Linux的热拔插UDEV机制
linux守护进程介绍 | Linux的热拔插UDEV机制
linux守护进程介绍 | Linux的热拔插UDEV机制
|
3天前
|
Unix Linux 调度
linux线程与进程的区别及线程的优势
linux线程与进程的区别及线程的优势
|
3天前
|
Linux 调度 C语言