白骑士的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 内存管理​​​​​​​

相关推荐
飞飞-躺着更舒服22 分钟前
【QT】实现电子飞行显示器(改进版)
开发语言·qt
武昌库里写JAVA38 分钟前
Java成长之路(一)--SpringBoot基础学习--SpringBoot代码测试
java·开发语言·spring boot·学习·课程设计
CYBEREXP20081 小时前
MacOS M3源代码编译Qt6.8.1
c++·qt·macos
ZSYP-S1 小时前
Day 15:Spring 框架基础
java·开发语言·数据结构·后端·spring
yuanbenshidiaos1 小时前
c++------------------函数
开发语言·c++
yuanbenshidiaos1 小时前
C++----------函数的调用机制
java·c++·算法
程序员_三木1 小时前
Three.js入门-Raycaster鼠标拾取详解与应用
开发语言·javascript·计算机外设·webgl·three.js
是小崔啊2 小时前
开源轮子 - EasyExcel01(核心api)
java·开发语言·开源·excel·阿里巴巴
tianmu_sama2 小时前
[Effective C++]条款38-39 复合和private继承
开发语言·c++
黄公子学安全2 小时前
Java的基础概念(一)
java·开发语言·python