【问题标题】:Code below affecting execution of earlier code下面的代码会影响早期代码的执行
【发布时间】: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


【解决方案1】:

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

fflush(stdout);

由于您的问题并不清楚您到底遇到了哪个printf,因此我也会刷新stderr

fflush(stderr);

【讨论】:

    猜你喜欢
    • 2019-02-17
    • 2022-01-23
    • 2016-07-22
    • 2021-09-17
    • 1970-01-01
    • 2011-11-10
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多