c语言数据库线程池,C语言多线程中运行线程池,在线程池中运行线程池,,传递的结构体参数值为空/NULL/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);

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值