Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimana untuk menggunakan C++ untuk pengaturcaraan serentak yang cekap?

Bagaimana untuk menggunakan C++ untuk pengaturcaraan serentak yang cekap?

王林
王林asal
2023-08-26 16:32:001351semak imbas

Bagaimana untuk menggunakan C++ untuk pengaturcaraan serentak yang cekap?

Bagaimana untuk menggunakan C++ untuk pengaturcaraan serentak yang cekap?

Pengenalan:
Dengan pembangunan sistem komputer, pempopularan teknologi berbilang teras, dan peningkatan permintaan untuk pemprosesan serentak yang tinggi, pengaturcaraan serentak telah menjadi semakin penting. C++ ialah bahasa pengaturcaraan yang berkuasa dengan set kaya alat pengaturcaraan serentak dan perpustakaan. Artikel ini menerangkan cara menggunakan C++ untuk pengaturcaraan serentak yang cekap dan menyediakan beberapa kod sampel.

1. Pengurusan utas dan utas:

  1. Mencipta utas:
    C++ 11 memperkenalkan fail pengepala <thread></thread>, yang boleh dibuat dengan mudah melalui std::thread kod> kelas Benang baharu. Berikut ialah contoh kod untuk mencipta utas: <thread></thread> 头文件,通过 std::thread 类可以轻松创建新线程。以下是创建线程的示例代码:
#include <iostream>
#include <thread>

void myFunction() {
    std::cout << "This is a new thread." << std::endl;
}

int main() {
    std::thread t(myFunction);  // 创建一个新线程
    t.join();  // 主线程等待新线程执行完毕
    return 0;
}
  1. 线程管理:
    std::thread 类的实例可以 join()detach(),当调用 join() 时,主线程将等待该线程执行完毕,而 detach() 则会让新线程在后台运行。以下是线程管理的示例代码:
#include <iostream>
#include <thread>

void myFunction() {
    std::cout << "This is a new thread." << std::endl;
}

int main() {
    std::thread t(myFunction);  // 创建一个新线程
    t.detach();  // 将线程设置为后台运行
    // 主线程可以继续执行其他任务
    return 0;
}

二、互斥锁和条件变量:

  1. 互斥锁:
    互斥锁(Mutex)用于保护共享资源,避免多个线程同时对资源进行访问而导致冲突。以下是互斥锁的示例代码:
#include <iostream>
#include <thread>
#include <mutex>

std::mutex mtx;  // 创建互斥锁

void myFunction() {
    mtx.lock();  // 加锁
    std::cout << "This is a critical section." << std::endl;
    mtx.unlock();  // 解锁
}

int main() {
    std::thread t1(myFunction);
    std::thread t2(myFunction);
    t1.join();
    t2.join();
    return 0;
}
  1. 条件变量:
    条件变量(Condition Variable)用于线程间的同步,可以阻塞一个线程,直到其他线程满足某个条件才唤醒它。以下是条件变量的示例代码:
#include <iostream>
#include <thread>
#include <mutex>
#include <condition_variable>

std::mutex mtx;  // 创建互斥锁
std::condition_variable cv;  // 创建条件变量
bool ready = false;  // 条件

void myFunction() {
    std::unique_lock<std::mutex> ul(mtx);
    cv.wait(ul, []{ return ready; });  // 阻塞线程直到满足条件
    std::cout << "This is a new thread." << std::endl;
}

int main() {
    std::thread t(myFunction);
    {
        std::lock_guard<std::mutex> lg(mtx);
        ready = true;
    }
    cv.notify_one();  // 唤醒等待条件的线程
    t.join();
    return 0;
}

三、并发容器:
C++ 11 引入了多个并发容器来解决多线程访问共享数据的问题,其中包括 std::vectorstd::mapstd::queue 等。以下是使用并发容器的示例代码:

#include <iostream>
#include <thread>
#include <vector>

std::vector<int> sharedVector;  // 共享容器
std::mutex mtx;  // 创建互斥锁

void producer() {
    for (int i = 0; i < 10; ++i) {
        std::lock_guard<std::mutex> lg(mtx);
        sharedVector.push_back(i);
    }
}

void consumer() {
    for (int i = 0; i < 10; ++i) {
        std::lock_guard<std::mutex> lg(mtx);
        if (!sharedVector.empty()) {
            std::cout << sharedVector.back() << std::endl;
            sharedVector.pop_back();
        }
    }
}

int main() {
    std::thread t1(producer);
    std::thread t2(consumer);
    t1.join();
    t2.join();
    return 0;
}

结论:
使用 C++ 进行高效的并发编程是一项重要的技术要求。通过深入了解 C++ 的线程、互斥锁、条件变量和并发容器,我们可以更好地处理多线程编程中的数据共享和同步问题,并提高程序的性能和效率。

参考资料:

  1. C++ Reference - <thread></thread>:https://www.cplusplus.com/reference/thread/
  2. C++ Reference - <mutex></mutex>:https://www.cplusplus.com/reference/mutex/
  3. C++ Reference - <condition_variable></condition_variable>
  4. rrreee
      Pengurusan utas: 🎜std::thread Kejadian kelas boleh menjadi join() atau detach(), apabila memanggil join(), utas utama akan menunggu sehingga thread selesai melaksanakan, manakala detach() code> akan membiarkan utas baharu Berjalan di latar belakang. Berikut ialah contoh kod untuk pengurusan benang: 🎜🎜rrreee🎜 2. Kunci Mutex dan pembolehubah keadaan: 🎜🎜🎜Kunci Mutex: 🎜Kunci Mutex (Mutex) digunakan untuk melindungi sumber dikongsi dan menghalang berbilang benang daripada mengakses sumber pada masa yang sama masa dan membawa kepada konflik. Berikut ialah kod sampel untuk kunci mutex: 🎜🎜rrreee<ol start="2">🎜Pembolehubah keadaan: 🎜Pembolehubah keadaan (Pembolehubah Keadaan) digunakan untuk penyegerakan antara utas dan boleh menyekat utas sehingga utas lain memenuhi tertentu syarat Bangun saja. Berikut ialah contoh kod untuk pembolehubah keadaan: 🎜🎜rrreee🎜 3. Bekas serentak: 🎜C++ 11 memperkenalkan berbilang bekas serentak untuk menyelesaikan masalah akses berbilang benang kepada data kongsi, termasuk <code>std::vector code>, <code>std::map, std::queue, dsb. Berikut ialah contoh kod menggunakan bekas serentak: 🎜rrreee🎜Kesimpulan: 🎜Pengaturcaraan serentak yang cekap dalam C++ ialah keperluan teknikal yang penting. Dengan mempunyai pemahaman yang mendalam tentang benang C++, mutex, pembolehubah keadaan dan bekas serentak, kami boleh mengendalikan isu perkongsian data dan penyegerakan dengan lebih baik dalam pengaturcaraan berbilang benang, serta meningkatkan prestasi dan kecekapan program. 🎜🎜Rujukan: 🎜🎜🎜Rujukan C++ - <thread></thread>: https://www.cplusplus.com/reference/thread/🎜🎜C++ Rujukan - :https://www.cplusplus.com/reference/mutex/🎜🎜C++ Rujukan - <condition_variable></condition_variable>:https://www.cplusplus.com/reference/condition_variable/🎜 🎜

    Atas ialah kandungan terperinci Bagaimana untuk menggunakan C++ untuk pengaturcaraan serentak yang cekap?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

    Kenyataan:
    Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn