线程是进程中的一个独立控制流。一个进程包含一个或多个线程。
线程基本上不拥有系统资源(只有少量运行中必不可少的资源),但它可与同属于一个进程的其他线程共享该进程的全部资源,包括地址空间(数据段和堆段)、通用信号处理机制、数据与I/O。而线程有自己的栈(自动变量)。
进程是系统资源分配的最小单位,线程是CPU调度的最小单位
Linux中的线程相关函数都是以pthread开头的,它的含义是:POSIX thread,即POSIX标准的线程。
关于POSIX线程的更多概念,大家可以去man pthreads
查看。
功能 | 线程 | 进程 |
---|---|---|
创建 | 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**。