线程是进程中的一个独立控制流。一个进程包含一个或多个线程。
线程基本上不拥有系统资源(只有少量运行中必不可少的资源),但它可与同属于一个进程的其他线程共享该进程的全部资源,包括地址空间(数据段和堆段)、通用信号处理机制、数据与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