CPU_多线程操作图片_代码详解

Pthreads库

pthread_attr() 初始化线程的各项属性

pthread_attr_setdetachstate() 为初始化的线程设置属性

pthread_create() 创建一个线程

第一个参数 是每个线程的"句柄",对操作系统非常重要,使操作系统能够跟踪线程。
第二个参数 对于所有线程都相同,内容是线程属性
第三个参数 告诉线程要执行的任务
第四个参数 经过一些指针操作后,该参数指向TheParam[i],每个线程知道自己是谁

pthread_attr_destroy()

pthread_join()合并线程

用于将任何给定的线程合并到最初创建它的线程中。你可以将"合并"过程想象成"毁灭"线程,或者父线程"吞食"刚刚创建的线程。

示例

main主函数被重复执行3次,每次执行使用2个线程完成计算任务。

c 复制代码
#include <pthread.h>
#include <stdint.h>
#include <ctype.h>
#include <stdlib.h>
#include <stdio.h>
#include <sys/time.h>
#include <unistd.h>  // sleep()函数头文件


#define REPS 	     3
#define MAXTHREADS   128

long  			NumThreads=2;         		// Total number of threads working in parallel 并行的线程总数
int 	     	ThParam[MAXTHREADS];		// Thread parameters ...线程参数
pthread_t      	ThHandle[MAXTHREADS];		// Thread handles 线程句柄
pthread_attr_t 	ThAttr;						// Pthread attrributes

void *MTFlip(void* tid)
{
	int i;
	long ts = *((int *) tid);       	// My thread ID is stored here
	printf("\ntid=%d\n",tid);
	
	for(i=0;i<3;i++){
		sleep(1);
		printf("\n 正在使用ts=%d 执行计算任务,循环到i=%d\n",tid,i);
	}
	
	pthread_exit(0);
}


int main(int argc, char** argv)
{

	int 				a,i,ThErr;
	struct timeval 		t;
	double         		StartTime, EndTime;
	double         		TimeElapsed;

	if((NumThreads<1) || (NumThreads>MAXTHREADS)){
		printf("\nNumber of threads must be between 1 and %u... Exiting abruptly\n",MAXTHREADS);
		exit(EXIT_FAILURE);
	}
	else{
		if(NumThreads != 1){
			printf("\nExecuting the multi-threaded version with %li threads ...\n",NumThreads);
		}
		else{
			printf("\nExecuting the serial version ...\n");
		}
	}

	gettimeofday(&t, NULL);
	StartTime = (double)t.tv_sec*1000000.0 + ((double)t.tv_usec);

	if(NumThreads >1){
		
		for(a=0; a<REPS; a++){
			pthread_attr_init(&ThAttr);
			pthread_attr_setdetachstate(&ThAttr, PTHREAD_CREATE_JOINABLE);
			printf("\n 代码重复执行第 %d 次\n",a+1);
			for(i=0; i<NumThreads; i++){
				ThParam[i] = i;
				ThErr = pthread_create(&ThHandle[i], &ThAttr, MTFlip, (void *)&ThParam[i]);
				if(ThErr != 0){
					printf("\nThread Creation Error %d. Exiting abruptly... \n",ThErr);
					exit(EXIT_FAILURE);
				}
			}
			pthread_attr_destroy(&ThAttr);
			for(i=0; i<NumThreads; i++){
				pthread_join(ThHandle[i], NULL);
			}
		}
	}else{
		printf("\n单线程串行执行代码\n");
		
		}
	

	gettimeofday(&t, NULL);
	EndTime = (double)t.tv_sec*1000000.0 + ((double)t.tv_usec);
	TimeElapsed=(EndTime-StartTime)/1000.00;
	TimeElapsed/=(double)REPS;

	printf("\n\nTotal execution time: %9.4f ms ",TimeElapsed);
	
	return (EXIT_SUCCESS);
}

toupper() 小写字母转换为大写字母

C 库函数 int toupper(int c)把小写字母转换为大写字母。

反参:

如果 c 有相对应的大写字母,则该函数返回 c 的大写字母,否则 c 保持不变。返回值是一个可被隐式转换为 char 类型的 int 值。

c 复制代码
#include <stdio.h>
#include <ctype.h>

int main()
{
   int i = 0;
   char str[] = "runoob";
   
   while(str[i])
   {
      putchar (toupper(str[i]));
      i++;
   }
   
  return(0);
}

gettimeofday() 获取到当前时间的秒数

该函数的头文件在/usr/include/sys/time.h头文件中。

函数原型:int gettimeofday(struct timeval*tv, struct timezone *tz);

用到两个结构体: timevaltimezone

这两个结构体定义在/usr/include/linux/time.h头文件中。

示例2

c 复制代码
#include <stdio.h>
#include <sys/time.h>
#include <unistd.h>
int main(){
    struct timeval tv;
    struct timezone tz;
    gettimeofday (&tv, &tz);
    printf("\ntv_sec; %d\n", tv.tv_sec);
    printf("tv_usec; %d\n", tv.tv_usec);
    printf("tz_minuteswest; %d\n", tz.tz_minuteswest);
    printf("tz_dsttime, %d\n", tz.tz_dsttime);
}

示例2

c 复制代码
#include <stdio.h>
#include <sys/time.h>
#include <unistd.h>  // sleep()函数头文件

#define REPS 	     1

int main()
{
	struct timeval 		t;
	double         		StartTime, EndTime;
	double         		TimeElapsed;

	gettimeofday(&t, NULL);
	StartTime = (double)t.tv_sec*1000000.0 + ((double)t.tv_usec);

	sleep(30);  //休眠30秒

	gettimeofday(&t, NULL);
	EndTime = (double)t.tv_sec*1000000.0 + ((double)t.tv_usec);
	TimeElapsed=(EndTime-StartTime)/1000.00;
	TimeElapsed/=(double)REPS;

	printf("\n\nTotal execution time: %9.4f ms ",TimeElapsed);

}
相关推荐
0 0 02 小时前
CCF-CSP 38-2 机器人复健指南(jump)【C++】考点:BFS/DFS
开发语言·c++·算法·深度优先·宽度优先
小O的算法实验室2 小时前
2025年IEEE TSMCS SCI1区TOP,面向异构多点动态聚合的多阶段粒子群算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
xiaoye-duck2 小时前
《算法题讲解指南:优选算法-前缀和》--29.和为k的子数组,30.和可被k整除的子数组
c++·算法
Z9fish2 小时前
sse 哈工大 C 语言编程练习 39
c语言·数据结构·算法
丶小鱼丶2 小时前
数据结构和算法之【二分查找】
java·数据结构·算法
忡黑梨2 小时前
BUUCTF_reverse_[MRCTF2020]Transform
c语言·开发语言·数据结构·python·算法·网络安全
枳颜2 小时前
LeetCode 466:统计重复个数
数据结构·算法·字符串
爱和冰阔落2 小时前
【C++STL上】栈和队列模拟实现 容器适配器 力扣经典算法秘籍
数据结构·c++·算法·leetcode·广度优先
程序员-King.2 小时前
day162—递归—买卖股票的最佳时机Ⅱ(LeetCode-122)
算法·leetcode·深度优先·递归