UDP与TCP的服务端、客户端的建立及注意点

使用UDP

服务端
  • bind : 服务器端需要使用 bind 将套接字绑定到特定的端口和IP地址(通常是 INADDR_ANY),这样它才能接收发送到这个端口的数据包。
  • 不需要 listenaccept: 因为UDP是无连接的协议,服务器不需要监听连接或接受连接。
客户端
  • 不需要 bind: UDP客户端通常不需要显式地绑定端口。系统会自动为客户端选择一个临时端口。
  • 不需要 listenaccept: 因为UDP是无连接的协议,客户端只需要知道服务器的IP地址和端口,然后直接发送数据即可。

使用TCP

服务端
  • bind : 服务器需要使用 bind 将套接字绑定到特定的端口和IP地址,以便接收连接请求。
  • listen : 绑定端口后,服务器需要调用 listen 函数,使套接字进入监听状态,准备接受连接请求。
  • accept : 当有客户端连接请求时,服务器使用 accept 函数接受连接,并创建一个新的套接字用于通信。
客户端
  • connect : TCP客户端不需要显式地绑定端口。客户端调用 connect 函数,系统会自动分配一个端口并连接到服务器的IP地址和端口。
  • 不需要 listenaccept: 客户端只需要建立连接,不需要监听和接受连接。

示例代码

UDP服务器
cpp 复制代码
bool CUdpServer::CreateSocket()
{
    WSADATA wsaData;
    if (0 != WSAStartup(MAKEWORD(2, 2), &wsaData))
    {
        return false;
    }

    m_Socket = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
    if (INVALID_SOCKET == m_Socket)
    {
        return false;
    }

    sockaddr_in address;
    address.sin_family = AF_INET;
    address.sin_port = htons(m_nPort);
    address.sin_addr.s_addr = htonl(INADDR_ANY);
    if (SOCKET_ERROR == bind(m_Socket, (SOCKADDR *)&address, sizeof(address)))
    {
        return false;
    }

    return true;
}

TCP服务器

cpp 复制代码
bool CTcpServer::CreateSocket()
{
    WSADATA wsaData;
    if (0 != WSAStartup(MAKEWORD(2, 2), &wsaData))
    {
        return false;
    }

    m_Socket = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
    if (INVALID_SOCKET == m_Socket)
    {
        return false;
    }

    sockaddr_in address;
    address.sin_family = AF_INET;
    address.sin_port = htons(m_nPort);
    address.sin_addr.s_addr = htonl(INADDR_ANY);
    if (SOCKET_ERROR == bind(m_Socket, (SOCKADDR *)&address, sizeof(address)))
    {
        return false;
    }

    if (SOCKET_ERROR == listen(m_Socket, SOMAXCONN))
    {
        return false;
    }

    return true;
}

TCP客户端

cpp 复制代码
bool CTcpClient::CreateSocket()
{
    WSADATA wsaData;
    if (0 != WSAStartup(MAKEWORD(2, 2), &wsaData))
    {
        return false;
    }

    m_Socket = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
    if (INVALID_SOCKET == m_Socket)
    {
        return false;
    }

    sockaddr_in serverAddress;
    serverAddress.sin_family = AF_INET;
    serverAddress.sin_port = htons(m_nPort);
    serverAddress.sin_addr.s_addr = inet_addr(m_ServerIP);

    if (SOCKET_ERROR == connect(m_Socket, (SOCKADDR *)&serverAddress, sizeof(serverAddress)))
    {
        return false;
    }

    return true;
}

总结:

  • UDP : 服务端需要 bind,客户端直接发送和接收即可。
  • TCP : 服务端需要 bindlisten,客户端需要 connect,不需要 bindlisten
相关推荐
sweet丶11 小时前
iOS开发必备的HTTP网络基础概览
网络协议·ios
老蒋新思维13 小时前
知识IP的长期主义:当AI成为跨越增长曲线的“第二曲线引擎”|创客匠人
大数据·人工智能·tcp/ip·机器学习·创始人ip·创客匠人·知识变现
是娇娇公主~14 小时前
HTTPS【密钥交换+证书校验】流程讲解
网络·网络协议·面试·https·ssl
誰能久伴不乏16 小时前
epoll 学习踩坑:`fcntl` 设置非阻塞到底用 `F_SETFL` 还是 `F_SETFD`?
linux·服务器·网络·c++·tcp/ip
北京耐用通信17 小时前
告别“蜘蛛网”接线!耐达讯自动化PROFIBUS 三路集线器让气缸布线“一拖三”的神操作
人工智能·物联网·网络协议·自动化·信息与通信
小于晏17 小时前
基于Socket实现的主流网络协议汇总
网络·网络协议
阿华hhh18 小时前
Linux系统编程(网络udp)
linux·服务器·c语言·网络·网络协议·udp
HansenPole82518 小时前
元编程笔记
笔记·网络协议·rpc
星哥说事19 小时前
SSL/TLS 证书管理,文件与数据库加密技术
数据库·网络协议·ssl
不知道累,只知道类19 小时前
[故障复盘] 生产环境 HTTP 连接池耗尽导致的“服务假死”分析
网络·网络协议·http