Toriyung

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

多线程TCP的一些问题

使用循环堵塞等待客户端连接,连接到一个就开一条线程,当用以下代码,即每次ad重新初始化后其地址作为实参进行线程的创建,结果就是当有新客户端连接,开了新线程时,旧线程看起来会被停止,实际上是因为ad用了地址而不是值作为实参,所以当新连接进来时,ad的值被更改,但地址不变,旧线程所使用的ad内的值也随之变换,使得不同线程所使用的ad是一样的。

复制代码
    while(1)
    {
        socklen_t remotelen = sizeof(struct sockaddr);
        int ad = accept(sd,(sockaddr *)&remote_ip,&remotelen);
        if(ad == -1)
        {
            std::cout<<"accept remote ip fail"<<errno<<std::endl;
            return -1;
        }
        
        pthread_t tid;
        int ret = pthread_create(&tid,NULL,recvthread,(void *)&ad);
        if(ret == -1)
        {
            std::cout<<"create thread fail"<<std::endl;
            close(ad);
        }
    }
复制代码

所以需要保留每个ad的值,比如用数组

复制代码
    int i=0;
    while(1)
    {
        socklen_t remotelen = sizeof(struct sockaddr);
        ad[i] = accept(sd,(sockaddr *)&remote_ip,&remotelen);
        if(ad[i] == -1)
        {
            std::cout<<"accept remote ip fail"<<errno<<std::endl;
            return -1;
        }
        
        pthread_t tid;
        int ret = pthread_create(&tid,NULL,recvthread,(void *)&ad[i]);
        if(ret == -1)
        {
            std::cout<<"create thread fail"<<std::endl;
            close(ad[i]);
        }
        i++;
    }
复制代码

 

while(1)
{
socklen_t remotelen = sizeof(struct sockaddr);
ad[i] = accept(sd,(sockaddr *)&remote_ip,&remotelen);
if(ad[i] == -1)
{
std::cout<<"accept remote ip fail"<<errno<<std::endl;
return -1;
}
 
pthread_t tid;
int ret = pthread_create(&tid,NULL,recvthread,(void *)&ad[i]);
if(ret == -1)
{
std::cout<<"create thread fail"<<std::endl;
close(ad[i]);
}
i++;
}

posted on   Toriyung  阅读(14)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
点击右上角即可分享
微信分享提示