什么是线程及为什么要有线程?
有时又称轻量级进程,程序执行的最小单位,系统独立调度和分派cpu的基本单位,它是进程中的一个实体。一个进程中可以有多个线程,这些线程共享进程的所有资源。
进程出现了很多弊端,一是由于进程是资源拥有者,创建、撤消与切换存在较大的时空开销,因此需要引入轻型进程(即线程);二是由于对称多处理机(SMP)出现,可以满足多个运行单位,而多个进程并行开销过大。
多线程的优势:
1、在多处理器中开发程序的并行性
2、在等待慢速IO操作时,程序可以执行其他操作,提高并发性
3、模块化的编程,能更清晰的表达程序中独立事件的关系,结构清晰
4、占用较少的系统资源
关于线程的一些术语
- 并发:并发是指在同一时刻,只能有一条指令执行,但多个进程指令被快速轮换执行,使得在宏观上具有多个进程同时执行的效果。 看起来同时发生(这里是在单核的基础上)。
- 并行是指在同一时刻,有多条指令在多个处理器上同时执行。真正的同时发生
- 同步:彼此有依赖关系的调用不应该“同时发生”,而同步就是要阻止那些“同时发生”的事情
- 异步的概念和同步相对,任何两个彼此独立的操作是异步的,它表明事情独立的发生
线程的创建
线程与进程的对比:
- pthread_t:是一个unsigned long int类型。
- 获取线程id:pthread_self()获得调用pthread_self()函数的线程的线程id,与getpid()类似,getpid()是获得进程id。
- 创建线程:pthread_create()
int pthread_create(pthread_t *restrict tidp,
const pthread_attr_t *restrict attr,
void *(*start_routine)(void *),
void *restrict arg)
第一个参数:新线程的id,如果成功则新线程的id回填充到tidp指向的内存
第二个参数:线程属性(调度策略,继承性,分离性…)
第三个参数:回调函数(新线程要执行的函数)
第四个参数:回调函数的参数
返回值:成功返回0,失败则返回错误码
编译时需要连接库lib pthread
注意:
1、主线程是随着进程的创建而创建
2、其他线程可以通过调用函数来创建,主要调用pthread_create
3、请注意,新线程可能在当前线程从函数pthread_create返回之前就已经运行了,甚至新线程可能在当前线程从函数pthread_create返回之前就已经运行完毕了。
下篇文章具体分析函数pthread_create。