c - 我如何在不包含 "unistd.h"的情况下使用 read() 和 write() ?

标签 c file-io header-files system-calls unistd.h

我在我的程序中使用了系统调用 read() 和 write(),但没有在程序中包含“unistd.h”头文件。但该程序仍然有效并给出了预期的结果。

运行程序后,我想我会阅读 read() 和 write() 的手册页。

在 read() 和 write() 的 man 2 页面中,SYNOPSIS 部分提到我需要包含 unistd.h 头文件才能使用 read() 或 write()。

SYNOPSIS
   #include <unistd.h>

   ssize_t read(int fd, void *buf, size_t count);


SYNOPSIS
   #include <unistd.h>

   ssize_t write(int fd, const void *buf, size_t count);

虽然我没有包含 unistd.h,但我的程序如何运行,我很惊讶?

下面是我的程序。这是一个使用 read() 和 write() 系统调用将源文件的内容复制到目标文件的程序。

#include<stdio.h>
#include<fcntl.h>
#include<sys/types.h>
#include<sys/stat.h>
#include<stdlib.h>

int main()
{
    /* Declaring the buffer. */
    /* Data read by read() will be stored in this buffer. */
    /* Later when write() is used, write() will take the contents of this buffer and write to the file.*/

    char buffer[512];

    /* Decalring strings to store the source file and target file names. */

    char source[128], target[128];

    /* Declaring integer variables in which integer returned by open() will be stored. */
    /* Note that this program will open a source file, and a target file. So, 2 integers will be needed. */

    int inhandle, outhandle;

    /* Declaring integer variable which will specify how much bytes to read or write.*/

    int bytes;

    /* Taking source filename from keyboard.*/

    printf("\nSource File name: ");
    scanf("%s",source);

    /* Open the source file using open().*/

    inhandle = open(source, O_RDONLY);

    /* If there is error while opening source file.*/

    if (inhandle == -1)
    {
            perror("Error opening source file.\n");
            exit(1);
    }

    /* Taking target filename from keyboard.*/

    printf("\nTarget File name: ");
    scanf("%s",target);

    /* Open the target file using open().*/

    outhandle = open(target, O_CREAT | O_WRONLY, 0660);

    /* If there is error while opening target file.*/

    if (outhandle == -1)
    {
            perror("Error opening target file.\n");
            close(inhandle);
            exit(2);
    }

     /* Below code does following:
       1. First reads (at most) 512 bytes from source file
       2. Then copies them to buffer
       3. If bytes read is greater than 0, write the content stored in buffer to target file.
    */

    while((bytes = read(inhandle, buffer, 512)) > 0)
    {
                    write(outhandle, buffer, bytes);
    }

    /* Close both source and target files. */
    close(inhandle);
    close(outhandle);

    return 0;
}

最佳答案

你的程序因为隐式函数声明而工作,read()write() 都返回 ssize_t 并且编译器假定编译器 int 当隐式声明函数时,它可能会像您所知的那样工作。

如果您在启用警告的情况下编译您的程序,那么编译器会使用 gcc 向您发出警告

gcc -Wall -Wextra -Werror

如果发现隐式声明的函数,即没有原型(prototype)的函数,将停止编译。

关于c - 我如何在不包含 "unistd.h"的情况下使用 read() 和 write() ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28549909/

相关文章:

c - 是否需要使用struct为C语言链表中的每个节点分配内存?

c++ - 为什么这在 C 中编译而不是 C++ (sigaction)?

c - 在 C 中使用 fgets 从文件中读取字符串

c - 如何将非标准头文件链接到 C 编译器

c - LCD 库 - MPLAB X

c - 如何重新分配一个空的二维数组

c - 以前工作的 C 代码出现新的段错误

winapi - 从物理硬盘读取数据

c++ - 变量或字段 'name of var'声明为void

c - C 编译器能够跨目标文件进行优化吗?