生如夏花的博客

专注于工业物联网行业数据采集,嵌入式Linux系统裁剪,5G智慧网关软件开发等

APUE(30)

信号集及相关函数

信号集sigset_t)是表示多个信号的数据类型。

不同的信号编号可能会超过一个整型量的位数,所以不能用整型量中的一位代表一个信号。

POSIX.1定义数据类型sigset_t用以表示信号集,并定义了信号的操作函数。

线程同步之读写锁

读写锁也称为共享互斥锁,具有3种状态:读模式下的加锁状态写模式下的加锁状态不加锁状态

一次仅有一个线程可以占有写模式下的读写锁,但是多个线程可以同时占有读模式下的读写锁。

读写锁非常适合于对数据结构读的次数远大于写的情况

与互斥量相比,读写锁(reader-writer lock)运行更高的并行性。

线程同步之互斥量

当多个线程共享相同的内存时,需要确保每个线程看到的都是一致的数据视图。

当一个线程可以修改的变量,其他线程也可以读取或修改的时候,就需要对这些线程进行同步,确保访问变量时不会得到无效的值。

线程同步之条件变量

互斥量防止多个线程同时访问同一共享变量。

条件变量允许一个线程就某个条件(共享变量)的变化状态通知其他线程,并让其他线程等待(阻塞于)该通知。

条件变量与互斥量一起使用,允许线程以无竞争的方式等待特定的条件发生。

线程属性

SUS定义了一些系统层面上对于线程的限制,比如进程可以创建的最大线程数、线程栈可用的最小字节数等等。

pthread接口允许我们传入线程或同步对象的属性来调节线程或同步对象的行为。

线程同步之屏障

屏障(barrier)是用户协调多个线程并行工作的同步机制。

屏障允许每个线程等待,直到所有的合作线程都到达某一点,然后从该点继续执行。

pthread_join是一种特殊的屏障,允许一个线程等待,直到另一个线程退出。

线程同步之条件变量属性

线程条件变量可以是线程以非竞争的方式同步执行

线程条件变量支持两个属性:进程共享时钟属性

进程共享属性可以使条件变量被多进程的线程使用。

时钟属性控制计算pthread_cond_timedwait()函数的超时参数(tsptr)时采用哪个时钟。