【发布时间】:2015-04-28 06:21:54
【问题描述】:
我正在为一个班级做一个项目,我运行了几次,它运行良好。突然之间,在只更改了它正在读取的文本文件之后,它就停止了工作。我运行它,它只是永远运行。我在顶部添加了一个 printf 以开始查看束缚我的东西。当我编译并运行 printf 没有激活时,什么也没发生。当注释掉我的代码主体、编译并运行它时,printf 工作正常。我从来没有见过这样的事情。怎么会这样?代码如下:
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netdb.h>
void error(const char *msg)
{
perror(msg);
exit(0);
}
int main(int argc, char* argv[])
{
int sockfd, portno, n;
struct sockaddr_in serv_addr;
struct hostent *server;
FILE *list = fopen("pwlist1.txt","r");
if (list == NULL) {
printf("File fail\n");
exit(1);
}
const size_t line_size = 30;
char* line = malloc(line_size);
char buffer[256];
strcpy(buffer,"FAILURE: ");
while (fgets(line, line_size, list) != NULL && strstr(buffer, "FAILURE:") != NULL) {
portno = 48579;
sockfd = socket(AF_INET, SOCK_STREAM, 0);
if (sockfd < 0)
error("ERROR opening socket");
server = gethostbyname("elnux1.cs.umass.edu");
if (server == NULL) {
fprintf(stderr,"ERROR, no such host\n");
exit(0);
}
bzero((char *) &serv_addr, sizeof(serv_addr));
serv_addr.sin_family = AF_INET;
bcopy((char *)server->h_addr,
(char *)&serv_addr.sin_addr.s_addr,
server->h_length);
serv_addr.sin_port = htons(portno);
if (connect(sockfd,(struct sockaddr *) &serv_addr,sizeof(serv_addr)) < 0)
error("ERROR connecting");
n = write(sockfd,"bloop",strlen("bloop"));
if (n < 0)
error("ERROR writing to socket");
bzero(buffer,256);
n = read(sockfd,buffer,255);
if (n < 0)
error("ERROR reading from socket");
n = write(sockfd,"667057",strlen("667057"));
if (n < 0)
error("ERROR writing to socket");
bzero(buffer,256);
n = read(sockfd,buffer,255);
if (n < 0)
error("ERROR reading from socket");
n = write(sockfd,line,strlen(line));
if (n < 0)
error("ERROR writing to socket");
bzero(buffer,256);
n = read(sockfd,buffer,255);
if (n < 0)
error("ERROR reading from socket");
}
if (strstr(buffer, "FAILURE:") == NULL) printf("You did it! The word is: %s\n",line);
else printf("Failure.\n");
close(sockfd);
return 0;
}
pwlist1.txt 的内容:
test
hi
【问题讨论】:
-
这有什么不妥之处?
-
作为一项规则,如果某事随机失败,请检查内存错误。使用
-Werror -Wall -Wextra -g -O0 -fsanitize=address编译并运行它。 -
谢谢,但在第二次 ping 之后代码仍然会永远循环。
-
看起来您的程序取决于您的堆栈缓冲区,其中
'\0's 位于适合您的位置。printf()的引入可能已经充分改变了事情,以至于您的未初始化缓冲区中有不同的东西。尝试初始化它们。 -
使用调试符号编译程序并在调试器下运行。当它似乎处于卡住状态时,退出程序并查看它卡在哪一行代码。
标签: c sockets network-programming