C++ | 多线程编程(四) 信号量

C++ | 多线程编程(四) 信号量
https://zh.cppreference.com/w/cpp/thread/counting_semaphore
成员函数:

  • release:增加内部计数器并除阻获取者
    相当于V操作
  • acquire: 减少内部计数器或阻塞到直至能如此
    相当于p操作
#include <iostream>
#include <thread>
#include <semaphore>

using namespace std;

/*
三个线程,依次打印ABC
*/

std::counting_semaphore sema(1);
std::counting_semaphore semb(0);
std::counting_semaphore semc(0);

void thread_a()
{
	for (int i = 0; i < 10; ++i)
	{
		sema.acquire();	// p
		cout << "A";
		semb.release(); // v
	}
}
void thread_b()
{
	for (int i = 0; i < 10; ++i)
	{
		semb.acquire();	// p
		cout << "B";
		semc.release();
	}
}
void thread_c()
{
	for (int i = 0; i < 10; ++i)
	{
		semc.acquire();	// p
		cout << "C";
		sema.release();
	}
}

int main()
{
	std::thread ta(thread_a);
	std::thread tb(thread_b);
	std::thread tc(thread_c);

	ta.join();
	tb.join();
	tc.join();

	return 0;
}

C++ | 多线程编程(四) 信号量


#include <iostream>
#include <thread>
#include <semaphore>

using namespace std;

/*  生产者,消费者模型 */

std::counting_semaphore seamp(1);	// 生产者信号量
std::counting_semaphore seams(0);	// 消费者信号量
int num(0);


// 生产者
void producer_thread()
{
	while (num < 10)
	{
		seamp.acquire(); // p
		num += 1;
		cout << "producer: " << num << endl;
		seams.release();	// v
	}
}
void consumer_thread()
{
	while (num < 10)
	{
		seams.acquire();
		cout << "consumer: " << num << endl;
		seamp.release();
	}
}

int main()
{
	std::thread tp1(producer_thread);	// 生产者线程
	std::thread ts1(consumer_thread);	// 生产者线程

	tp1.join();
	ts1.join();

	return 0;
}

C++ | 多线程编程(四) 信号量

上一篇:线程通信中的限流应该如何做?


下一篇:递归锁