C 影响早期代码执行的以下代码

C 影响早期代码执行的以下代码,c,sockets,network-programming,C,Sockets,Network Programming,我正在为一个班级做一个项目,我运行过几次,效果很好。突然间,在仅仅更改了它正在读取的文本文件之后,它就停止了工作。我运行它,它只是永远运行。我在顶部添加了一个printf,以开始了解是什么吸引了我。当我编译并运行printf没有激活时,什么也没发生。当注释掉我的代码主体、编译并运行它时,printf工作得很好。我从未见过这样的事。怎么会这样?代码如下: #include <stdio.h> #include <stdlib.h> #include <unistd.h

我正在为一个班级做一个项目,我运行过几次,效果很好。突然间,在仅仅更改了它正在读取的文本文件之后,它就停止了工作。我运行它,它只是永远运行。我在顶部添加了一个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;
}

您描述的问题(当您在代码的其余部分进行注释时,
printf
未输出)的常见原因是,
stdout
未被刷新。您可以通过在
printf
之后添加显式刷新来解决此问题

fflush(stdout);
由于您的问题不清楚您对哪个
printf
有问题,因此我也会仔细检查
stderr

fflush(stderr);

它有什么不正确之处?通常,如果某个东西随机出现故障,请检查内存错误。使用
-Werror-Wall-Wextra-g-O0-fsanizize=address编译并运行它。谢谢,但是代码在第二次ping之后仍然会一直循环。看起来您的程序取决于堆栈缓冲区是否在适合您的位置有
'\0'
s。
printf()
的引入可能已经改变了很多事情,使得未初始化的缓冲区中有不同的东西。尝试初始化它们。使用调试符号编译程序并在调试器下运行。当它看起来像是处于卡滞状态时,中断程序,看看它卡在哪一行代码上。
fflush(stderr);