• pthread
  • API对比
  • 调度
  • 编译

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