Udp 和 Tcp socket的一般编程套路(笔记)

一. Udp套路:

第一步:创建套接字

第二步:配置服务器地址信息

第三步:绑定套接字

cpp 复制代码
void init()
    {
        _socketfd = socket(AF_INET,SOCK_DGRAM,0);//第一步 创建套接字
        //AF_INET:使用IPv4协议
        //SOCK_DGRAM就是数据报
        // UDP - 不需要建立连接
        // 直接发送数据,无需connect()
        struct sockaddr_in addr;//第二步 配置服务器地址信息
        memset(&addr,0,sizeof(addr));
        addr.sin_family = AF_INET;
        addr.sin_port = htons(_port);      
        addr.sin_addr.s_addr = INADDR_ANY;
        socklen_t size = sizeof(addr);
        if(bind(_socketfd,(struct sockaddr*)&addr,size) < 0)//第三步 绑定套接字
        {
            LOG(level::FATAL)<<"bind false";
            exit(1);
        }
        LOG(level::INFO)<<"bind success";
        
    }

就可以运行了

cpp 复制代码
 void start()
    {
        while(1)
        {
            char buff[512];
            struct sockaddr_in addrin;
            socklen_t sizein = sizeof(addrin);
            ssize_t n = recvfrom(_socketfd,buff,sizeof(buff)-1,0,(struct sockaddr*)&addrin,&sizein);//从套接字中获取信息
            if(n > 0)
            {
                buff[n] = 0;
                LOG(level::DEBUG)<<buff;
                
                std::string message;
                message = "server say# ";
                message += buff;
                ssize_t m = sendto(_socketfd,message.c_str(),message.size(),0,(struct sockaddr*)&addrin, sizein);//从套接字中发送信息
            }
            
        }
    }

二.Tcp套路:

  1. 创建Socket

  2. 绑定地址

  3. 开始监听

cpp 复制代码
    void Init()
    {
        _listenfd = socket(AF_INET,SOCK_STREAM,0);//第一步 获取监听套接字
        //SOCK_STREAM 数据流
        if(_listenfd < 0)
        {
            LOG(level::FATAL)<<"Socket false";
            exit(SOCKER_ERR);
        }

        LOG(level::INFO)<<"socket success "<<_listenfd;
        Inetaddr saddr(_port);
        int n = bind(_listenfd,(const struct sockaddr*)&saddr.Getaddr(),sizeof(saddr.Getaddr()));//第二步 绑定服务端
        if(n == -1)
        {
            LOG(level::FATAL)<<"bind false";
            exit(BIND_ERR);
        }

        if(listen(_listenfd,defbacklog) < 0)//第三步 监听
        {
            LOG(level::FATAL)<<"listen false";
            exit(LISTEN_ERR);
        }

    }
  1. accept 从监听listen fd获取远端的套接字
cpp 复制代码
         while(_Isrunning)
        {
            struct sockaddr_in peer;//建立远端来接受远端信息
            socklen_t sz = sizeof(peer);
            int sfd = accept(_listenfd,(sockaddr*)&peer,&sz);
            //从监听fd获取远端的套接字
            if(sfd < 0)
            {
                LOG(level::ERROR)<<"accept false";
                exit(ACCEPT_ERR);
            }
            LOG(level::DEBUG)<<"accept success "<<sfd;
            Inetaddr local(peer);
            //下面是我自己线程的执行,不用理
            ThreadData* thdata = new ThreadData(sfd,local,this);
            pthread_t th1;
            pthread_create(&th1,nullptr,Routine,thdata);
        }
相关推荐
运维行者_6 小时前
企业无线网络监控的挑战与智能化演进趋势
大数据·运维·服务器·网络·数据库
国强_dev7 小时前
技术探讨:使用 stunnel 加密转发数据库连接时,如何获取客户端真实 IP?
数据库·网络协议·tcp/ip
Coder_Shenshen8 小时前
西门子S7CommPlus协议鉴权算法原理与流程详解
网络·后端·算法
HavenlonLabs11 小时前
Havenlon 对抗性完整(十七):安全不是“防住攻击”,而是控制失败方式
网络·人工智能·架构·安全威胁分析·安全架构·havenlon
fei_sun11 小时前
路径MTU发现
linux·运维·网络
tachibana213 小时前
hot100 回文链表(234)
java·网络·数据结构·leetcode·链表
从零开始的代码生活_14 小时前
NAT、代理服务与内网穿透详解
linux·服务器·网络·c++·http·智能路由器
云栖梦泽在14 小时前
Claude Code / Codex 使用卡顿怎么办?AI 编程 Agent 连接失败与网络排查思路
网络·人工智能·网络协议·chatgpt·性能优化
Jeremy_WW14 小时前
QSFP-DD MSA Hardware协议解读(二)
网络·模块测试·智能硬件
深盾科技_Virbox14 小时前
加密狗授权能力选型:从授权模型到全生命周期管理
java·网络·数据库