• linux进程


    使用pstree以数结构的方式查看linux现有进程

    liunx在启动的时候会由内核创建一个init进程

    其他进程都是init进程执行fork函数创建的,init进程的pid是1

    fork函数是干嘛的?

    fork函数简单来说就是克隆进程,克隆出来的进程称为子进程,原来的叫父进程
    fork函数执行的时候先复制父进程的PCB(PCB在内核空间),然后再复制用户空间的代码段、数据段、栈、堆、程序计数器
    至于,克隆出来的进程为什么干不一样的活,下面会说明。

    当我们在编写C程序的时候想获取该进程的pid怎么做?

    • 引入头文件unistd.h,该文件在/usr/include/unistd.h
    • 直接调用getpid,成功返回该进程的pid,失败返回-1

    进程的生命周期

    C程序的启动函数是main函数,当启动main函数前会调用特殊函数获取main函数的入口地址,然后给main函数传递参数

    进程的中止




    进程内存空间分布


    正文就是代码:通常是共享只读的
    初始化数据:程序执行前明确赋值的,比如int a=10;
    未初始化数据:没有明确赋值的,使用的默认值,如int a[10];

    环境变量表

    每个进程都有自己的环境变量表

    c程序获取环境变量


    还有其他类似的函数,比如设置等

    c程序创建进程

    父子进程异同

    fork的用法

  • 相关阅读:
    社区检测算法--Infomap
    correlation matrices 相关矩阵
    多分类评估指标
    juniper修改用户密码
    zabbix4.4监控mysql状态
    高并发linux内核参数优化
    用脚本监控windows tcp的连接数
    使用typeperf监控系统资源
    rsync同步时报错
    windows jenkins编译报错处理
  • 原文地址:https://www.cnblogs.com/treasury/p/12758959.html
Copyright © 2020-2023  润新知