当前位置: 首页 > article >正文

tcp线程进程多并发

tcp线程多并发

#include<myhead.h>
#define SERPORT 8888
#define SERIP "192.168.0.118"
#define BACKLOG 20
typedef struct 
{
    int newfd;
    struct sockaddr_in cin;
}BMH;
void *fun1(void *sss)
{
     int newfd=accept((BMH *)sss)->newfd;
     struct sockaddr_in cin=((HMY *)sss)->cin;
     char buff[1000];
     while(1)
     {
         bzero(buff,sizeof(buff));
         int len=recv(newfd,buff,sizeof(buff),0);
         printf("收到%s:%d的信息%s\n",inet_ntoa(cin.sin_addr),ntohs(cin.sin_port),buff);
         if(len==0)
         {
             printf("客户端退出");
             break;
         }
         strcat(buff,"xxx");
         send(newfd,buff,sizeof(buff),0);
         printf("发送成功\n");
     }
     pthread_exit(NULL);
}
int main(int argc, const char *argv[])
{
    int oldfd=socket(AF_INET,SOCK_STREAM,0);
    if(oldfd==-1)
    {
        perror("oldfd");
        return -1;
    }
    int bmz=8;
    if(setsockopt(oldfd,SOL_SOCKET,SO_REUSEADDR,&bmz,sizeof(bmz))==-1)
    {
        perror("setsockopt");
        return -1;
    }
    printf("端口快速复用应用成功\n");
    struct sockaddr_in sin={
     .sin_failmy=AF_INET,
     .sin_port=htons(SERPORT),
     .sin_addr.s_addr=inet_addr(SERIP)
    };
    if(bind(oldfd,(struct sockaddr *)&sin,sizeof(sin))==-1)
    {
        perror(bind);
        return -1;
    }
    if(listen(oldfd,BACKLOG)==-1)
    {
        perror("listen");
        return -1;
    }
    printf("监听成功\n");
    struct sockaddr_in cin;
    int cinlen=sizeof(cin);
    BMH MSG;
    while(1)
    {
        int newfd=accept(oldfd,(struct sockaddr *)&cin,&cinlen);
        if(newfd==-1)
        {
            perror("accept");
            return -1;
        }
        printf("%s:%d客户端连接\n",inet_ntoa(cin.sin_addr),ntohs(cin.sin_port));
        MSG.newfd=newfd;
        MSG.cin=cin;
        pthread_t tid;
        if(pthread_create(&tid,NULL,fun1,MSG)!=0)
        {
            perror("pthread_create");
            return -1;
        }
        pthread_detach(tid);
    }

    return 0;
}
 

tcp进程多并发

#include <myhead.h>
#define SERPORT 9999
#define SERIP "192.168.0.130"
#define BACKLOG 10

void hande(int sss)
{
    if(sss==SIGCHLD)
    {
        while(waitpid(-1,NULL,WNOHANG)!=-1);
    }
}

int main(int argc, const char *argv[])
{

#if 1
    if(signal(SIGCHLD,hande)==SIG_ERR)//捕获子进程退出的信号
    {
        perror("signal");
        return -1;
    }
#endif
    int oldfd = socket(AF_INET,SOCK_STREAM,0);//1、创建原始套接字
    if(oldfd ==-1)
    {
        perror("socket");
        return -1;
    }

    int kkk=666;
    if(setsockopt(oldfd,SOL_SOCKET,SO_REUSEADDR,&kkk,sizeof(kkk))==-1)//端口号快速复用
    {
        printf("setsockopt");
        return -1;
    }
    printf("端口快速复用成功\n");
    struct sockaddr_in sin = {
    .sin_family = AF_INET,
    .sin_port = htons(SERPORT),
    .sin_addr.s_addr = inet_addr(SERIP)
    };
    if(bind(oldfd,(struct sockaddr *)&sin,sizeof(sin))==-1)//2、绑定
    {
        perror("bind");
        return -1;
    }
    if(listen(oldfd,BACKLOG)==-1)
    {
        perror("listen");
        return -1;
    }
    //接下来创建子进程,父进程负责接收客户端请求,子进程负责数据收发
    struct sockaddr_in cin;
    int cinlen = sizeof(cin);
    
    while(1)
    {
    int newfd = accept(oldfd,(struct sockaddr *)&cin,&cinlen);    
    if(newfd==-1)
    {
        perror("accept");
        return -1;
    }
    printf("newfd = %d\n",newfd);
    printf("%s:%d连接成功\n",inet_ntoa(cin.sin_addr),ntohs(cin.sin_port));
    pid_t pid = fork();
    if(pid>0)
    {
        close(newfd);
    }
    else if(pid==0)
    {
        close(oldfd);
        char buff[1024];
        while(1)
        {
            int len = recv(newfd,buff,sizeof(buff),0);
            if(len==0)
            {
                printf("客户端退出\n");
                break;
            }
            printf("服务器收到信息:%s\n",buff);
            strcat(buff,"^_^");
            send(newfd,buff,sizeof(buff),0);
            printf("发送成功\n");
        }
        
        exit(0);
    }
    else{
        perror("fork");
        return -1;
    }
    }
    close(oldfd);
    return 0;
}
 


http://www.kler.cn/a/300396.html

相关文章:

  • 【useCallback Hook】在多次渲染中缓存组件中的函数,避免重复创建函数
  • 如何使用MaskerLogger防止敏感数据发生泄露
  • 2024-春秋杯冬季赛
  • vue2使用flv.js在浏览器打开flv格式视频
  • SAP POC 项目完工进度 - 收入确认方式【工程制造行业】【新准则下工程项目收入确认】
  • 数据结构漫游记:动态实现栈(stack)
  • Matlab自学笔记三十五:表table数据与外部文件的读入和写出
  • Navicat 17 新特性 | 聚焦 MongoDB
  • 点餐小程序实战教程05登录界面搭建
  • Java 中处理 XML 文件
  • NIO详细解释
  • DSC+DW自动安装工具
  • python科学计算:NumPy 线性代数与矩阵操作
  • TQA相关
  • STM32F103C8----GPIO(跟着江科大学STM32)
  • 真正解决微信截图卡住(假死)
  • 【 html+css 绚丽Loading 】 000048 乾元旋涡盘
  • 【ArcGIS】栅格计算器原理及案例介绍
  • 如何加入PTP硬件时钟的组播组
  • Select组件选中调试,Tooltip组件hover调试技巧分享
  • Linux 中的 route 命令介绍以及使用
  • 【嵌入式开发 Linux 常用命令系列 7.1 -- git log 只显示日期和主题(title)和commit id】
  • Moco论文阅读笔记
  • 【Flutter】解决第一次运行项目很慢(gradle需要下载依赖)
  • 哈希表(功能不太全,只能查找)
  • Go语言 管道2