C语言进程

这篇博客详细介绍了C语言中的进程环境,包括虚拟地址空间、环境表、进程表项、跨函数跳转和进程资源限制。接着讨论了进程控制,如属性、创建、终止、收尸、注册终止处理程序和替换。此外,还涉及了进程间通信,如管道和XSI。最后,讲解了守护进程的特点、创建、日志处理和单实例实现,以及进程间的关系,如会话、进程组和进程。
摘要由CSDN通过智能技术生成

目录

目录

一、进程环境

1.虚拟地址空间

2.环境表

 3.进程表项

4.跨函数跳转

 5.进程资源限制

二.进程控制

 1.属性

 2.创建

 3.终止

 4.收尸

 5.注册终止处理程序

 6.替换 

 三.进程间通信

1.管道 

 2.xsi

四.守护进程

1.特点

2.创建

3.日志

4.单实例

五.进程间的关系

 1.会话

2.进程组

3.进程


一、进程环境

1.虚拟地址空间

  • 栈:局部变量,函数的形参;未初始化值随机;生命周期随函数的调用结束而结束
  • 堆:用户自行申请和释放,动态开辟
  • bss段:未初始化的局部静态变量和全局变量;初始值为0
  • data段:已初始化的局部静态变量和全局变量;生命周期从定义开始到进程结束
  • 文本段

2.环境表

 extern char **environ

#include <stdio.h>
#include <stdlib.h>
 extern char **environ;
 int main(int argc,char *argv[],char *environ[])
 {
     int i;
     for(i=0;environ[i];i++)
         puts(environ[i]);
     exit(0);
 }

 3.进程表项

4.跨函数跳转

#include <setjmp.h>
int setjmp(jmp_buf env);

setjmp 函数的功能是将函数在此处的上下文保存在 jmp_buf 结构体中,以供 longjmp 从此结构体中恢复。

  • 参数 env 即为保存上下文的 jmp_buf 结构体变量;
  • 如果直接调用该函数,返回值为 0; 若该函数从 longjmp 调用返回,返回值为非零,由 longjmp 函数提供。根据函数的返回值,我们就可以知道 setjmp 函数调用是第一次直接调用,还是由其它地方跳转过来的。
void longjmp(jmp_buf env, int val);

longjmp 函数的功能是从 jmp_buf 结构体中恢复由 setjmp 函数保存的上下文,该函数不返回,而是从 setjmp 函数中返回。

  • 参数 env 是由 setjmp 函数保存过的上下文。
  • 参数 val 表示从 longjmp 函数传递给 setjmp 函数的返回值,如果 val 值为0, setjmp 将会返回1,否则返回 val。
  • longjmp 不直接返回,而是从 setjmp 函数中返回,longjmp 执行完之后,程序就像刚从 setjmp 函数返回一样。

#include <stdio.h>
#include <setjmp.h>
#include <stdlib.h>
static jmp_buf env;
int div2num (int n1,int n2)
{
    if(n2==0)
        longjmp(env,1);//第二个参数随意,按1处理,longjmp带回的返回值
    return n1/n2;
}
int main()
{
    int n1,n2;
    if(setjmp(env)==0)//规定第一次返回值为0
        printf("请输入俩个整形变量值\n");
    else
        printf("请重新输入\n");
//  if(setjmp(env)!=0)
//      printf("跳转2");

    scanf("%d%d",&n1,&n2);
    printf("res:%d/%d=%d\n",n1,n2,div2num(n1,n2));
    exit(0);
}
                                                                         
                                                                         
                                                                         

 5.进程资源限制

命令:ulimit -a

llj@llj-virtual-machine:~$ ulimit -a
core file size          (blocks, -c) 0
data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) unlimited
pending signals                 (-i) 7641
max locked memory       (kbytes, -l) 65536
max memory size         (kbytes, -m) unlimited
open files                      (-n) 1024
pipe size            (512 bytes, -p) 8
POSIX message queues     (bytes, -q) 819200
real-time priority              (-r) 0
stack size              (kbytes, -s) 8192
cpu time               (seconds, -t) unlimited
max user processes              (-u) 7641
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited

 函数:

#include <sys/resource.h>
int getrlimit( int resource, struct rlimit *rlptr );//函数查询资源限制
int setrlimit( int resource, const struct rlimit *rlptr );//函数更改资源限制
//两个函数返回值:若成功则返回0,若出错则返回非0值
struct rlimit {
    rlim_t    rlim_cur;    /* 当前限制 */
    rlim_t    rlim_max;    /* 最大值 */
};

 在更改资源限制时,须遵循下列三条规则

  • 任何一个进程都可将一个软限制值更改为小于或等于其硬限制值
  • 任何一个进程都可降低其硬限制值,但它必须大于或等于其软限制值。这种降低对普通用户而言是不可逆的
  • 只有超级用户进程可以提高硬限制值

常量RLIM_I

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值