账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    C语言多线程中运行线程池,在线程池中运行线程池,,传递的结构体参数值为空/NULL/0
    34
    0

    C语言多线程中运行线程池,在线程池中运行线程池,,传递的结构体参数值为空/NULL/0

    本贴问题,之前已经提问过一次,当时已经解决了,原贴在这里https://segmentfault.com/q/10...
    .现在的代码贴了部分出来,问题也在下方描述,我刚刚接触C语言,也不是专业程序员.爱好者,在开发中遇到了问题,请求帮助

    
    
    
    typedef struct {
    }LoanInfos;
    
    typedef struct{
        int cp;//主线程编号
        int thread;//线程编号
        long int time;
    
        int arraysize;//二维数组的主数组有多少个元素
        int arraykey;//二维数组的主数组的第几个元素
    
    }ListingInfos;
    typedef struct{
        int cp;//主线程编号
        int thread;//线程编号
        int thread_pool;//线程池编号
        long int time;
        
        int arraysize;//二维数组的主数组有多少个元素
        int arraykey;//二维数组的主数组的第几个元素
        int arraykey_min;
    }S_ListingInfos;
    
    
    //配置单次请求处理标的数目为多少个
    #define DEIL_LEN 10
    //数据库连接配置
    char *db_host = "127.0.0.1";
    char *db_user = "root";
    char *db_pass = "password";
    char *db_name = "database";
    
    /*************以上为参数设置区域***************/
    struct threadpool *user_pool;
    struct threadpool *strategy_pool;
    
    int main() {
        curl_global_init(CURL_GLOBAL_ALL);
        mysql_library_init(0, NULL, NULL);
        user_pool = threadpool_init(100, 1000); //创建用户组线程池,单次只处理15个线程,最多等待100个策略            
        s_pool = threadpool_init(100, 1000); //创建方法组线程池,单次只处理15个线程,最多等待100个策略        
        //创设线程
        pthread_t t1, t2;
        pthread_create(&t1, NULL, getlist, (void *)0);//传递线程参数代码为0
        usleep(100000 * 5);//间隔0.5毫秒创设线程
        pthread_create(&t2, NULL, getlist, (void *)1);//传递线程参数代码为1
    
                                                                                    
        
    
        pthread_join(t1, NULL);
        //usleep(100000);//0.1秒
        pthread_join(t2, NULL);
    
        threadpool_destroy(s_pool);//销毁线程池
        threadpool_destroy(user_pool);//销毁线程池
        mysql_library_end();
    
        return 0;
    }
    
    //刷新列表并处理详情线程
    void* getlist(void* m) {
        int cp = (int)m;
        pthread_detach(pthread_self()); //分离线程,使得它不能被其他线程回收或杀死的,它的存储器资源在它终止时由系统自动释放
        //以下实现无线循环
        for (int i;; i += 1) {
            long int time;
            long int r_time;
            struct tm *gmt;  //格林威治时间 
            struct tm *gmt2;  //格林威治时间 
            struct timeval tv;
            long int ss;
            ....//这里定义了很多局部变量
    
    
            usleep(100000 * 20);//2秒刷新一次一次
            
            //时间设置
            {
            gettimeofday(&tv, NULL);
            ss = tv.tv_sec;
            //time = ss * 1000 + tv.tv_usec / 1000;//获取当前毫秒
            //time -= refresh_time;//当前毫秒减去刷新毫秒,回到N毫秒之前
            time = ss + 8 * 60 * 60;//当前时间戳
            r_time = time - refresh_time / 1000;
            gmt = gmtime(&r_time);//转为格林威治时间 
    
            strftime(__request_time, BUFLEN, "%Y-%m-%d %H:%M:%S", gmt);
            gmt2 = gmtime(&ss);//转为格林威治时间 
            strftime(send_time, BUFLEN, "%Y-%m-%d %H:%M:%S", gmt2);
            }
            
        
    
            #####这里有一部分MySQL处理代码和数据处理过程############
    
            
            
        ListingInfos listing_infos_[l_size];
            for (int _i = 0; _i < l_size; _i++)
            {
            
                listing_infos_[_i].thread = _i;
                listing_infos_[_i].cp = cp;
                listing_infos_[_i].time = time;
                listing_infos_[_i].arraysize = l_size;
                listing_infos_[_i].arraykey = _i;
                //创建线程
                int temp;
                printf("【%d】【%d】创建线程前的ID号:%ld\n", cp, _i, listing_infos_[_i].Id);
                threadpool_add_job(s_pool, ListThread, &listing_infos_[_i]);
    
            }
                
    
            
        }
    }
    
    
    void *ListThread(void *arg)
    {
        ListingInfos *listing_infos;
        listing_infos = (ListingInfos *)arg;
        printf("【%d】listid_thread【%d】线程中获取的ID:%ld\n", listing_infos->cp, listing_infos->thread, listing_infos->Id);
        
        
        
        
        //连接数据库
        MYSQL *conn;
        MYSQL_RES *res;
        MYSQL_ROW row;
        
        //生成SQL
        
        printf("【%d】listid_thread【%d】发送查询策略SQL:%s\n", listing_infos->cp, listing_infos->thread, t_sql);
        
        
        int arraysize = listing_infos->arraysize;
        int arraykey = listing_infos->arraykey;
        S_ListingInfos s_listing_infos[arraysize][100];
        int count = 0;
    
        while (row = mysql_fetch_row(res))
        {
            if (o >= 100) {
                break;
            }
            unsigned long int *lengths = NULL;
            lengths = mysql_fetch_lengths(res); 
        
            #######处理数据
    
            //弄一个结构变量,存储S组的信息
            strategy_listing_infos[arraykey][o].arraysize = arraysize;
            strategy_listing_infos[arraykey][o].arraykey = arraykey;
            strategy_listing_infos[arraykey][o].arraykey_min = o;
            .....//这里在整合数据
            
            
            printf("\n【%d】【%d】【%d】标号%ld----策略:%s[%d]\t前\n", s_listing_infos[arraykey][o].cp, s_listing_infos[arraykey][o].thread, s_listing_infos[arraykey][o].thread_pool, s_listing_infos[arraykey][o].Id, s_listing_infos[arraykey][o].Name, s_listing_infos[arraykey][o].SId);

    问题出在这里,下方的代码,上方的打印出来是没有问题的,然后就调用user_pool线程池

            threadpool_add_job(user_pool, UsersThread, &s_listing_infos[arraykey][o]);
            
            o++; count++;
        }
        //printf("【%d】【%d】计数符合策略数count[%d]\n", listing_infos->cp, listing_infos->thread, count);
        mysql_free_result(res);
        //printf("【%d】listid_thread【%d】连接数据库关闭\n", listing_infos->cp, listing_infos->thread);
        mysql_close(conn);
        mysql_thread_end();
        pthread_exit(0);
        return ((void *)0);
    }

    在下面的线程中,我不论是打印结果,还是弄到MYSQL数据库查看结果,都有很多下方的结果,没有达到期望值
    【0】【0】【0】ID号0----策略:[0]
    【0】【0】【0】ID号0----策略:[0]
    【0】【0】【0】ID号0----策略:[0]
    【0】【0】【0】ID号0----策略:[0]
    【0】【0】【0】ID号0----策略:[0]
    【0】【0】【0】ID号0----策略:[0]
    【0】【0】【0】ID号0----策略:[0]
    【0】【0】【0】ID号0----策略:[0]
    【0】【0】【0】ID号0----策略:[0]
    【0】【0】【0】ID号0----策略:[0]
    【0】【0】【0】ID号0----策略:[0]

    void* UsersThread(void* arg)
    {
        S_ListingInfos *s_listing_infos = (S_ListingInfos *)arg;
        printf("\n【%d】【%d】【%d】ID号%ld----策略:%s[%d]\n", s_listing_infos->cp, s_listing_infos->thread, s_listing_infos->thread_pool, s_listing_infos->ListingId, s_listing_infos->StrategyName, s_listing_infos->StraId);
        
    }
    
    
    2
    打赏
    收藏
    点击回答
        全部回答
    • 0
    • ★孤寂←天空☆ 普通会员 1楼

      在C语言中,线程池中运行线程池的结构体参数值为空/NULL/0通常是空指针异常或错误的操作。当一个线程池中的线程被创建后,这些线程的结构体参数通常会被初始化为特定的值。

      如果线程池中没有线程被创建,那么它将保持空/NULL/0的结构,这意味着线程池的运行状态将是停止的。这种情况通常发生在创建线程池时,或者在尝试修改线程池的状态(例如,将线程池的状态设置为非停止状态)时。

      要解决这个问题,你需要检查线程池的创建和修改状态的代码。确保线程池的状态在正确的范围内,且线程被正确地初始化为空/NULL/0。你可能需要添加一些错误检查代码来确保线程池的状态是正确的。

    更多回答
    扫一扫访问手机版
    • 回到顶部
    • 回到顶部