程序基础知识

对称多处理器 (SMP, Symmetrical Multi-Processing) 多核处理器(Multi-core Processor) 应用程序接口(Application Programming Interface) 系统调用接口(System call Interface) 软件中断(Software Interrupt) 硬件规格(Hardware Specification) 多道程序(Multiprogramming) 分时系统(Time-Sharing System) 多任务系统(Multi-tasking System) 进程(Process) 抢占式(Preemptive) 硬件驱动(Device Driver) 扇区(Sector) LBA(Logical Block Address)即整个硬盘中所有的扇区从0开始编号,一直到最后一个扇区,这个扇区编号叫做逻辑扇区号。逻辑扇区号抛弃了所有复杂的磁道、盘面之类的概念。 虚拟地址空间(Virtual Address Space) 物理地址空间(Physical Address Space) 分段(Segmentation)基本思路是把一段与程序所需要的内存空间大小的虚拟空间映射到某个地址空间 分页(Paging)基本方法是把地址空间人为地等分成固定大小的页,每一页的大小由硬件决定,或硬件支持多种大小的页,由操作系统选择决定页的大小。 虚拟页(VP Virtual Page) 物理页(PP Physical Page) 磁盘页(DP Disk Page) 页错误(Page Fault) MMU(Memory Management Unit) 虚拟地址到物理地址的转换 flowchart LR CPU --> |Vitual Address| MMU --> |Physical Address| PhysicalMemory 线程(Thread)有时被称为轻量级进程(Lightweight Process, LWP)是程序执行流的最小单元。一个标准的线程由线程 ID、当前指令指针(PC)、寄存器集合和堆栈组成。 线程私有 线程之间共享 (进程所有) 局部变量 全局变量 函数的参数 堆上的数据 TLS(Thread Local Storage)数据 函数里的静态变量 程序代码,任何线程都有权利读取病执行任何代码 打开的文件,A线程打开的文件可以由B线程读写 在单处理器对应多线程的情况下,并发是一种模拟出来的状态。操作系统会让这些多线程程序轮流执行,每次仅执行一小段时间(通常是几十到几百毫秒),这样每个线程就“看起来”在同时执行。这样的一个不断在处理器上切换不同的线程的行为称之为线程调度 (Thread Schedule)。在线程调度中,线程通常拥有至少三种状态 ...

April 9, 2026 · 2 min · Theme PaperMod

静态链接

#include <stdio.h> int main() { printf("Hello World\n"); return 0; } gcc hello.c ./a.out 上面的过程分解为4个步骤,分别是预处理(Prepressing)、编译(Compilation)、汇编(Assembly)和链接(Linking)。 flowchart LR src["Source Code\nhello.c"] header["Header Files\nstdio.h\n...."] lib["Static Library\nlibc.a\n..."] cpp["Preprocessing\n(cpp)"] hi["Preprocessed\nhello.i"] gcc["Compilation\n(gcc)"] hs["Assembly\nhello.s"] as["Assembly\n(as)"] ho["Object File\nhello.o"] ld["Linking\n(ld)"] out["Executable\na.out"] src --> cpp header --> cpp cpp --> hi --> gcc --> hs --> as --> ho --> ld --> out lib --> ld 预编译 第一步与预编译的过程相当于如下命令(-E 表示只进行预编译) gcc -E hello.c -o hello.i 或 cpp hello.c > hello.i 预编译的处理规则如下 将所有的 #define 删除,并且展开所有的宏定义 处理所有条件预编译指令,比如 #if #ifdef #elif #else #endif 处理 #include 预编译指令,将被包含的文件插入到该预编译指令的位置。这个过程是递归进行的,也就是说被包含的文件可能还包含其他文件 删除所有的注释 // 和 /**/ 添加行号和文件名标识,比如 #2 “hello.c” 2, 已便于编译时编译器产生调试用的行号信息及用于编译时产生编译错误或警告时能够显示行号 保留所有的 #pragma 编译指令,因为编译器需要使用它们 编译 编译过程就是把预处理完的文件进行一系列词法分析、语法分析、语义分析及优化后生产相应的汇编代码文件。上面的编译过程相当于 gcc -S hello.i -o hello.s ...

April 9, 2026 · 8 min · Theme PaperMod