C 影响早期代码执行的以下代码
我正在为一个班级做一个项目,我运行过几次,效果很好。突然间,在仅仅更改了它正在读取的文本文件之后,它就停止了工作。我运行它,它只是永远运行。我在顶部添加了一个printf,以开始了解是什么吸引了我。当我编译并运行printf没有激活时,什么也没发生。当注释掉我的代码主体、编译并运行它时,printf工作得很好。我从未见过这样的事。怎么会这样?代码如下:C 影响早期代码执行的以下代码,c,sockets,network-programming,C,Sockets,Network Programming,我正在为一个班级做一个项目,我运行过几次,效果很好。突然间,在仅仅更改了它正在读取的文本文件之后,它就停止了工作。我运行它,它只是永远运行。我在顶部添加了一个printf,以开始了解是什么吸引了我。当我编译并运行printf没有激活时,什么也没发生。当注释掉我的代码主体、编译并运行它时,printf工作得很好。我从未见过这样的事。怎么会这样?代码如下: #include <stdio.h> #include <stdlib.h> #include <unistd.h
#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;
}
您描述的问题(当您在代码的其余部分进行注释时,
printf
未输出)的常见原因是,stdout
未被刷新。您可以通过在printf
之后添加显式刷新来解决此问题
fflush(stdout);
由于您的问题不清楚您对哪个printf
有问题,因此我也会仔细检查stderr
fflush(stderr);
它有什么不正确之处?通常,如果某个东西随机出现故障,请检查内存错误。使用
-Werror-Wall-Wextra-g-O0-fsanizize=address编译并运行它。谢谢,但是代码在第二次ping之后仍然会一直循环。看起来您的程序取决于堆栈缓冲区是否在适合您的位置有'\0'
s。printf()
的引入可能已经改变了很多事情,使得未初始化的缓冲区中有不同的东西。尝试初始化它们。使用调试符号编译程序并在调试器下运行。当它看起来像是处于卡滞状态时,中断程序,看看它卡在哪一行代码上。
fflush(stderr);