legongju.com
我们一直在努力
2025-02-05 02:44 | 星期三

C++信号量如何控制资源访问

在C++中,信号量(semaphore)是一种用于控制多个进程或线程对共享资源访问的同步原语

  1. 包含头文件:首先,需要包含头文件以使用信号量功能。
#include 
  1. 初始化信号量:在程序中创建一个信号量对象,并设置其初始值。这个值表示可以同时访问共享资源的线程数。
sem_t sem;
sem_init(&sem, 0, 1); // 初始化信号量,初始值为1

这里,sem_init函数的第一个参数是一个指向信号量对象的指针,第二个参数是信号量的共享属性(0表示共享,1表示独占),第三个参数是信号量的初始值。

  1. 访问共享资源:在访问共享资源之前,线程需要等待信号量变为可用状态。可以使用sem_waitsem_trywait函数实现。
sem_wait(&sem); // 等待信号量变为可用状态
// 访问共享资源

如果信号量的值为0,sem_wait函数会阻塞线程,直到信号量变为可用状态。sem_trywait函数则尝试立即获取信号量,如果信号量不可用,它会立即返回一个错误代码,而不是阻塞线程。

  1. 释放信号量:在访问完共享资源后,线程需要释放信号量,以便其他等待的线程可以获取信号量并访问共享资源。可以使用sem_post函数实现。
// 访问完共享资源后
sem_post(&sem); // 释放信号量

sem_post函数会将信号量的值加1,表示一个资源已经被释放。

  1. 销毁信号量:当所有线程都完成对共享资源的访问后,需要销毁信号量对象。可以使用sem_destroy函数实现。
sem_destroy(&sem); // 销毁信号量对象

这是一个简单的C++信号量示例,用于控制对共享资源的访问:

#include 
#include 
#include 

std::mutex mtx;
sem_t sem;
int shared_resource = 0;

void thread_func(int id) {
    sem_wait(&sem); // 等待信号量变为可用状态

    std::unique_lock lock(mtx);
    std::cout << "Thread " << id << " is accessing the shared resource." << std::endl;
    shared_resource++;
    lock.unlock();

    // 模拟访问共享资源的时间
    std::this_thread::sleep_for(std::chrono::milliseconds(100));

    lock.lock();
    std::cout << "Thread " << id << " has finished accessing the shared resource." << std::endl;
    shared_resource--;
    lock.unlock();

    sem_post(&sem); // 释放信号量
}

int main() {
    const int num_threads = 5;
    std::thread threads[num_threads];

    sem_init(&sem, 0, 1); // 初始化信号量,初始值为1

    for (int i = 0; i < num_threads; ++i) {
        threads[i] = std::thread(thread_func, i);
    }

    for (int i = 0; i < num_threads; ++i) {
        threads[i].join();
    }

    sem_destroy(&sem); // 销毁信号量对象

    return 0;
}

在这个示例中,我们创建了一个信号量来控制对共享资源shared_resource的访问。信号量的初始值为1,表示同一时间只有一个线程可以访问共享资源。其他线程需要等待信号量变为可用状态才能访问共享资源。

未经允许不得转载 » 本文链接:https://www.legongju.com/article/14155.html

相关推荐

  • c++ mysql库的数据更新与删除操作

    c++ mysql库的数据更新与删除操作

    在C++中,可以使用MySQL C++ Connector库来进行数据更新和删除操作。以下是一个简单的示例代码,展示如何使用MySQL C++ Connector库来进行数据更新和删除操作:<...

  • c++ memset_s与memset有何不同

    c++ memset_s与memset有何不同

    memset_s 和 memset 都是 C++ 中用于设置内存区域的函数,但它们之间存在一些关键差异 安全性:memset_s 是一个更安全的版本,因为它会检查目标缓冲区的大小。如...

  • c++中使用memset_s需要注意什么

    c++中使用memset_s需要注意什么

    在C++中,memset_s函数是一个安全的内存设置函数,它可以防止缓冲区溢出 包含头文件:在使用memset_s之前,请确保已经包含了正确的头文件。对于C++,应该包含头文...

  • c++ memset_s如何安全清零内存

    c++ memset_s如何安全清零内存

    在C++中,memset_s是一个安全的方法来清零内存
    #include
    #include int main() { char buffer[100]; // 填充缓冲区 for (int i = 0; i< sizeof(buffer)...

  • C++原子操作如何降低开发难度

    C++原子操作如何降低开发难度

    C++11 引入了原子操作(atomic operations),它们是一种特殊的操作,可以在多线程环境中保证原子性,即不会被其他线程中断。原子操作可以降低开发难度,因为它们...

  • C++原子操作能简化代码逻辑吗

    C++原子操作能简化代码逻辑吗

    C++原子操作(atomic operations)是一种特殊的操作,它们可以在多线程环境中保证原子性,即这些操作在执行过程中不会被其他线程中断。原子操作可以简化代码逻辑...

  • C++原子操作有哪些注意事项

    C++原子操作有哪些注意事项

    C++中的原子操作是一种特殊的操作,它们可以在多线程环境中保证操作的原子性,即不会被其他线程中断。在使用C++原子操作时,需要注意以下几点: 原子操作不是线程...

  • C++原子操作怎样提升系统稳定性

    C++原子操作怎样提升系统稳定性

    C++原子操作(atomic operations)是一种特殊的操作,它们可以在多线程环境中保证原子性,即操作在执行过程中不会被其他线程中断。这有助于避免数据竞争(data r...