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);
        }
相关推荐
Yeats_Liao2 小时前
Java网络编程(六):NIO vs BIO性能对比与场景选择
java·网络·nio
LeoZY_2 小时前
开源超级终端PuTTY改进之:增加点对点网络协议IocHub,实现跨网段远程登录
运维·网络·stm32·嵌入式硬件·网络协议·运维开发
有趣灵魂4 小时前
在docker中容器使用iptables限制IP访问端口
服务器·tcp/ip·docker·容器
知北游天4 小时前
Linux网络:使用UDP实现网络通信(网络套接字的创建&&绑定)
linux·网络·udp
半桔5 小时前
【网络编程】UDP 编程实战:从套接字到聊天室多场景项目构建
linux·网络·c++·网络协议·udp
IT成长日记5 小时前
【LVS入门宝典】LVS NAT模式实战指南:ip_forward、iptables与SNAT、DNAT规则配置详解
linux·运维·tcp/ip·负载均衡·lvs·nat
hhcgchpspk5 小时前
flask获取ip地址各种方法
python·tcp/ip·flask
Bruce_Liuxiaowei6 小时前
SOCKS与防火墙:穿透与守护的网络安全协奏曲
网络·安全·web安全·网络安全
IT成长日记6 小时前
【LVS入门宝典】LVS-TUN模式原理与配置:跨越网络界限的负载均衡解决方案
linux·网络·负载均衡·lvs·tun