Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/c/65.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
ion正在查找返回值0。建议更正函数之间的接口。哪一行代码触发访问冲突?在代码的其他问题中,argc是一个简单的整数。你可以整天传递这个整数,而不需要知道它的地址argv[]已经是指针。您可以整天传递该指针,而不必记录它的地址。这一行:\define\u _C_Winsock_Getaddrinfo - Fatal编程技术网

ion正在查找返回值0。建议更正函数之间的接口。哪一行代码触发访问冲突?在代码的其他问题中,argc是一个简单的整数。你可以整天传递这个整数,而不需要知道它的地址argv[]已经是指针。您可以整天传递该指针,而不必记录它的地址。这一行:\define\u

ion正在查找返回值0。建议更正函数之间的接口。哪一行代码触发访问冲突?在代码的其他问题中,argc是一个简单的整数。你可以整天传递这个整数,而不需要知道它的地址argv[]已经是指针。您可以整天传递该指针,而不必记录它的地址。这一行:\define\u ,c,winsock,getaddrinfo,C,Winsock,Getaddrinfo,ion正在查找返回值0。建议更正函数之间的接口。哪一行代码触发访问冲突?在代码的其他问题中,argc是一个简单的整数。你可以整天传递这个整数,而不需要知道它的地址argv[]已经是指针。您可以整天传递该指针,而不必记录它的地址。这一行:\define\u CRT\u SECURE\u NO\u WARNINGS,然后“include guard”将生成该@define的多个定义。一般来说,应完全避免使用前导下划线,因为编译器会根据编译步骤在所有标识符前加上1、2或3个前导下划线。源代码中此类“用


ion正在查找返回值0。建议更正函数之间的接口。哪一行代码触发访问冲突?在代码的其他问题中,
argc
是一个简单的整数。你可以整天传递这个整数,而不需要知道它的地址<代码>argv[]已经是指针。您可以整天传递该指针,而不必记录它的地址。这一行:
\define\u CRT\u SECURE\u NO\u WARNINGS
,然后“include guard”将生成该@define的多个定义。一般来说,应完全避免使用前导下划线,因为编译器会根据编译步骤在所有标识符前加上1、2或3个前导下划线。源代码中此类“用户”提供的前导下划线可能会给编译器带来混乱。(虽然大多数现代编译器都能处理这个问题,但为什么要让事情变得困难呢)您可能希望通过google或Wikipedia查找“三星程序员”的定义函数:
win32_connect()
在连接失败时返回“1”,但是
main()
函数正在查找返回值0。建议更正函数之间的接口。哪一行代码触发访问冲突?在代码的其他问题中,
argc
是一个简单的整数。你可以整天传递这个整数,而不需要知道它的地址<代码>argv[]已经是指针。您可以整天传递该指针,而不必记录它的地址。这一行:
\define\u CRT\u SECURE\u NO\u WARNINGS
,然后“include guard”将生成该@define的多个定义。一般来说,应完全避免使用前导下划线,因为编译器会根据编译步骤在所有标识符前加上1、2或3个前导下划线。源代码中此类“用户”提供的前导下划线可能会给编译器带来混乱。(虽然大多数现代编译器都能处理这个问题,但为什么要让事情变得困难呢)您可能希望通过google或Wikipedia查找“三星程序员”的定义函数:
win32_connect()
在连接失败时返回“1”,但是
main()
函数正在查找返回值0。建议更正函数之间的接口。哪一行代码触发访问冲突?在代码的其他问题中,
argc
是一个简单的整数。你可以整天传递这个整数,而不需要知道它的地址<代码>argv[]已经是指针。您可以整天传递该指针,而不必记录它的地址。这一行:
\define\u CRT\u SECURE\u NO\u WARNINGS
,然后“include guard”将生成该@define的多个定义。一般来说,应完全避免使用前导下划线,因为编译器会根据编译步骤在所有标识符前加上1、2或3个前导下划线。源代码中此类“用户”提供的前导下划线可能会给编译器带来混乱。(虽然大多数现代编译器都能处理这个问题,但为什么要让事情变得困难呢)您可能希望通过google或Wikipedia查找“三星程序员”的定义函数:
win32_connect()
在连接失败时返回“1”,但是
main()
函数正在查找返回值0。建议更正功能之间的接口。
argc = 2, argv[1] = "localhost", PORT = 27015
win32_connect(&argc, &argv, PORT);
win32_connect(int *argc, char** argv[], int port)
{
    ...
    iResult = getaddrinfo(argv[1], port, &hints, &result); <- Access Violation
    ...
}
#define _CRT_SECURE_NO_WARNINGS
#ifndef CHEADER_H
#define CHEADER_H

//- Includes
#include <sys/types.h>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <errno.h>
#include <fcntl.h>

//- OS specific includes
#ifdef _WIN32
    #define WIN32_LEAN_AND_MEAN
    #include <windows.h>
    #include <winsock2.h>
    #include <ws2tcpip.h>
    #pragma comment (lib, "Ws2_32.lib")
    #pragma comment (lib, "Mswsock.lib")
    #pragma comment (lib, "AdvApi32.lib")
#endif
....
int main(int argc, char *argv[])
{
    //- Define variables
    int connected = 1;
    int sockfd;
    char cSend[BUF];
    char cRecv[BUF];

    //- Create socket + Connect to server
    if ((sockfd = win32_connect(argc, argv, PORT)) < 0) {
        printf("Failed to connect to server.");
        exit(1);
    }
    ...
}
#include "cHeader.h"

#ifdef LINUX
    ...irrelevant unix code...
#endif

#ifdef _WIN32
int win32_connect(int argc, char* argv[], int port)
{
    WSADATA wsaData;
    SOCKET ConnectSocket = INVALID_SOCKET;
    struct addrinfo *result = NULL,
        *ptr = NULL,
        hints;
    char *sendbuf = "this is a test";
    char recvbuf[BUF];
    int iResult;
    int recvbuflen = BUF;

    // Validate the parameters
    if (argc != 2) {
        //printf("usage: %s server-name\n", argv[0]);
        return 1;
    }

    // Initialize Winsock
    iResult = WSAStartup(MAKEWORD(2, 2), &wsaData);
    if (iResult != 0) {
        printf("WSAStartup failed with error: %d\n", iResult);
        return 1;
    }

    ZeroMemory(&hints, sizeof(hints));
    hints.ai_family = AF_UNSPEC;
    hints.ai_socktype = SOCK_STREAM;
    hints.ai_protocol = IPPROTO_TCP;

    // Resolve the server address and port
    iResult = getaddrinfo(argv[1], port, &hints, &result);
    if (iResult != 0) {
        printf("getaddrinfo failed with error: %d\n", iResult);
        WSACleanup();
        return 1;
    }

    // Attempt to connect to an address until one succeeds
    for (ptr = result; ptr != NULL; ptr = ptr->ai_next) {

        // Create a SOCKET for connecting to server
        ConnectSocket = socket(ptr->ai_family, ptr->ai_socktype,
            ptr->ai_protocol);
        if (ConnectSocket == INVALID_SOCKET) {
            printf("socket failed with error: %ld\n", WSAGetLastError());
            WSACleanup();
            return 1;
        }

        // Connect to server.
        iResult = connect(ConnectSocket, ptr->ai_addr, (int)ptr->ai_addrlen);
        if (iResult == SOCKET_ERROR) {
            closesocket(ConnectSocket);
            ConnectSocket = INVALID_SOCKET;
            continue;
        }
        break;
    }

    freeaddrinfo(result);

    if (ConnectSocket == INVALID_SOCKET) {
        printf("Unable to connect to server!\n");
        WSACleanup();
        return 1;
    }

    return ConnectSocket;
}
#endif
int win32_connect(int argc, char *argv[], int port)
win32_connect(argc, argv, PORT);
#define PORT 1234
#define PORT "1234"
int win32_connect(int argc, char* argv[], const char *port)