1.指针是无符号型整形
2.(&a + 1) : 跳过a类型的长度
3. .bss段 .txt代码段 .data :数据段
4. 指向只读数据段的指针地址都相同(因为只读数据段不可更改)
6. 在汇编中 : 标号的本质是: 地址
使用中断切换入内核空间
7.字符数组是两份拷贝 字符指针一份拷贝
8.用户空间 : 用户程序---------printf, putchar, fputs---------------libc----------buffer
内核空间 : 内核
两着之间通过write进行连接
9.UNIX的传统是Everything is a File.
10.每个进程在内核中都有一个task_struct结构体来维护进程相关的信息, 在Linux内核中称为进程描述符,而在操作系统中称为进程控制块
task_struct中包含该进程当前打开的所有文件的信息称为文件描述符表,在内核中用files_struct结构体表示, 其中的表项称为文件描述符,每个表项都包含一个指向已打开文件的指针
5.分别用FILE *指针表示文件描述符
stdin(0) stdout(1) stderr(2)
11. int open(const char *pathname, int flags);
int open(const char *pathname, int flags, mode_t mode);
返回未被使用的最小的整数
必选项 :
O_RDONLY 只读打开
O_WRONLY 只写打开
O_RDWR 可读可写打开
可选项 :
O_APPEND 表示追加。
O_CREAT 若此文件不存在则创建它, 使用此选项需要提供第三个参数mode, 表示该文件的访问权限
O_EXCL 如果同时指定了O_CREAT, 而文件文件已存在,则出错
O_TRUNC 如果此文件存在,而且为只写或可读可写成功打开,则将其长度截断位0
O_NONBLOCK 对于设备文件,以O_NONBLOCK方式打开可以做非阻塞I/O(Nonblock I/O)
注意open函数和fopen函数上细微的差别:
1. 以写的方式fopen一个文件时, 如果文件不存在会自动创建,以写方式open一个文件时, 必须明确指定O_CREAT才会创建文件,否则文件不存在就出错返回
2. 以 w 或w+方式fopen一个文件时,如果文件已存在就截断, 以写的方式open一个文件时, 必须明确指定O_TRUNC才会截断文件,否则直接在原来的数据上改写
注意事项 : 文件的权限是由open的mode 参数和当前进程的umask掩码共同决定的
12. ssize_t close(int fd); :成功返回0, 失败返回-1
13.ssize_t read(int fd, void *buf, size_t count);
1. 从终端设备读,通常以行为单位, 读到换行符就返回了,
2. 从网络读, 根据不同的传输层协议和内核缓存机制,返回值可能小于请求的字节数
3.读常规文件时, 在读到count字节之前已达到文件末尾。 例子: 距离文件末尾还有30个字节而请求读100个字节,则read返回30,下次read返回0
14.ssize_t write(int fd, const void *buf, size_t count);
返回值是写入的字节数, 若出错返回 -1.写常规文件时, write的返回值通常等于请求写的字符数count, 向设备或网络写则不一定