2017-08-02 20 views
-2
#include <sys/socket.h> 
#include <sys/types.h> 
#include <netinet/in.h> 
#include <netdb.h> 
#include <stdio.h> 
#include <arpa/inet.h> 
#include <string.h> 
#include <stdlib.h> 
#include <unistd.h> 
#include <errno.h> 

int main(int argc, char *argv[]){ 

    int sockfd; 
    struct sockaddr_in serv_addr; 
    struct hostent *hp; 
    char buff[100]; 

    //Create socket 
    sockfd = socket(AF_INET, SOCK_STREAM, 0); 
    if(sockfd < 0){ 
     perror("Failed to create socket!"); 
     exit(1); 
    } 

    serv_addr.sin_family = AF_INET; 
    hp = gethostbyname(argv[1]); * 

エラーは上記の行にある可能性がありますが、解決方法がわかりません これです。このエラーを解決するにはどうすればよいですか?

Geany、Linuxでこのコードをコンパイル、ビルド、実行すると、セグメンテーションフォールトエラーメッセージが表示されます。それはどうしてですか、どうすれば解決できますか?

+7

このコードは不完全でコンパイルされません。このような小さなプログラムの中にあるSEGFAULTは、デバッグを始める良いタイミングです。 gdbを使用してコードを実行し、クラッシュが発生した場所を確認します。 – Gerhardh

+1

コマンドライン引数を渡していますか? – skrtbhtngr

+3

あなたは 'argc'が少なくとも2であることを確認しません。 – Gerhardh

答えて

0

私はあなたの問題は、パラメータとしてそれ以外の場合は、このスペースをコンソールに何かを送っているはずここ

hp = gethostbyname(argv[1]); 

をあると思います(ARGV [1])ので、障害が発生したセグメンテーション無効です。

ケースパラメータには、接続しようとしているコンピュータの名前を指定してください。例:

./program hosToConnectTo 

このトリックを行う必要があります。

+0

それははるかに短い解決策でした。 –

0

Linuxを使用する場合は、

ulimit -a 
ulimit -c ulimited // set core file size limitless 

その後、実行可能again.Aコアファイルを実行はcreated.Thisなりセグメンテーションフォールト前の最後のスタックのスナップショットです。

gdb [executable] core 

今、セグメンテーションフォルトが発生する場所を確認できます。

+1

OPは、単にGDBでプログラムを実行し、クラッシュを待つこともできます。ありがとう。 – Gerhardh

0

argc[1]が存在することを確認する必要があります。 シンプル:

if (!argv[1]) 
    return (-1); 

おそらくトリックを行います。

ヒント:ValgrindとGDBは、エラーがどこから来て解決されたかを見つけるのに2つの非常に強力なツールです。

これらのログを読み込むのに慣れるまでには少し時間がかかりますが、一度使い慣れたら、タイムアウトやSegFaultsのほとんどが解決しやすくなるだけでなく、また、メモリリーク、allocs、およびフリーを追跡するので、プログラムのメモリ消費を最適化することができます。

関連する問題