Linux系统学习
1. Linux系统调用
系统调用指操作系统提供给用户程序调用的一组“特殊”接口,用户程序可以通过这组“特殊”接口来获得操作系统内核提供的服务。
为什么用户程序不能直接访问系统内核提供的服务呢?这是由于在Linux中,为了更好地保护内核空间,将程序的运行空间分为用户空间和内核空间(也就是常称的用户态和内核态),它们分别运行在不同的级别上,逻辑上是相互分离的。因此,用户进程通常情况下不允许访问内核数据,也无法使用内核函数,它们只能在用户空间操作用户数据,调用用户空间的函数。
但是,在有些情况下,用户空间的进程需要获得一定的系统服务(调用内核空间程序),这时操作系统就必须利用系统提供用户的“特殊接口”———系统调用规定用户进程进入内核空间的具体位置。在进行系统调用时,程序运行空间需要从用户空间进入内核空间,处理完成后再返回用户空间。
Linux系统调用还算精简(只有250个左右),它继承了UNIX系统调用中最基本和最有用的部分。这些系统调用按照功能逻辑大致可分为进程控制、进程间通信、文件系统控制、存储管理、网络管理、套接字控制、用户管理等几类。
用户编程接口(API)
前面讲到的系统调用并不直接与程序员进行交互,它仅仅是一个通过软中断机制向内核提交请求以获取内核服务的接口。实际使用中,程序员调用的通常都是用户编程接口(API)。
例如,创建进程的API函数fork()函数对应于内核空间的sys_fork()系统调用,但并不是所有的函数都对应一个系统调用。有时,一个API函数会需要几个系统调用来共同完成函数的功能,甚至还有一些API函数不需要调用相应的系统调用(因此它所完成的不是内核提供的服务)。
系统命令
系统命令相对于API更高了一层,它实际上是一个可执行程序,它的内部引用了用户编程接口(API)来实现相应的功能,它们之间的关系如下图1:
2. Linux系统文件I/O编程(一)---open()等基本函数
4. Linux系统文件I/O编程(三)---I/O多路复用
6. Linux多任务编程(二)---fork()函数及其基础实验
7. Linux多任务编程(三)---exec函数族及其基础实验
8. Linux多任务编程(四)---exit()函数及其基础实验
9. Linux多任务编程(五)---wait()、waitpid()函数及其基础实验
10.Linux多任务编程(六)---编写多进程程序及其代码
11. Linux多任务编程(七)---Linux守护进程及其基础实验
12. Linux进程间通信(一)---进程间通信概述及其种类
13. Linux进程间通信(二)---管道通信之无名管道及其基础实验
14. Linux进程间通信(三)---管道通信之有名管道及其基础实验
15.Linux进程间通信(四)---信号通信之信号发送捕捉kill()、raise()、alarm()、pause()及其基础实验
16. Linux进程间通信(五)---信号通信之signal()、信号集函数组及其基础实验
17. Linux进程间通信(六)---信号量通信之semget()、semctl()、semop()及其基础实验
18. Linux进程间通信(七)---共享内存之shmget()、shmat()、shmdt()及其基础实验
19. Linux进程间通信(八)---消息队列之msgget()、msgsnd()、msgrcv()及其基础实验
20. Linux进程间通信(九)---综合实验之有名管道通信实验
21. Linux进程间通信(十)---综合实验之共享内存实验
22. Linux多线程编程(一)---多线程基本编程
23. Linux多线程编程(二)---线程之间的同步与互斥
24. Linux多线程编程(三)---线程之间的同步与互斥进阶实验