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);
关于TTCLOUD服务商在今年初的时候有介绍过一次,而且对于他们家的美国圣何塞服务器有过简单的测评,这个服务商主要是提供独立服务器业务的。目前托管硬件已经达到5000台服务器或节点,主要经营圣何塞,洛杉矶以及日本东京三个地区的数据中心业务。这次看到商家有推出了新上架的日本独立服务器促销活动,价格 $70/月起,季付送10Mbps带宽。也可以跟进客户的需求进行各种DIY定制。内存CPU硬盘流量带宽价...
pacificrack怎么样?pacificrack商家发布了七月最新优惠VPS云服务器计划方案,推出新款优惠便宜VPS云服务器采用的是国产魔方管理系统,也就是PR-M系列,全系基于KVM虚拟架构,这次支持Windows server 2003、2008R2、2012R2、2016、2019、Windows 7、Windows 10以及Linux等操作系统,最低配置为1核心2G内存1Gbps带宽1...
tmhhost为2021年暑假开启了全场大促销,全部都是高端线路的VPS,速度快有保障。美国洛杉矶CN2 GIA+200G高防、洛杉矶三网CN2 GIA、洛杉矶CERA机房CN2 GIA,日本软银(100M带宽)、香港BGP直连200M带宽、香港三网CN2 GIA、韩国双向CN2。本次活动结束于8月31日。官方网站:https://www.tmhhost.com8折优惠码:TMH-SUMMER日本...
linux多线程编程为你推荐
qq空间首页QQ空间主页怎么弄?麒麟820和980哪个好麒麟980和骁龙855那个好一点?迈腾和帕萨特哪个好帕萨特和迈腾哪个车好?华为p40和mate30哪个好荣耀30pro和华为P40哪个好?机械表和石英表哪个好手表中,石英表和机械表的区别和优缺点播放器哪个好哪个播放器最好辽宁联通营业厅辽宁移动网上营业厅进入办法willyunlee电影拳皇演的是什么意思电信dns服务器地址电信光纤的dns地址怎么设置360云盘共享群360云盘怎么找共享群
上海vps 个人域名备案流程 科迈动态域名 vmsnap3 美国主机代购 shopex空间 ev证书 java空间 炎黄盛世 网站cdn加速 200g硬盘 服务器是干什么的 佛山高防服务器 isp服务商 100m独享 台湾google smtp虚拟服务器 河南移动梦网 贵阳电信 申请免费空间 更多