生如夏花的博客

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

APUE(20)

线程同步之读写锁

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

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

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

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

线程同步之互斥量

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

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

进程关系

本文主要介绍了终端,包括物理终端、模拟终端以及伪终端等。

两种不同的登录方式、即终端登录和网络登录。

重点是进程组、会话以及控制终端之间的联系。

最后是作业控制,作业控制是目前很多类Unix系统都支持的功能。

介绍了shell程序是如何实现作业控制的以及shell运行程序的方式。

系统数据文件和信息

口令文件/etc/passwd和组文件/etc/group经常被多个进程频繁使用。用户每次登录Linux和使用ls命令都会访问口令文件。

除了直接访问文件之外,系统通过一些接口来对外提供信息,比如系统标识函数、时间和日期函数。

标准IO

标准I/O库由ISO C标准制定的。标准I/O库相对于系统I/O处理了很多细节,比如缓冲区分配、以优化的块大小执行I/O(这个数据存储在stat结构体中的st_blksize字段)等。

系统I/O是以文件描述符来作为基础展开的,而标准I/O是围绕流进行的,打开或创建文件时会将流和文件关联起来。

获取与流相关的文件描述符可以使用函数fileno()

流和文件相关联为文件流,流和内存关联起来为内存流。

文件和目录

本文描述了文件的属性,主要是struct stat结构体中的相关字段,比如文件所有者ID、文件所属组ID、块大小等。

其次详细描述了文件权限的相关内容,包括文件的基本权限、进程创建、读写文件的权限验证规则以及修改文件权限的相关接口等。

最后是文件系统简介,包含inode、目录项等,以及文件时间,创建删除以及读写目录等。

文件IO

本节主要介绍不带缓冲的I/O(unbuffered I/O),不带缓冲指的是每个readwrite都会调用内核中的一个系统调用。

不带缓冲的I/O函数不是ISO C的标准函数,但是是符合POSIX的。

原子操作在多进程之间贡献文件变得相当重要。

主要涉及的函数有oepn, read, write, lseek, close; dup, fcntl, sync, fsync, ioctl