UNIX/gcc。
TCP/IPでチャットプログラムを作っているんですが
ログアウトメッセージなるものを送る前に
sendto() sent a different number of bytes than expected: Socket operation on non-socketというエラーが出ます。
起こる箇所:クライアント
msgStruct.option = htonl(option);
msgStruct.seatLog = htonl(loggedIn);
if (sendto(sock, &msgStruct, sizeof(msgStruct), 0, (struct sockaddr *)
&echoServAddr, sizeof(echoServAddr)) != sizeof(msgStruct)) {
printf("sizeof(msgStruct): %d\n", sizeof(msgStruct));
DieWithError("sendto() sent a different number of bytes than expected");
これはどういうときに起こるのでしょうか?
このエラーが起こり始めたのはファイルの中のポート番号の値を変えてからです。
元通りにポート番号をコマンドの引数から得た値に直せば
このエラーは消えますが、そうするとチャットプログラムとして動作しなくなってしまいます。
//これで各自のクライアントが独自のポート番号を持てます
echoDummyAddr.sin_port = 29990 + (unsigned short)recordNumber;
//元々はechoServPort = atoi(argv[1]);で得た値を送ってました
loggedIn = logIn(option, msgString, seatLog, inet_ntoa(echoClntAddr.sin_addr), echoDummyAddr.sin_port);
関数側(端折ってます):
int logIn(int option, char *id, int loggedIn, char *ip, unsigned short portNum)
{
FILE *file_ptr;
user record_file;
record_file.portNum = portNum;
fwrite(&record_file, sizeof(record_file), 1, file_ptr);
fclose(file_ptr);
}
return loggedIn;
}
小さなヒントでもいいですから、どうか宜しくお願いします。
No.2ベストアンサー
- 回答日時:
このエラー(Socket operation on non-socket)
がでるのは、sockの値が破壊され、0になっていると考えられます。
sockはint型で確保されているはずので、printf文で、
sentoを呼び出す前に、sockの内容を表示してみては如何でしょうか。(エラーが発生したときに表示でもかまいませんが)
また、力づくになりますが、いたるところにprintf文をいれる方法もあります。
printf("sock=%d\n",sock);
又は、
sock = socket()のあとで
sock_save = sockとして(sock_saveはint型)
if (sock != sock_save) printf("sock=%d\n",sock);
とする手もあります。(sockが破壊された時に印字される)
そのとき
printf("src=%s line=%d sock=%d\n",__FILE__,__LINE__,sock);とすると、このprintfを実行した、ソース名と行番号も表示されますので、この方がよいかもしれません。
>>sockはint型で確保されているはずので
>>printf("src=%s line=%d sock=%d\n",__FILE__,__LINE__,sock);とすると、このprintfを実行した、ソース名と行番号も表示されますので
なるほど、勉強になりました。
お陰様で解決しました。
と今頃お礼してみます。
ありがとうございました!
No.1
- 回答日時:
こんにちは
Socket()作成の部分は見えないので、なんともいえないですが、sockという変数は本当にSocket作成した変数ですか?
ちなみに、標準errnoの定義だと上記のエラーは:
ENOTSOCK
非ソケットに対するソケット操作です (Socket operation on non-socket)
と定義されています。
可能性としては
(1)sockは本当のSocketハンドルではない
(2)select()の時、fd_setのメンバーには間違ってるメンバーが含まれている
ですね。
ありがとうございます。
はい、sockは
/* Create a datagram/UDP socket */
if ((sock = socket(PF_INET, SOCK_DGRAM, IPPROTO_UDP)) < 0) //←UDPです、はい
DieWithError("socket() failed");
のように正しく作成されていると思います。
現にloginや自前のwhoコマンドなどでもこのsockを使ってメッセージを送ってますが
正しく動作しています。
書き忘れていましたが、チャット部分はTCP/IPですが
それまでのメニューはUDPを使っていて、このエラー箇所もUDPのソケットです。
あと、このプログラムではselect()は使っていませんね。
sockの内容を確認する方法はないでしょうか?
もしそんな方法があるのならその行を至るところに埋め込んで
変化したところを見れば何が悪さをしているのか見つけられるはずです。
それとも他に解決方法がありますでしょうか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
- ・ゆるやかでぃべーと タイムマシンを破壊すべきか。
- ・「I love you」 をかっこよく翻訳してみてください
- ・歩いた自慢大会
- ・許せない心理テスト
- ・字面がカッコいい英単語
- ・昔のあなたへのアドバイス
- ・かっこよく答えてください!!
- ・あなたが好きな本屋さんを教えてください
- ・これ何て呼びますか Part2
- ・人生で一番思い出に残ってる靴
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・初めて自分の家と他人の家が違う、と意識した時
- ・単二電池
- ・チョコミントアイス
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
プログラムがエラーが出る原因
-
C言語で自作ヘッダーを作ったの...
-
クレーンでのCFブレーキとな...
-
物理の波についてです 時刻12/8...
-
減衰係数の求め方がわかりません
-
等式4m+5n=75を満たす自然数の...
-
音声を重畳するとは・・・
-
オシロスコープを起動しただけ...
-
CPUの波形が0%と100%を行き来...
-
電気回路の「干渉を引き起こす...
-
複数のシリンダーの同調化にコ...
-
SPI 非言語の問題です
-
自動制御で言う【遅れ】とは。
-
互いに素と負の数
-
数学Aの問題です。 答えは、左...
-
古典制御のゲイン交差周波数と...
-
二つの波形の合致を調べる方法は?
-
物理の問題なのですが、この問...
-
ブリッジ整流波形のオシロスコ...
-
順列、4桁の整数をつくる問題
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
TCP/IP: 非ソケットに対するソ...
-
3×3のラテン方陣をつくるプログ...
-
'printf':識別子が見つかりませ...
-
c言語プログラミングで初項を1....
-
加減剰余のオーバーフローについて
-
リターンキー又は、スペースキ...
-
Expression: nptr != NULL
-
プログラムがエラーが出る原因
-
コンソールAPIのSetConsoleScre...
-
C言語で自作ヘッダーを作ったの...
-
プログラミングが分かりません。
-
C言語初心者です。計算がうまく...
-
下記のプログラムを実行したと...
-
以下の問題のプログラムを教え...
-
コンパイルがうまくいかない件
-
C言語 文字列の中の文字が条件...
-
C++ なのですがエラーが消えません
-
エラーの原因がわかりません。
-
Linux Ubuntu18.04.3でTcoipに...
-
C言語のエラーについて
おすすめ情報