写入 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 指针。只需检查您的文件指针,看看文件是否被正确打开。顺便说一句,无论何时以任何语言打开文件,这都是一个很好的做法。
#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 指针。只需检查您的文件指针,看看文件是否被正确打开。顺便说一句,无论何时以任何语言打开文件,这都是一个很好的做法。