线程
进程可以完成多任务,实现宏观上的并行。
进程短板:1、通信 2、切换开销很大。
为什么需要线程?
其实,在真实的操作系统中,程序运行的最小单位是线程,进程的实质是分配资源。
多线程隶属于一个进程,实现并发,独立运行。通信方便。
不好的地方:同步和互斥就是关键的处理地方。
现代多核心计算机对于多进程和多线程处理方式:
可以保证多个线程在不同的CPU核心上运行,进程不能保证。
pthread动态库链接的时候,可以加-pthread还可以-lpthread,正规的写法不加l。
子线程和主线程如果通信,就可以使用数据段
线程结束(退出)函数:1、return 2、pthread_exit
进程退出之前回收子线程:
1、pthread_join(阻塞在这里,等待回收子线程)
2、pthread_detach主线程分离子线程,分离后子线程就自己管自己。
pthread_cancel 主线程取消子线程(赶紧让他死)
pthread_setcancelstate 设置线程取消的状态(PTHREAD_CANCEL_ENABLE、PTHREAD_CANCEL_DISABLE),一旦可以取消(1、立即执行2、等待线程执行结束后取消线程).
pthread_setcanceltype设置线程是否立即执行取消动作。
linux下常用的线程信号量:
1、创建和初始化信号量:sem_init
参数1:输出型参数;参数2:0(linux不支持多个进程共享这个信号量);参数3:信号量初始值
2、相当于P操