C++中多线程

简介:  1.多线程 多线程案例: #include <iostream> #include <thread> #include <string> #include<windows.h>   using namespace std;   void run(int num)


1.多线程

多线程案例:

#include <iostream>

#include <thread>

#include <string>

#include<windows.h>

 

using namespace std;

 

void run(int num)

{

    Sleep(1000);

    std::cout << "你好天朝" << num << endl;

}

 

void main()

{

    thread *p[10];

    for (int i = 0; i < 10;i++)

    {

        p[i] = new thread(run,i);//循环创建线程

        //p[i]->join();//等待,相当于堵塞的状态

        p[i]->detach();//脱离当前主线程自由执行,乱序,也就是说每个线程的执行是随机的,是并发执行。

    }

    cin.get();

}

运行结果是:

2.线程案例2

#include <iostream>

#include <thread>

#include <string>

#include<windows.h>

 

using namespace std;

 

void helloworld()

{

    std::cout << "你好天朝" << endl;

}

 

void helloworldA()

{

    std::cout << "你好天朝A" << endl;

}

 

void helloworldB()

{

    std::cout << "你好天朝B" << endl;

}

//通过下面这种方式实现的线程永远是顺序的

void main()

{

    std::thread t1(helloworld);//线程顺序执行

    std::thread t2(helloworldA);

    std::thread t3(helloworldB);

    cin.get();

}

3.线程加锁和线程解锁

#include <iostream>

#include <thread>

#include <string>

#include<windows.h>

#include<mutex>

using namespace std;

//两个线程并行访问一个变量

int g_num = 20;//找到或者找不到的标识

mutex g_mutex;

void goA(int num)

{

    //你访问的变量,在你访问期间,别人访问不了,

    //这种情况明显可以看到自己被执行的次数多了

    g_mutex.lock();

    for (int i = 0; i < 15; i++)

    {

        Sleep(300);

        g_num = 10;

        std::cout << "线程" << num << "   " << g_num << endl;

    }

    g_mutex.unlock();

}

void goB(int num)

{

    for (int i = 0; i < 15; i++)

    {

        Sleep(500);

        g_num = 11;

        std::cout << "线程" << num << "   " << g_num << endl;

    }

}

void main()

{

    thread t1(goA,1);

    thread t2(goB, 2);

    t1.join();

    t2.join();

    std::cin.get();

}

运行结果:

4.线程之间通信以及锁定

案例:

#include <iostream>

#include <thread>

#include <string>

#include<windows.h>

 

using namespace std;

 

//两个线程并行访问一个变量

//找到或者找不到的标识

int g_num = 20;

 

void goA(int num)

{

    for (int i = 0; i < 15;i++)

    {

        Sleep(1000);

        if (i == 6)

        {

            g_num = 5;

        }

        if (g_num == 5)

        {

            std::cout << "线程" << num << "结束\n";

            return;

        }

        std::cout << "线程" << num << "  " << g_num << endl;

    }

}

 

void goB(int num)

{

    for (int i = 0; i < 150; i++)

    {

        Sleep(1000);

        if (g_num == 5)

        {

            std::cout << "线程" << num << "结束   \n";

            return;

        }

        std::cout << "线程" << num << "   " << g_num << endl;

    }

}

 

void main()

{

    thread t1(goA, 1);

    thread t2(goB, 2);

    t1.join();

    t2.join();

 

    std::cin.get();

}

 

目录
相关文章
|
12月前
|
存储 消息中间件 资源调度
C++ 多线程之初识多线程
这篇文章介绍了C++多线程的基本概念,包括进程和线程的定义、并发的实现方式,以及如何在C++中创建和管理线程,包括使用`std::thread`库、线程的join和detach方法,并通过示例代码展示了如何创建和使用多线程。
144 1
C++ 多线程之初识多线程
|
11月前
|
缓存 安全 C++
C++无锁队列:解锁多线程编程新境界
【10月更文挑战第27天】
685 7
|
11月前
|
消息中间件 存储 安全
|
12月前
|
存储 并行计算 安全
C++多线程应用
【10月更文挑战第29天】C++ 中的多线程应用广泛,常见场景包括并行计算、网络编程中的并发服务器和图形用户界面(GUI)应用。通过多线程可以显著提升计算速度和响应能力。示例代码展示了如何使用 `pthread` 库创建和管理线程。注意事项包括数据同步与互斥、线程间通信和线程安全的类设计,以确保程序的正确性和稳定性。
230 5
|
12月前
|
存储 前端开发 C++
C++ 多线程之带返回值的线程处理函数
这篇文章介绍了在C++中使用`async`函数、`packaged_task`和`promise`三种方法来创建带返回值的线程处理函数。
451 6
|
缓存 负载均衡 Java
c++写高性能的任务流线程池(万字详解!)
本文介绍了一种高性能的任务流线程池设计,涵盖多种优化机制。首先介绍了Work Steal机制,通过任务偷窃提高资源利用率。接着讨论了优先级任务,使不同优先级的任务得到合理调度。然后提出了缓存机制,通过环形缓存队列提升程序负载能力。Local Thread机制则通过预先创建线程减少创建和销毁线程的开销。Lock Free机制进一步减少了锁的竞争。容量动态调整机制根据任务负载动态调整线程数量。批量处理机制提高了任务处理效率。此外,还介绍了负载均衡、避免等待、预测优化、减少复制等策略。最后,任务组的设计便于管理和复用多任务。整体设计旨在提升线程池的性能和稳定性。
271 5
|
12月前
|
C++
C++ 多线程之线程管理函数
这篇文章介绍了C++中多线程编程的几个关键函数,包括获取线程ID的`get_id()`,延时函数`sleep_for()`,线程让步函数`yield()`,以及阻塞线程直到指定时间的`sleep_until()`。
203 0
C++ 多线程之线程管理函数
|
12月前
|
资源调度 Linux 调度
Linux C/C++之线程基础
这篇文章详细介绍了Linux下C/C++线程的基本概念、创建和管理线程的方法,以及线程同步的各种机制,并通过实例代码展示了线程同步技术的应用。
191 0
Linux C/C++之线程基础
|
Java 调度
基于C++11的线程池
基于C++11的线程池
|
Dart 编译器 API
Dart ffi 使用问题之在C++线程中无法直接调用Dart函数的问题如何解决
Dart ffi 使用问题之在C++线程中无法直接调用Dart函数的问题如何解决