質問

私はVS2008とWin7でC ++で働いています。

プログラムを調べている間、私は作成されたスレッドに従っていましたが、gethostbyname()はそれ自体のスレッドを作成するようです。理由を説明してもらえますか?

MSDNについては、「GethostbyName関数によって返されるホステント構造のメモリは、Thread LocalストレージからWinsock DLLによって内部的に割り当てられています。」

このメモリは視覚的なスタジオをだまして、それがスレッドだと考えていますか?

編集:からです このリンク, また、私の観察から、これは接続関数でも起こるということです。これは通常の動作だと思います。

以下のコードはMSDN [gethostbynameページ]からのもので、同じ動作を示します。

int main(int argc, char **argv)    
{    
    //-----------------------------------------
    // Declare and initialize variables
    WSADATA wsaData;
    int iResult;

    DWORD dwError;
    int i = 0;

    struct hostent *remoteHost;
    char *host_name;
    struct in_addr addr;

    char **pAlias;

    // Validate the parameters
    if (argc != 2) {
        printf("usage: %s hostname\n", argv[0]);
        printf("  to return the IP addresses for the host\n");
        printf("       %s www.contoso.com\n", argv[0]);
        printf(" or\n");
        printf("       %s IPv4string\n", argv[0]);
        printf("  to return an IPv4 binary address for an IPv4string\n");
        printf("       %s 127.0.0.1\n", argv[0]);
        return 1;
    }
    // Initialize Winsock
    iResult = WSAStartup(MAKEWORD(2, 2), &wsaData);
    if (iResult != 0) {
        printf("WSAStartup failed: %d\n", iResult);
        return 1;
    }

    host_name = argv[1];

    printf("Calling gethostbyname with %s\n", host_name);
    remoteHost = gethostbyname(host_name);

    if (remoteHost == NULL) {
        dwError = WSAGetLastError();
        if (dwError != 0) {
            if (dwError == WSAHOST_NOT_FOUND) {
                printf("Host not found\n");
                return 1;
            } else if (dwError == WSANO_DATA) {
                printf("No data record found\n");
                return 1;
            } else {
                printf("Function failed with error: %ld\n", dwError);
                return 1;
            }
        }
    } else {
        printf("Function returned:\n");
        printf("\tOfficial name: %s\n", remoteHost->h_name);
        for (pAlias = remoteHost->h_aliases; *pAlias != 0; pAlias++) {
            printf("\tAlternate name #%d: %s\n", ++i, *pAlias);
        }
        printf("\tAddress type: ");
        switch (remoteHost->h_addrtype) {
            case AF_INET:
                printf("AF_INET\n");
            break;
            case AF_NETBIOS:
                printf("AF_NETBIOS\n");
            break;
            default:
                printf(" %d\n", remoteHost->h_addrtype);
            break;
        }
        printf("\tAddress length: %d\n", remoteHost->h_length);

        i = 0;
        if (remoteHost->h_addrtype == AF_INET)
        {
            while (remoteHost->h_addr_list[i] != 0) {
                addr.s_addr = *(u_long *) remoteHost->h_addr_list[i++];
                printf("\tIP Address #%d: %s\n", i, inet_ntoa(addr));
            }
        }
        else if (remoteHost->h_addrtype == AF_NETBIOS)
        {   
            printf("NETBIOS address was returned\n");
        }   
    }
    return 0;
}
役に立ちましたか?

解決

afaik、gethostbynameブロック。

Winsockはしばしばいくつかのヘルパースレッドを作成します。

他のヒント

いいえ、スレッドローカルストレージは、新しいスレッドのスタートアップとは無関係です。

スレッドは、呼び出しスレッドの再び危機に影響を与えることなく非同期コールバックを使用する必要があるなど、GethostbyName APIのサブ操作に関するスレッドの影響の問題のために必要になる場合があります。

または、Winsock操作のサブセットに必要なデーモンスレッドが必要なWinsockの怠zyな初期化機能である可能性があり、これはデーモンを必要とする最初のAPIでした。

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top