线程是进程中的一个独立控制流。一个进程包含一个或多个线程。
线程基本上不拥有系统资源(只有少量运行中必不可少的资源),但它可与同属于一个进程的其他线程共享该进程的全部资源,包括地址空间(数据段和堆段)、通用信号处理机制、数据与I/O。而线程有自己的栈(自动变量)。
进程是系统资源分配的最小单位,线程是CPU调度的最小单位
pthread
Linux中的线程相关函数都是以pthread开头的,它的含义是:POSIX thread,即POSIX标准的线程。
关于POSIX线程的更多概念,大家可以去man pthreads
查看。
API对比
功能 | 线程 | 进程 |
---|---|---|
创建 | pthread_create | fork,vfork |
退出 | pthread_exit | exit |
等待 | pthread_join | wait,waitpid |
取消/终止 | pthread_cacel | abort |
读取ID | pthread_self | getpid |
通信机制 | 信号,信号量,互斥锁,读写锁,条件变量 | 管道(有名/无名),信号,信号量,消息队列,共享内存 |
调度
线程和进程支持同样的调度策略:
- SCHED_OTHER 分时调度策略,(默认的)
- SCHED_FIFO 实时调度策略,先到先服务
- SCHED_RR 实时调度策略,时间片轮转
编译
在编译(gcc)包含pthread函数的程序时,要显式地链接线程库,即-lpthread。