質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

Q&A

解決済

1回答

3206閲覧

recvfrom関数に正しいソケットディスクリプタを渡すとその前のprintfが効かない

toroleaman

総合スコア95

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

0グッド

0クリップ

投稿2015/10/17 11:18

編集2015/10/17 11:21

UDP通信用にデータ受信サーバを作ろうとしていますが、
どのPORTで動作しているのかソケットディスクリプタがいくつなのかをprintfしようとしていますが、
printfでコンソールにログが表示されません。

★の箇所を
(sockfd, buf, sizeof(buf), 0, (struct sockaddr*)&from, (socklen_t*)&addrlen);
から
recvfrom(0, buf, sizeof(buf), 0, (struct sockaddr*)&from, (socklen_t*)&addrlen);
にすると、コンソール上に
「-addr=0--port=20931--=sock=3====」と出力されます。reecvfrom関数に渡すソケットディスクリプタによってその前に実行されているprintfでのログが出ないなんてことがあり得るのでしょうか。

#include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <getopt.h> #include <sys/types.h> #include <sys/socket.h> #include <netinet/in.h> #include <arpa/inet.h> #include <netdb.h> static int get_socket(int, unsigned long); int main(int argc, char *argv[]) { char buf[12255] = {0,0}; int sockfd = 0; int port = 50001; int len = 0; struct sockaddr_in from; socklen_t addrlen; sockfd = get_socket(port, 0); addrlen = sizeof(struct sockaddr_in); printf("=sock=%d====",sockfd); len = recvfrom(sockfd, buf, sizeof(buf), 0, (struct sockaddr*)&from, (socklen_t*)&addrlen);/*★*/ close(sockfd); return 0; } static int get_socket(int portnum, unsigned long ipaddr) { int sockfd; struct sockaddr_in server; sockfd = socket(AF_INET, SOCK_DGRAM, 0); memset(&server, 0, sizeof(struct sockaddr_in)); server.sin_family = AF_INET; if (ipaddr == 0) { server.sin_addr.s_addr = htonl(INADDR_ANY); printf("-addr=%d--",server.sin_addr.s_addr); } else { server.sin_addr.s_addr = htonl(ipaddr); } server.sin_port = htons(portnum); printf("-port=%d--",server.sin_port); if (bind(sockfd, (struct sockaddr *) &server,sizeof(struct sockaddr_in)) == -1) { close(sockfd); return -1; } return sockfd; }

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

行単位でバッファリングされていると思います。且つrecvfrom()でブロックしているのでプログラムが終了するか、バッファが一杯になるか、改行がくるまで出力されないのだと思います。printf()の後に一行、fflush(stdout)を入れてみてください。

あるいは、setvbuf()という標準関数で行バッファリングを無効にすることもできます。

出力が変わってしまいますが、普通にprintf()の最後に改行'\n'を入れるのもありかと。

投稿2015/10/17 14:06

sharow

総合スコア1149

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

toroleaman

2015/10/18 05:39

なるほど、ffrushでいけました。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問