白骑士的C++教学高级篇 3.2 多线程与并发

系列目录

上一篇:白骑士的C++教学高级篇 3.1 文件操作

随着计算机硬件的发展,现代计算机通常配备了多核处理器,为并发编程提供了硬件基础。C++11引入了一组强大的多线程库,使得开发多线程应用程序变得更加容易和安全。本篇内容将详细介绍C++11的多线程基础、线程管理和同步机制(互斥量与条件变量),帮助掌握C++中的多线程编程技术。

C++11多线程基础

C++11标准库引入了多线程支持,提供了 'std::thread' 类用于创建和管理线程。使用 'std::thread' 类可以轻松地创建新线程并在其中执行代码。

创建线程

创建线程最基本的方式是将一个函数传递给 'std::thread' 构造函数。下面是一个简单的示例,演示了如何创建和启动一个线程:

cpp 复制代码
#include <iostream>
#include <thread>


void printMessage() {
    std::cout << "Hello from thread!" << std::endl;
}


int main() {
    std::thread t(printMessage);

    // 等待线程完成
    t.join();

    return 0;
}

在这段代码中,我们定义了一个名为 'printMessage' 的函数,并将其传递给 'std::thread' 构造函数来创建线程。使用 't.join()' 方法等待线程完成执行。

传递参数

可以通过构造函数将参数传递给线程函数,例如:

cpp 复制代码
#include <iostream>
#include <thread>


void printMessage(const std::string& message) {
    std::cout << message << std::endl;
}


int main() {
    std::string msg = "Hello from thread with parameters!";
    std::thread t(printMessage, msg);

    t.join();

    return 0;
}

在这段代码中,我们将一个字符串参数传递给 'printMessage' 函数,并在线程中打印该消息。

线程管理

线程管理包括线程的创建、同步和销毁。C++11标准库提供了多种工具来帮助管理线程。

分离线程

可以使用 'detach()' 方法将线程与主线程分离,允许线程在后台运行,例如:

cpp 复制代码
#include <iostream>
#include <thread>


void backgroundTask() {
    std::this_thread::sleep_for(std::chrono::seconds(2));
    std::cout << "Background task completed." << std::endl;
}


int main() {
    std::thread t(backgroundTask);

    t.detach();

    std::cout << "Main thread continues to run..." << std::endl;
    std::this_thread::sleep_for(std::chrono::seconds(3));

    return 0;
}

在这段代码中,我们使用 'detach()' 方法分离线程,使其在后台运行,而主线程继续执行。

线程同步

线程同步是确保多个线程安全地访问共享资源的关键。C++11提供了多种同步机制,如互斥量(mutex)和条件变量(condition variable)。

互斥量与条件变量

互斥量和条件变量是同步多个线程访问共享资源的基本工具。

互斥量

互斥量(mutex)用于保护共享资源,确保同一时间只有一个线程可以访问资源。C++11提供了 'std::mutex' 类来实现互斥量。

cpp 复制代码
#include <iostream>
#include <thread>
#include <mutex>


std::mutex mtx;


void printNumbers(int start, int end) {
    std::lock_guard<std::mutex> guard(mtx);

    for (int i = start; i <= end; ++i) {
        std::cout << i << " ";
    }
    std::cout << std::endl;
}


int main() {
    std::thread t1(printNumbers, 1, 5);
    std::thread t2(printNumbers, 6, 10);

    t1.join();
    t2.join();

    return 0;
}

在这段代码中,我们使用 'std::mutex' 保护共享资源,并使用 'std::lock_guard' 自动管理互斥量的锁定和解锁。

条件变量

条件变量(condition variable)用于在线程之间同步事件。C++11提供了 'std::condition_variable' 类来实现条件变量,例如:

cpp 复制代码
#include <iostream>
#include <thread>
#include <mutex>
#include <condition_variable>


std::mutex mtx;
std::condition_variable cv;


bool ready = false;


void printNumbers(int id) {
    std::unique_lock<std::mutex> lock(mtx);

    cv.wait(lock, [] { return ready; });

    std::cout << "Thread " << id << " is running." << std::endl;
}


void setReady() {
    std::unique_lock<std::mutex> lock(mtx);

    ready = true;

    cv.notify_all();
}


int main() {
    std::thread t1(printNumbers, 1);
    std::thread t2(printNumbers, 2);
    std::this_thread::sleep_for(std::chrono::seconds(1));

    setReady();

    t1.join();
    t2.join();

    return 0;
}

在这段代码中,我们使用 'std::condition_variable' 在线程之间同步事件。'cv.wait(lock, [] { return ready; })' 用于等待条件满足,而 'cv.notify_all()' 用于通知所有等待线程条件已满足。

总结

多线程与并发是C++编程中的重要概念,通过合理使用多线程技术,可以显著提高程序的性能和响应速度。C++11引入了一组强大的多线程库,使得多线程编程变得更加容易和安全。本篇内容详细介绍了C++11多线程基础、线程管理以及同步机制(互斥量与条件变量),希望通过这些内容,你能更好地掌握C++多线程编程技术,为编写高效、可靠的并发程序打下坚实的基础。

下一篇:白骑士的C++教学高级篇 3.3 内存管理​​​​​​​

相关推荐
leo__52021 小时前
基于C#与HALCON开发的完整视觉检测系统案例
开发语言·c#·视觉检测
天赐学c语言21 小时前
Linux - windows作为client访问linux服务端
linux·网络·c++
猿饵块21 小时前
python--sys
开发语言·python
故河21 小时前
Python工具:Conda 包管理器
开发语言·python·conda
亦复何言??21 小时前
ROS2 节点使用 Conda 环境运行 Python 依赖的解决方案
开发语言·python·conda
蜜獾云1 天前
设计模式之构造器模式:封装复杂对象的构造逻辑
java·开发语言·设计模式
娇娇yyyyyy1 天前
Qt编程(3): 信号和槽函数
开发语言·数据库·qt
wwww.wwww1 天前
qt程序执行时报错:无法定位程序输入点,但是通过IDE的run又可以正常的运行。
开发语言·ide·qt
乌鸦乌鸦你的小虎牙1 天前
qt 5.12.8 配置报错(交叉编译环境)
开发语言·数据库·qt
feifeigo1231 天前
Leslie人口模型MATLAB实现(中长期人口预测)
开发语言·matlab