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で質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# c言語の問題の説明、各所ごとに 5 2023/07/26 11:03
- C言語・C++・C# #include <stdio.h>int main(void) { int buf[100] = 6 2022/11/01 22:45
- C言語・C++・C# c言語の問題です 3 2023/01/10 16:15
- C言語・C++・C# C言語 プログラミング 4 2022/05/22 11:53
- その他(プログラミング・Web制作) python flask から fastapiへの移行時のエラー対処 1 2023/02/05 12:26
- C言語・C++・C# プログラミングの授業の課題です 1 2023/01/17 22:15
- C言語・C++・C# バイナリファイルをコピーするのにかかる時間を測りたいのですが実行するとFatel error:gli 2 2022/11/03 01:10
- C言語・C++・C# このプログラミング誰か教えてくれませんか 1 2022/06/02 15:27
- C言語・C++・C# C言語のエラーについて 2 2022/07/11 13:56
- その他(プログラミング・Web制作) pythonのエラーについて 2 2022/08/17 17:17
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Expression: nptr != NULL
-
プログラミングが分かりません。
-
C言語のエラーについて
-
プログラムがエラーが出る原因
-
'printf':識別子が見つかりませ...
-
コマンドライン引数について。
-
分割コンパイルの手順と方法に...
-
C言語で自作ヘッダーを作ったの...
-
クレーンでのCFブレーキとな...
-
オシロスコープのDCとAC
-
互いに素と負の数
-
入力容量(Input Capacitance)...
-
16進数を正負反転する方法
-
複数のシリンダーの同調化にコ...
-
SPI 非言語の問題です
-
自動制御で言う【遅れ】とは。
-
音声波形を表示する
-
3bit2進加算器について全加算機...
-
パターン効果/裾引き(アイパタ...
-
数学:図形問題について 先日、...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
プログラミングが分かりません。
-
C言語のエラーについて
-
'printf':識別子が見つかりませ...
-
3×3のラテン方陣をつくるプログ...
-
プログラムがエラーが出る原因
-
TCP/IP: 非ソケットに対するソ...
-
Expression: nptr != NULL
-
加減剰余のオーバーフローについて
-
getch / putch用のヘッダ
-
コマンドライン引数について。
-
C言語のソースコードについて教...
-
C言語初心者です。計算がうまく...
-
C言語 コンパイルエラー(文字...
-
C言語 遺伝的アルゴリズムでの...
-
C言語で自作ヘッダーを作ったの...
-
リターンキー又は、スペースキ...
-
以下の問題のプログラムを教え...
-
c言語入門
-
C/C++ return文で関数の返却値...
-
c言語プログラミングで初項を1....
おすすめ情報