【Linux系统】系统编程

一、Linux 系统编程

Linux 的系统编程(Linux System Programming )是指直接与操作系统内核提供的 系统调用(System Calls)低级接口(Low-level Interfaces)交互的编程方式。它是介于应用程序开发和内核开发之间的一种编程层次,用来编写高性能、可靠并能直接控制系统资源的程序。

1. Linux 系统编程的核心概念

  1. 系统调用(System Call)

    • 系统调用是用户空间程序与内核空间通信的主要接口。
    • 常见的系统调用包括:
      • 文件操作:open(), read(), write(), close()
      • 进程控制:fork(), exec(), wait(), exit()
      • 内存管理:mmap(), brk()
      • 进程通信:pipe(), socket(), shmget()
    • 它们为程序提供了访问内核资源的手段。
  2. 用户空间与内核空间

    • 用户空间(User Space):应用程序运行的普通内存区域,不能直接访问硬件。
    • 内核空间(Kernel Space):操作系统核心的执行区域,负责管理硬件和资源。
    • 系统调用是两者之间受控的"桥梁"。

    用户空间不能直接操作硬件资源,必须通过"系统调用"进入内核空间,请求内核来完成操作。

  3. 文件描述符(File Descriptor, FD)

    • 在 Linux 中,几乎所有资源都被抽象为"文件",包括普通文件、设备、管道、socket。
    • 每打开一个资源,内核就分配一个整数型"文件描述符"。

2. Linux 系统调用常见分类

类别 典型接口 使用场景
文件与目录 open(), read(), write(), lseek(), stat() 文件读写、权限管理
进程管理 fork(), exec(), waitpid() 创建、执行其他程序
信号处理 signal(), sigaction() 异步事件通知(如 Ctrl+C)
多线程编程 pthread_create(), pthread_mutex_lock() 并发执行、多核利用
进程间通信 (IPC) 管道、命名管道、共享内存、消息队列、信号量 数据交换、协同工作
网络编程 socket(), bind(), connect(), send(), recv() TCP/UDP 通信
内存映射 mmap(), munmap() 高效文件访问或共享内存
时间与定时 gettimeofday(), clock_gettime() 计时与延时控制

3. 系统编程与应用编程的区别

对比点 系统编程 应用编程
层级 接近内核(使用系统调用) 基于库或框架
接口 POSIX 标准、C 接口 高级语言接口(Python、Qt 等)
目标 性能、控制力、资源管理 开发效率、易用性
示例 Shell、终端、守护进程 图形界面程序、网页应用
相关推荐
十日十行11 小时前
Linux和window共享文件夹
linux
Sinclair15 小时前
简单几步,安卓手机秒变服务器,安装 CMS 程序
android·服务器
木心月转码ing18 小时前
WSL+Cpp开发环境配置
linux
Rockbean2 天前
用40行代码搭建自己的无服务器OCR
服务器·python·deepseek
蝎子莱莱爱打怪2 天前
Centos7中一键安装K8s集群以及Rancher安装记录
运维·后端·kubernetes
茶杯梦轩2 天前
CompletableFuture 在 项目实战 中 创建异步任务 的核心优势及使用场景
服务器·后端·面试
崔小汤呀2 天前
最全的docker安装笔记,包含CentOS和Ubuntu
linux·后端
何中应2 天前
vi编辑器使用
linux·后端·操作系统
何中应2 天前
Linux进程无法被kill
linux·后端·操作系统
何中应2 天前
rm-rf /命令操作介绍
linux·后端·操作系统