服务器多线程学习

  在windows平台下,使用vs2017新建了一个控制台项目,实践C++11新特性thread。实践的主要思想是通过建立一个vector存入大量数据,将数据分成两半,一半主线程操作,一半子线程操作,对比单线程运行时间,是否提升了效率。

#include<iostream>
#include<thread>//线程头文件
#include<future>//简单说std::future提供了一种访问异步操作结果的机制
#include<cmath>//数学操作头文件
#include<vector>
#include<chrono>//获取本机器参考线程数的头文件
#include<cstdlib>//C语言中的stdlib.h在C++被重命名为cstdlib
#include<ctime>////C语言中的time.h在C++被重命名为ctime

using namespace std;

//沉重的计算事实上就算这样计算也很快
double caculate(double v)
{
	if (v<=0)
	{
		return v;
	}
	this_thread::sleep_for(chrono::milliseconds(10));//线程延时操作,为了模拟数据很多处理慢
	return sqrt((v*v + sqrt(v - 5)*(v + 2.5) / 2.0) / v);
}
//for_each
template<typename Iter,typename Fun>
double visitRange( thread::id id,Iter iterBegin, Iter iterEnd, Fun func)
{
	auto curId = this_thread::get_id();//获取主线程ID
	if (id == curId)
	{
		cout << curId << "hello main thread\n" << endl;
	}
	else
	{
		cout << curId << "hello work thread\n";
	}
	double v = 0;
	for (auto iter = iterBegin; iter < iterEnd; ++iter)
	{
		v += func(*iter);
	}
	return v;
}

//多线程 处理一组数据 将一组数据分为两半
int main()
{
	auto mainThreadId = this_thread::get_id();
	vector<double> v;
	for (int i = 0; i < 1000; ++i)
	{
		v.push_back(rand());
	}
	cout << v.size() << endl;
	double value = 0.0;
	auto nowc = clock();//记录时间
	//单线程总数据操作
	for (auto& info :v)
	{
		value += caculate(info);
	}
	auto finc = clock();//记录时间
	cout << "time value =" << finc- nowc << endl;
	cout << "value =" <<value << endl;

	auto midIter = v.begin() + (v.size() / 2);//分割vector
	//第二部分
	nowc = clock();//记录子线程时间
	double anotherv = 0.0;
	auto iterEnd = v.end();
	//传入线程
	thread s([&anotherv, mainThreadId, midIter, iterEnd]()
	{
		anotherv = visitRange(mainThreadId,midIter, iterEnd, caculate);
	});
	auto id = s.get_id();  //获取s线程id
	auto halfv = visitRange(mainThreadId,v.begin(), midIter, caculate);
	s.join();

	finc = clock();//记录子线程时间
	cout << "duo timevalue =" << finc - nowc << endl;

	cout << "anotherv =" << (anotherv) << endl;
	cout << "halfv =" << (halfv) << endl;
	cout << "Allvalue =" << (halfv + anotherv) << endl;
}

  

原文地址:https://www.cnblogs.com/zhangthree/p/10989153.html

时间: 2024-11-18 02:48:02

服务器多线程学习的相关文章

服务器多线程学习(二)

这里的代码是为了引入一个问题:线程安全 #include<iostream> #include<thread>//线程头文件 #include<future>//简单说std::future提供了一种访问异步操作结果的机制 #include<cmath>//数学操作头文件 #include<vector> #include<chrono>//获取本机器参考线程数的头文件 #include<cstdlib>//C语言中的st

Java多线程学习(吐血超详细总结)

林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 目录(?)[-] 一扩展javalangThread类 二实现javalangRunnable接口 三Thread和Runnable的区别 四线程状态转换 五线程调度 六常用函数说明 使用方式 为什么要用join方法 七常见线程名词解释 八线程同步 九线程数据传递 本文主要讲了java中多线程的使用方法.线程同步.线程数据传递.线程状态及相应的一些线程函数用法.概述等. 首先讲一下进程和线程

Qt多线程学习:创建多线程

[为什么要用多线程?] 传统的图形用户界面应用程序都仅仅有一个运行线程,而且一次仅仅运行一个操作.假设用户从用户界面中调用一个比較耗时的操作,当该操作正在运行时,用户界面一般会冻结而不再响应.这个问题能够用事件处理和多线程来解决. [Linux有线程的概念吗?] 传统的UNIX系统也支持线程的概念,但一个进程里仅仅同意有一个线程,这样多线程就是多进程.Linux下的Posix线程(pthreads)是一种轻量级的进程的移植性实现,线程的调度由内核完毕,每一个线程都有自己的编号.假设使用线程,整体

Java多线程学习(详细)

一.进程与线程的区别 进程:每个进程都有独立的代码和数据空间(进程上下文),进程间的切换会有较大的开销,一个进程包含1--n个线程.(进程是资源分配的最小单位) 线程:同一类线程共享代码和数据空间,每个线程有独立的运行栈和程序计数器(PC),线程切换开销小.(线程是cpu调度的最小单位) 线程和进程一样分为五个阶段:创建.就绪.运行.阻塞.终止.     多进程是指操作系统能同时运行多个任务(程序).     多线程是指在同一程序中有多个顺序流在执行. 在java中要想实现多线程,有两种手段,一

C#多线程学习(一) 多线程的相关概念

什么是进程?    当一个程序开始运行时,它就是一个进程,进程包括运行中的程序和程序所使用到的内存和系统资源.而一个进程又是由多个线程所组成的. 什么是线程?    线程是程序中的一个执行流,每个线程都有自己的专有寄存器(栈指针.程序计数器等),但代码区是共享的,即不同的线程可以执行同样的函数. 什么是多线程?    多线程是指程序中包含多个执行流,即在一个程序中可以同时运行多个不同的线程来执行不同的任务,也就是说允许单个程序创建多个并行执行的线程来完成各自的任务. 多线程的好处:    可以提

C#多线程学习(六) 互斥对象

C#多线程学习(六) 互斥对象 如何控制好多个线程相互之间的联系,不产生冲突和重复,这需要用到互斥对象,即:System.Threading 命名空间中的 Mutex 类. 我们可以把Mutex看作一个出租车,乘客看作线程.乘客首先等车,然后上车,最后下车.当一个乘客在车上时,其他乘客就只有等他下车以后才可以上车.而线程与Mutex对象的关系也正是如此,线程使用Mutex.WaitOne()方法等待Mutex对象被释放,如果它等待的Mutex对象被释放了,它就自动拥有这个对象,直到它调用Mute

C#多线程学习(一) 多线程的相关概念(转)

什么是进程?当一个程序开始运行时,它就是一个进程,进程包括运行中的程序和程序所使用到的内存和系统资源.而一个进程又是由多个线程所组成的. 什么是线程?线程是程序中的一个执行流,每个线程都有自己的专有寄存器(栈指针.程序计数器等),但代码区是共享的,即不同的线程可以执行同样的函数. 什么是多线程?多线程是指程序中包含多个执行流,即在一个程序中可以同时运行多个不同的线程来执行不同的任务,也就是说允许单个程序创建多个并行执行的线程来完成各自的任务. 多线程的好处:可以提高CPU的利用率.在多线程程序中

多线程学习 + o2o简识

多线程学习: ( 1.NSThread 2.NSOperationQueue 3.GCD ) 1.进程和线程: 进程:app无法独立运行,需要分配内存空间,每个app至少有一个进程,是应用程序的开始(缺点:不能同时执行) 线程:是应用程序运行的最小单元可以多个线程并发同时执行,防止主线程堵塞,增加运行效率. 主线程:又叫UI主线程,程序运行都是在主线程加载,加载视图,但不可加载数据,因为请求网络数据的时间特别长,会出现空白现象(更新UI一定要在主线程中写) 子线程:没法加载UI,UI只在主线程中

java多线程学习(3)

1)竞争条件 在实际的多线程应用中,通常会有两个或多个线程需要对共同的对象进行共享访问,如果两个线程访问相同的对象,而且每一个都调用了一个会改变对象状态的方法, 那么,线程就会相互倾轧.根据各个线程访问数据的不同顺序,可能会产生腐蚀现象.这种情况通常称为竞争条件. 2)同步 为了多个线程对共享数据的腐蚀,就需要对数据的存取实现同步:常用的同步方法有3种: 1.Reenlock 用Reenlock保护代码块的基本机构如下: 1 Lock myLock=new ReenLock; 2 3 myLoc