一、操作系统(Operator System)
概念
任何计算机系统都包含一个程序集合,称为操作系统(OS)。
包含:
1.内核(进程管理 内核管理 文件管理 驱动管理)
2.其他程序(库函数 shell程序等)
设计OS的目的
1.与硬件交互,管理所有软硬件资源。
2.为用户程序提供一个良好的执行环境
定位:管理软件
结构图
总结
计算机管理硬件
1.描述起来用结构体
2.组织起来用链表或者其他高级数据结构
系统调用和库函数概念
1.操作系统对外表现为一个整体,但是会暴露自己的部分接口,供上层开发使用,这部分由操作系统提供的接口,叫做系统调用。
2.系统调用在使用上,功能比较基础,对用户的需求比较高,所以开发者对其进行了进一步封装,从而形成了库,有利于更上层用户进行二次开发。
二、进程
基本概念
课本概念:程序执行的一个实例,正在执行的程序等
内核观点:担当分配系统资源(CPU时间,内存)的实体。
描述进程-PCB
进程的数据被放置在一个叫做进程控制块的数据结构中,可以理解为进程属性的集合。
1.Linux下的PCB是task_struct.
2.task_struct是Linux内核的一种数据结构,它会被装载到RAM(内存)里并且包含着进程的信息。
查看进程
进程的信息可以通过 /proc 系统文件查看
大多数进程信息同样可以使用top和ps这些用户工具来获取。
通过系统调用获取进程标志符
进程id (PID) 父进程id (PPID)
#include<stdio.h>
#include<sys/types.h>
#include<unistd.h>
int main(){
printf("pid: %d\n", getpid());
printf("ppid: %d\n", getppid());
return 0;
}
通过系统调用创建进程-fork初始
运行 man fork 认识 fork
fork 有两个返回值
父子进程代码共享 数据各自开辟空间 私有一份(采用写时拷贝)
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
int main()
{
int ret = fork();
printf("hello proc : %d!, ret: %d\n", getpid(), ret);
sleep(1);
return 0;
}
运行结果