小威
...

  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, 向设备或网络写则不一定

posted on 2013-09-02 18:52  小威_  阅读(149)  评论(0)    收藏  举报