写入 Txt Tile 时出错

Error while writing Txt Tile

    #include<stdio.h>
    #include<stdlib.h>
    #include<string.h>
    #include<unistd.h>
    #include<arpa/inet.h>
    #include<sys/socket.h>

    #define BUF_SIZE 1024       
    #define OPSZ     4        //Bye of int


    void error_handling(char *message);
    int calculate(int opnds[], char  operator, char *message, char * address);

    int main(int argc, char *argv[])
    {
        int serv_sock, clnt_sock;
        int recv_cnt, recv_len;
        int opnd_cnt;
        char opinfo[BUF_SIZE];           
        int result;

        struct sockaddr_in serv_addr;
        struct sockaddr_in clnt_addr;
        socklen_t clnt_addr_size;

        FILE *getFile=fopen("data.txt", "r");
        FILE *writeFile=fopen(argv[1], "w");

        char  buffer[BUF_SIZE]={0,};

        fscanf(getFile, "%s", buffer);
        buffer[BUF_SIZE-1] = 0;

        if(argc!=3)
        {
            printf("Usage : %s <TEXT> <port>\n", argv[0]);
            exit(1);
        }

        if( (fprintf(writeFile, "%s", buffer)) == -1 )      //ERROR!!!       //Copy message to output.txt
            error_handling("fprintf ERROR! ");
        printf("%s\n\n", buffer);

        printf("Server Running...\n");

        serv_sock=socket(PF_INET, SOCK_STREAM, 0);
        if(serv_sock == -1)
            error_handling("socket() error");

        memset(&serv_addr, 0, sizeof(serv_addr));
        serv_addr.sin_family=AF_INET;
        serv_addr.sin_addr.s_addr=htonl(INADDR_ANY);
        serv_addr.sin_port=htons(atoi(argv[2]));

        if(bind(serv_sock, (struct sockaddr*) &serv_addr, sizeof(serv_addr)) == -1)
            error_handling("bind() error");

        if(listen(serv_sock, 5) == -1 )
            error_handling("listen() error");

        clnt_addr_size=sizeof(clnt_addr);

        while(1)            //Iterative Server implement
            {

            recv_len = 0;           

            clnt_sock=accept(serv_sock, (struct sockaddr*) &clnt_addr,                 &clnt_addr_size);
            if(clnt_sock == -1)
                error_handling("accept() error");


            while( (3*OPSZ) > recv_len )
            {
                recv_cnt = read(clnt_sock, &opinfo[recv_len], BUF_SIZE-1);
                recv_len += recv_cnt;
    }

            result = calculate((int*)opinfo, opinfo[recv_len-1], buffer, argv[1]);
            printf("%d", result);   
            write(clnt_sock, (char*)&result, sizeof(result));


            close(clnt_sock);
        }

        close(serv_sock);

        printf("Server Closed \n ");

        fclose(getFile);
        return 0;
    }

    void error_handling(char *buffer)
    {
        fputs(buffer, stderr);
        fputc('\n', stderr);
        exit(1);
    }

    int calculate(int opnds[] ,char operator, char *buffer, char *address)
    {
        int result;
        int i;
        FILE *my_write, *my_append;
        my_write = fopen(address, "w");
        my_append = fopen(address, "a");

        switch(operator)
        {
        case '+':
            result = opnds[1] + opnds[2];
            fprintf(my_append, "%d", result);
            break;
        case '-':
            result = opnds[1] - opnds[2];
            fprintf(my_write, "%d", result);
            break;
        case '*':
            result = opnds[1] * opnds[2];
            fprintf(stdout, "%s\n" ,buffer);
            fprintf(stdout, "%d\n", result);
            break;
        }
        return result;

        fclose(my_write);
        fclose(my_append);
    }               

我写的行有错误"ERROR"我不知道行中有什么问题。

我打算写文件"argv[1]"。我发现文件已创建.. 但是,缓冲区中的字符串并没有发送到文件中。它也发生在 "calculate" 函数中。

为什么我不能写入文件...

您的问题有两种可能性。

第一个在这里:

fscanf(getFile, "%s", buffer);
buffer[BUF_SIZE-1] = 0;

这段代码没有错,它可能只是有点危险,因为它取决于文件是明文并且单词由空格分隔,并且这些单词比分配的缓冲区短。如果您注意到,fscanf 不会询问您的缓冲区大小,因此如果您不小心,您可能会溢出缓冲区(这会非常糟糕地搞砸一切)。现在,none 这可能是你的问题,因为你的缓冲区大小 (1024)

最有可能的候选人是这里的这一行:

FILE *writeFile=fopen(argv[1], "w");

如评论中所述,您甚至没有检查 argv[1] 是否存在(尽管它确实存在是因为您检查以确保您的代码后面有 3 个参数,这应该是第一件事你这样做)更重要的是, argv[1] 是你正在写入的文件。 fopen 将以写入模式创建此文件,但前提是它 can/needs 到。 argv[1] 可能指向您的程序无权访问的文件、被另一个程序锁定的文件或目录中不存在的文件。

谢天谢地,所有这些问题都可以用这个简单的测试来总结:

if(writeFile == NULL)
    error_handling("\'writeFile\' could not be opened!");
如果无法打开指定的文件,

fopen 将 return 一个 NULL 指针。只需检查您的文件指针,看看文件是否被正确打开。顺便说一句,无论何时以任何语言打开文件,这都是一个很好的做法。