Printf在C程序中有异常行为

时间:2014-10-07 15:25:49

标签: c printf

我在Ubuntu上用C创建一个服务器,但是我遇到了一个无法正常工作的printf函数的问题。这是代码。我喜欢终端打印" dd"一旦程序启动,但它没有做任何事情。建议?

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <sys/socket.h>
#include <netdb.h>

void main(){
printf("dd");
int ds_sock;
struct sockaddr_in my_addr;
ds_sock=socket(AF_INET,SOCK_STREAM,0);

memset(&my_addr,0,sizeof(my_addr));
my_addr.sin_family=AF_INET;
my_addr.sin_port=htons(25000);
my_addr.sin_addr.s_addr=INADDR_ANY;

bind(ds_sock,(struct sockaddr *)&my_addr,sizeof(my_addr));

listen(ds_sock,3);
printf("dd");
int ds_sock_acc;
struct sockaddr_in addr;
size_t sin_size = sizeof(struct sockaddr_in);
ds_sock_acc = accept(ds_sock,(struct sockaddr *)&addr,&sin_size);
while(ds_sock_acc==-1) {
    printf("connessione non riuscita");
    ds_sock_acc = accept(ds_sock,(struct sockaddr *)&addr,&sin_size);
}
printf("connessione riuscita");
close(ds_sock);
close(ds_sock_acc);
}

这个(客户端)按预期工作:

void main(){
printf("dd");
int ds_sock;
ds_sock = socket(AF_INET, SOCK_STREAM,0);

int ret;
struct sockaddr_in Eaddr;
Eaddr.sin_family = AF_INET;
Eaddr.sin_port = htons(25000);
Eaddr.sin_addr.s_addr=inet_addr("127.0.0.1");
ret = connect(ds_sock,(struct sockaddr *)&Eaddr,sizeof(Eaddr));
while(ret==-1){ 
    printf("Errore nel connect");
    ret = connect(ds_sock,(struct sockaddr *)&Eaddr,sizeof(Eaddr));
}
printf("connect OK");
close(ds_sock);

}

3 个答案:

答案 0 :(得分:5)

printf的输出将被缓冲。

要立即获得输出,您有两个选择:

  • 在字符串末尾添加换行符(\n)(printf("dd\n");)。这会隐式刷新输出流(即写出缓冲的内容)。

  • 在printf语句(fflush(stdout);)之后显式刷新标准输出流。

至于问题的第二部分,第二个例子产生输出可能只是因为程序是短暂的,并且在程序退出时刷新输出缓冲区。否则,它将具有相同的行为(尝试在最后一次关闭后添加sleep(30)语句以便自己查看。)

答案 1 :(得分:3)

您需要刷新输出。

最简单的方式:

printf("dd\n");

更好的方法:

printf("dd");
fflush(stdout);

答案 2 :(得分:2)

您需要刷新输出流。使用fflush(stdout)