linux多线程编程linux单进程如何实现多核cpu多线程分配?

linux多线程编程  时间:2020-12-30  阅读:()

在Linux环境下,对一个设备文件进行多线程读写(两个线程就行),求大神给一个简单的程序。

配置文件为 conf.txt 测试代码如下,注意链接的时候加上 -lpthread 这个参数 #include <stdio.h> #include <errno.h> //perror() #include <pthread.h> #include <unistd.h> //sleep() #include <time.h> // time() #include <stdlib.h> //rand() #define FD "conf.txt" typedef void *(*fun)(void *); struct my_struct { unsigned time_to_wait; int n; }; void *test_thread(struct my_struct *); int main (int argc, char const *argv[]) { FILE *fp = fopen(FD, "r"); if (fp == NULL) { perror(FD); return -1; } srand((unsigned)time(NULL)); //初始化随机种子 int thread_count; fscanf(fp, "%d", &thread_count); fclose(fp); if (thread_count <= 0) { printf("线程数<1,退出程序。

"); return -1; } pthread_t *ptid = (pthread_t *)malloc(sizeof(pthread_t) * thread_count); //保存线程ID int i; for (i = 0; i < thread_count; i++) { int tw = rand() % thread_count + 1; //随机等待时间 struct my_struct * p = (struct my_struct *)malloc(sizeof(struct my_struct)); if (p == NULL) { perror("内存分配错误"); goto ERROR; } p->time_to_wait = tw; p->n = i + 1; int rval = pthread_create(ptid + i, NULL, (fun) test_thread, (void *)(p)); //注意这里的强制转换(两个) if (rval != 0) { perror("Thread creation failed"); goto ERROR; } //sleep(1); //这句加也可以,不加也可以。

最开始的时候加上这个是为了让两个线程启动的时候之间有一定的时间差 } printf("主线程启动 "); fflush(stdout); for (i = 0; i < thread_count; i++) { pthread_join(*(ptid + i), NULL); //等待所有线程退出。

} printf(" 主线程退出 "); ERROR: free(ptid); return 0; } void *test_thread(struct my_struct * p) //线程启动的时候运行的函数 { printf("第%d个线程启动,预计运行%d秒 ", p->n, p->time_to_wait); fflush(stdout); sleep(p->time_to_wait); //让线程等待一段时间 printf("第%d个线程结束 ", p->n); fflush(stdout); free(p); return NULL; } 你的第二个问题我在百度HI回你了~

在Linux下用C++创建新线程

#include <stdio.h> #include <pthread.h> #include <stdlib.h> void* thread(void* arg) { printf ("The child process... "); } int main(int argc, char *argv[]) { pthread_t id; int i,ret; ret=pthread_create(&id,NULL,(void *)thread,NULL); if(ret!=0) { printf ("Create pthread error! "); exit (1); } } 程序如上就可以编译。

它属于linux下C编程中多线程编程的范围。

用命令 -lpthread 1.c -o 1 ./1 就可以出结果。

多线程编程的基础可以参考 /huifeng00/blog/item/ed13ddc0d6c59c170ff47715.html

最近在学linux中多线程编程,发现很多函数参数为void *retval,这是什么意思啊,是说retval这个指针是指向

这个一般是用来返回结构体指针的 结构体是没有确定类型的 多线程里面的参数也是void * arg 这样的话 更通用 你可以传任意类型 也可以返回任意类型 但是要做强制类型转换

linux单进程如何实现多核cpu多线程分配?

linux下的单进程多线程的程序,要实现每个线程平均分配到多核cpu,主要有2个方法 1:利用linux系统自己的线程切换机制,linux有一个服务叫做irqbalance,这个服务是linux系统自带的,默认会启动,这个服务的作用就是把多线程平均分配到CPU的每个核上面,只要这个服务不停止,多线程分配就可以自己实现。

但是要注意,如果线程函数内部的有某个循环,且该循环内没有任何系统调用的话,可能会导致这个线程的CPU时间无法被切换出去。

也就是占满CPU现象,此时加个系统调用,例如sleep,线程所占的CPU时间就可以切换出去了。

2:利用pthread库自带的线程亲和性设置函数,来设置线程在某个CPU核心上跑,这个需要在程序内部实现。

同时注意不要和进程亲和性设置搞混淆了 int?pthread_setaffinity_np(pthread_t?thread,?size_t?cpusetsize, const?cpu_set_t?*cpuset); int?pthread_getaffinity_np(pthread_t?thread,?size_t?cpusetsize,? cpu_set_t?*cpuset); 从函数名以及参数名都很明了,唯一需要点解释下的可能就是cpu_set_t这个结构体了。

这个结构体的理解类似于select中的fd_set,可以理解为cpu集,也是通过约定好的宏来进行清除、设置以及判断: //初始化,设为空 void?CPU_ZERO?(cpu_set_t?*set);? //将某个cpu加入cpu集中? void?CPU_SET?(int?cpu,?cpu_set_t?*set);? //将某个cpu从cpu集中移出? void?CPU_CLR?(int?cpu,?cpu_set_t?*set);? //判断某个cpu是否已在cpu集中设置了? int?CPU_ISSET?(int?cpu,?const?cpu_set_t?*set);

Hostodo商家提供两年大流量美国VPS主机 可选拉斯维加斯和迈阿密

Hostodo商家算是一个比较小众且运营比较久的服务商,而且还是率先硬盘更换成NVMe阵列的,目前有提供拉斯维加斯和迈阿密两个机房。看到商家这两年的促销套餐方案变化还是比较大的,每个月一般有这么两次的促销方案推送,可见商家也在想着提高一些客户量。毕竟即便再老的服务商,你不走出来让大家知道,迟早会落寞。目前,Hostodo有提供两款大流量的VPS主机促销,机房可选拉斯维加斯和迈阿密两个数据中心,且都...

RAKsmart秒杀服务器$30/月,洛杉矶/圣何塞/香港/日本站群特价

RAKsmart发布了9月份优惠促销活动,从9月1日~9月30日期间,爆款美国服务器每日限量抢购最低$30.62-$46/月起,洛杉矶/圣何塞/香港/日本站群大量补货特价销售,美国1-10Gbps大带宽不限流量服务器低价热卖等。RAKsmart是一家华人运营的国外主机商,提供的产品包括独立服务器租用和VPS等,可选数据中心包括美国加州圣何塞、洛杉矶、中国香港、韩国、日本、荷兰等国家和地区数据中心(...

Friendhosting,美国迈阿密机房新上线,全场45折特价优惠,100Mbps带宽不限流量,美国/荷兰/波兰/乌兰克/瑞士等可选,7.18欧元/半年

近日Friendhosting发布了最新的消息,新上线了美国迈阿密的云产品,之前的夏季优惠活动还在进行中,全场一次性45折优惠,最高可购买半年,超过半年优惠力度就不高了,Friendhosting商家的优势就是100Mbps带宽不限流量,有需要的朋友可以尝试一下。Friendhosting怎么样?Friendhosting服务器好不好?Friendhosting服务器值不值得购买?Friendho...

linux多线程编程为你推荐
cf蜗牛外挂蜗牛透视如何使用燃气热水器和电热水器哪个好燃气热水器和电热水器哪个好法兰绒和珊瑚绒哪个好珊瑚绒和法兰绒哪个暖和机械表和石英表哪个好自动石英表与全自动机械表哪个好核芯显卡与独立显卡哪个好独立显卡和核心显卡哪个好dnf魔枪士转职哪个好dnf魔枪士转职哪个适合平民玩红茶和绿茶哪个好红茶和绿茶哪个比较好?网络机顶盒哪个好什么牌子的网络机顶盒最好考生个人空间登录我是2007年入的学2010年毕业我想查询这3年的成绩,怎么办啊?求解答!首选dns服务器地址什么是首选DNS服务器和备用DNS服务器?
tk域名注册 贵州电信宽带测速 java虚拟主机 河南m值兑换 hinet 电信主机 台湾google 广州虚拟主机 iki 登陆qq空间 网站加速 博客域名 蓝队云 标准机柜 赵荣 天津摇号申请网站 北京车牌号申请网站 免费网络游戏排行 最大的免费网络硬盘 睿云网快速查分 更多