gpt4 book ai didi

c - 写入 Txt Tile 时出错

转载 作者:太空宇宙 更新时间:2023-11-04 08:28:52 25 4
gpt4 key购买 nike

    #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]”。我发现文件已创建..但是,缓冲区中的 String 没有发送到 File.. 而且它也发生在“计算”函数中。

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

最佳答案

您的问题有两种可能性。

第一个在这里:

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

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

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

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

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

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

if(writeFile == NULL)
error_handling("\'writeFile\' could not be opened!");

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

关于c - 写入 Txt Tile 时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29271143/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com