Skip to content

Latest commit

 

History

History
46 lines (36 loc) · 1.93 KB

线程.md

File metadata and controls

46 lines (36 loc) · 1.93 KB

线程是进程中的一个独立控制流。一个进程包含一个或多个线程。
线程基本上不拥有系统资源(只有少量运行中必不可少的资源),但它可与同属于一个进程的其他线程共享该进程的全部资源,包括地址空间(数据段和堆段)、通用信号处理机制、数据与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_cancel abort
读取ID pthread_self getpid
通信机制 信号,信号量,互斥锁,读写锁,条件变量 管道(有名/无名),信号,信号量,消息队列,共享内存

进程,线程共享的资源的区别:

多进程 多线程
代码,文件描述符,内存映射区 堆,全局变量

线程更节省资源。

线程基础API总结

功能 描述
pthread_create 创建线程
pthread_exit 单个线程退出
pthread_join 阻塞等待线程退出并获取线程退出状态
pthread_detach 线程分离
pthread_attr_init 线程属性变量初始化(常用来设置线程的分离属性)
pthread_cancle 取消线程

调度

线程和进程支持同样的调度策略:

  • SCHED_OTHER 分时调度策略,(默认的)
  • SCHED_FIFO 实时调度策略,先到先服务
  • SCHED_RR 实时调度策略,时间片轮转

编译

在编译(gcc)包含pthread函数的程序时,要显式地链接线程库,即**-lpthread**。