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

发布于 2022-09-06 08:15:22 字数 6133 浏览 17 评论 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);
    
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

池木 2022-09-13 08:15:22

临时解决方法 :usleep(1000); 睡眠1毫秒解决了问题
但是又遇到新的问题了 不知道哪里是不是内存溢出了

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文