有人可以发布一个简单的示例来说明如何在C ++中启动两个(面向对象)线程。

我正在寻找可以扩展运行方法(或类似方法)的实际C ++线程对象,而不是调用C样式线程库。

我遗漏了任何特定于OS的请求,希望任何答复的人都可以使用跨平台库进行答复。 我现在将其明确。


#1楼

创建一个您希望线程执行的函数,例如:

void task1(std::string msg)
{std::cout << "task1 says: " << msg;
}

现在创建thread对象,该对象最终将调用上述函数,如下所示:

std::thread t1(task1, "Hello");

(您需要#include <thread>才能访问std::thread类)

构造函数的参数是线程将执行的函数,其后是函数的参数。 线程在构建时自动启动。

如果以后要等待线程完成执行该函数,请调用:

t1.join();

(加入意味着调用新线程的线程将等待新线程完成执行,然后再继续执行自己的执行)。


编码

#include <string>
#include <iostream>
#include <thread>using namespace std;// The function we want to execute on the new thread.
void task1(string msg)
{cout << "task1 says: " << msg;
}int main()
{// Constructs the new thread and runs it. Does not block execution.thread t1(task1, "Hello");// Do other things...// Makes the main thread wait for the new thread to finish execution, therefore blocks its own execution.t1.join();
}

有关std :: thread的更多信息,请点击此处

  • 在GCC上,使用-std=c++0x -pthread编译。
  • 只要您的编译器支持此(C ++ 11)功能,这对任何操作系统都适用。

#2楼

还有一个用于POSIX操作系统的POSIX库。 检查兼容性

#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>
#include <iostream>void *task(void *argument){char* msg;msg = (char*)argument;std::cout<<msg<<std::endl;
}int main(){pthread_t thread1, thread2;int i1,i2;i1 = pthread_create( &thread1, NULL, task, (void*) "thread 1");i2 = pthread_create( &thread2, NULL, task, (void*) "thread 2");pthread_join(thread1,NULL);pthread_join(thread2,NULL);return 0;}

用-lpthread编译

http://en.wikipedia.org/wiki/POSIX_Threads


#3楼

在很大程度上取决于您决定使用的库。 例如,如果您使用wxWidgets库,则线程的创建将如下所示:

class RThread : public wxThread {public:RThread(): wxThread(wxTHREAD_JOINABLE){}
private:RThread(const RThread &copy);public:void *Entry(void){//Do...return 0;}};wxThread *CreateThread() {//Create threadwxThread *_hThread = new RThread();//Start thread_hThread->Create();_hThread->Run();return _hThread;
}

如果您的主线程调用CreateThread方法,则将创建一个新线程,该线程将开始执行“ Entry”方法中的代码。 在大多数情况下,您必须保留对该线程的引用才能加入或停止该线程。 更多信息在这里: wxThread文档


#4楼

好吧,从技术上讲,任何此类对象最终都将基于C风格的线程库构建,因为C ++仅在c ++ 0x中指定了一个普通的std::thread模型,该模型只是被钉住了,尚未实现。 这个问题有点系统性,从技术上讲,现有的c ++内存模型不够严格,无法为所有“发生之前”的情况提供明确定义的语义。 汉斯·勃姆(Hans Boehm)不久前就该主题撰写了一篇论文,并且在制定有关该主题的c ++ 0x标准方面发挥了作用。

http://www.hpl.hp.com/techreports/2004/HPL-2004-209.html

那就是说,有几个跨平台的线程C ++库在实践中工作得很好。 英特尔线程构建块包含一个tbb :: thread对象,该对象非常接近c ++ 0x标准,Boost具有一个boost :: thread库,其功能相同。

http://www.threadingbuildingblocks.org/

http://www.boost.org/doc/libs/1_37_0/doc/html/thread.html

使用boost :: thread,您将获得类似以下内容的信息:

#include <boost/thread.hpp>void task1() { // do stuff
}void task2() { // do stuff
}int main (int argc, char ** argv) {using namespace boost; thread thread_1 = thread(task1);thread thread_2 = thread(task2);// do other stuffthread_2.join();thread_1.join();return 0;
}

#5楼

#include <thread>
#include <iostream>
#include <vector>
using namespace std;void doSomething(int id) {cout << id << "\n";
}/*** Spawns n threads*/
void spawnThreads(int n)
{std::vector<thread> threads(n);// spawn n threads:for (int i = 0; i < n; i++) {threads[i] = thread(doSomething, i + 1);}for (auto& th : threads) {th.join();}
}int main()
{spawnThreads(10);
}

#6楼

在搜索在新线程中调用其自己的实例方法的C ++类的示例时,会出现此问题,但我们无法以这种方式使用任何这些答案。 这是一个执行此操作的示例:

class DataManager
{
public:bool hasData;void getData();bool dataAvailable();
};

类.cpp

#include "DataManager.h"void DataManager::getData()
{// perform background data munginghasData = true;// be sure to notify on the main thread
}bool DataManager::dataAvailable()
{if (hasData){return true;}else{std::thread t(&DataManager::getData, this);t.detach(); // as opposed to .join, which runs on the current thread}
}

请注意,此示例不会进入互斥或锁定状态。


#7楼

除非有人希望在全局命名空间中使用单独的函数,否则我们可以使用lambda函数创建线程。

使用lambda创建线程的主要优点之一是我们不需要将局部参数作为参数列表传递。 我们可以对它使用捕获列表,lambda的闭包属性将照顾生命周期。

这是示例代码

int main() {int localVariable = 100;thread th { [=](){cout<<"The Value of local variable => "<<localVariable<<endl;}}th.join();return 0;
}

到目前为止,我发现C ++ lambda是创建线程的最佳方法,尤其是对于简单的线程函数

C ++中线程的简单示例相关推荐

  1. 命令行运行vbs脚本并传参数给vbs中的变量简单示例

    详细了解脚本请参考:脚本学习及应用分享 - 批处理和脚本的交互 简单代码示例: CommandLine:    path\cscript.exe  xxx.vbs helloworld VBSCode ...

  2. Qt中线程的简单使用

    对于线程过去写的比较少,现在也几乎是小白的水平.先创建Qt empty project,即Qt空项目,打开QtCreate->文件->新建文件或项目->其它项目->empty ...

  3. C#中汉字排序简单示例(拼音/笔划)

    可以按照区域语言修改排序规则. class Program{static void Main(string[] args){string[] arr = { "趙(ZHAO)", ...

  4. sql server中case的简单示例

    select *,     case          when resultrate>0 then case --<<case嵌套                          ...

  5. vs如何写多线程_java中的多线程的示例

    在讨论多线程之前,让我们先讨论线程.线程是进程中轻量级的最小部分,可以与同一进程的其他部分(其他线程)并发运行.线程是独立的,因为它们都有独立的执行路径,这就是为什么如果一个线程中发生异常,它不会影响 ...

  6. java中的多线程的示例

    在讨论多线程之前,让我们先讨论线程.线程是进程中轻量级的最小部分,可以与同一进程的其他部分(其他线程)并发运行.线程是独立的,因为它们都有独立的执行路径,这就是为什么如果一个线程中发生异常,它不会影响 ...

  7. php中的函数调简单 传入参数即可,php函数与传递参数的简单示例

    这篇文章主要为大家详细介绍了php函数与传递参数的简单示例,具有一定的参考价值,可以用来参考一下. 感兴趣的小伙伴,下面一起跟随512笔记的小玲来看看吧! 本文实例讲述了函数的调用与函数定义语法,并讲 ...

  8. python停止线程池_详解python中Threadpool线程池任务终止示例代码

    需求 加入我们需要处理一串个位数(0~9),奇数时需要循环打印它:偶数则等待对应时长并完成所有任务:0则是错误,但不需要终止任务,可以自定义一些处理. 关键点 定义func函数处理需求 callbac ...

  9. python线程监控_Python实现线程状态监测简单示例

    本文实例讲述了Python实现线程状态监测.分享给大家供大家参考,具体如下: # -*- coding:utf-8 -*- from threading import Thread import ti ...

最新文章

  1. pptv网络电视android,PP视频(原聚力视频)
  2. .NET轻量级ORM框架Dapper入门精通
  3. 西交计算机组成原理第四章,17春西交《计算机组成原理》在线作业.doc
  4. datagrip将一个数据库中的数据_跨平台数据库管理神器DataGrip,用上就爱不释手...
  5. 求正整数N(N1)的质因数的个数,相同的质因数需要重复计算(java)
  6. (转)word2vec前世今生
  7. Unity3D 怎样在安卓手机上播放视频
  8. tomcat/redis/dubbo/netty
  9. python三维转换教程_Python科学计算三维可视化【完结】
  10. GDAL读取高程文件,获取经纬度点的高程
  11. 【预测模型】趋势移动平均法预测发电量
  12. 杰里之AC696 系列 2M 的 SDK 开蓝牙一拖二出现奇怪的问题【篇】
  13. 在linux下恶臭hellotext中作用的?,《Linux内核与程序设计》实验学习笔记
  14. C#控制键盘按键的常用方法
  15. 学计算机用书包吗,起底大学生活 | 书包物品大揭秘
  16. eas k5.4 (七):v4.17 - Util(ization) Est(imated)
  17. 智能语音应用开发之DPL2.0高级特性
  18. Oracle ERP 库存管理(业务流程 核心流程)
  19. 雅诗兰黛宣布其国际业务以及欧洲、中东和非洲业务的重要领导层任命
  20. 2020Android开发者学习路线(快速篇),29岁vivo员工吐槽

热门文章

  1. INADDR_ANY的理解
  2. Java中super关键字的位置
  3. 编程思想之多线程与多进程——以操作系统的角度述说线程与进程
  4. 第十二周项目一-实现复数类中的运算符重载(3)
  5. Android 10.0 系统启动之SystemServer进程-[Android取经之路]
  6. Tomcat Jenkins iOS自动打包
  7. linux除了eeprom其他的保存方法,linux的EEPROM的读写控制.doc
  8. python 函数(二)
  9. CodeForces786B 线段树 + 最短路
  10. GridView学习记录(一)