C++多线程编程(2):四种线程管理方法

文章首发于我的个人博客:欢迎大佬们来逛逛

文章目录

线程管理

有一个this_thread的名称空间中定义了许多的线程管理方法:

  • get_id:获取当前线程id
  • sleep_for:当前线程休眠一段时间
  • sleep_for:当前线程休眠,直到某个时间点之后结束休眠
  • yield:当前线程立刻被抛弃,释放CPU时间片

get_id

获取当前线程id,每个线程的id都是唯一的,并且也可以获取主线程的id:

cpp 复制代码
//获取线程Id
void threadID() {
	std::cout << "Id: " << std::this_thread::get_id() << '\n';
}

sleep_for

chrono库提供了许多关于时间的操作,在我们接下来的介绍中需要用到。

当前线程休眠一段时间,其中一段时间是你自己给出的。

实际上调用这个函数会立刻使得线程从运行态转为阻塞状态,并且休眠一段时间。

位于阻塞态会让出当前的CPU资源,因此可以使得其他线程使用他让出的CPU资源,提高资源的利用率。

线程的五种状态:创建,就绪,运行,阻塞,终止

函数原型如下:

  • chrono::duration:表示一个时间段。
cpp 复制代码
void sleep_for(const chrono::duration<...>& durationTime)

具体如何传参?

cpp 复制代码
std::this_thread::sleep_for(std::chrono::seconds(2));  // 休眠两秒
std::this_thread::sleep_for(std::chrono::microseconds(2000)); //休眠两千毫秒

还有minutes,hours等等。

cpp 复制代码
//sleep_for延迟函数
void testSleep_for() {
	std::cout << "子线程sleep_for: \n";
	std::this_thread::sleep_for(std::chrono::seconds(2));
	std::cout << "子线程sleep_for结束: \n";
}

sleep_until

该函数与上面的函数类似,只不过他接受一个时间点 ,上面的sleep_for是一个时间段

cpp 复制代码
void sleep_until(const chrono::time_point<...>& _Abs_time)

对于chrono如何表示一个时间点**time_point** 有以下方法:

  • system_clock:获取系统时间

  • steady_clock: 表示稳定时间间隔,即不随系统时间修改而变化的时间间隔。

  • high_resolution_clock: 实际上就是上一种

    cpp 复制代码
    using high_resolution_clock = steady_clock;

如何获取当前时间?

使用now()函数

以下三种根据情况使用,都可以作为sleep_until的参数。

cpp 复制代码
std::chrono::high_resolution_clock::now();
std::chrono::system_clock::now();
std::chrono::steady_colck::now();

具体应用:

使得每次打印间隔两秒 的时间间隔,如下我们构造了一个时间点

实际上与sleep_for类似,只不过sleep_for表示一个时间段,sleep_until表示到...为止,是一个时间点。

cpp 复制代码
std::cout << "子线程Sleep_untild: \n";
	for (int i = 1; i <= 10; i++) {
		auto startTime = std::chrono::steady_clock::now();
		std::this_thread::sleep_until(startTime+std::chrono::seconds(2));
		std::cout << "i= " << i << '\n';
	}
std::cout << "子线程Sleep_untild结束: \n";

yield

该函数表示立刻抛弃(立刻停止)此线程,释放CPU时间片,并且立刻使得该线程从运行转到就绪状态

注意虽然抛弃了此线程,释放了CPU的资源,但是它仍然会参与到下一轮的线程CPU时间片的争夺中,也就是说我调用了这个函数函数,为什么感觉没有什么用呢?实际上这是一个概率问题。

案例:

每执行一次循环,让该线程主动放弃 CPU 资源重新和其他线程再次抢夺 CPU 时间片,如果其他线程抢到了 CPU 时间片就可以执行相应的任务了。

否则容易出现其他线程没有机会执行的困难。

cpp 复制代码
void testYield2(int id) {
	for (int i = 1; i <= 1000; i++) {
		std::cout << "id: " <<id << ": " << i << '\n';
		std::this_thread::yield();
	}
}

...
std::thread t3(testYield2, 1);
std::thread t4(testYield2, 2);
t3.join();
t4.join();
相关推荐
yashuk13 小时前
C语言 vs. C++ ,哪个更适合初学者?
c语言·c++·面向对象编程·初学者·学习路径
-许平安-13 小时前
MCP项目笔记十(客户端 MCPClient)
c++·笔记·ai·raii·mcp·pluginapi·plugin system
一只旭宝13 小时前
【C++ 入门精讲2】函数重载、默认参数、函数指针、volatile | 手写笔记(附完整代码)
c++·笔记
旖-旎13 小时前
哈希表(存在重复元素||)(4)
数据结构·c++·算法·leetcode·哈希算法·散列表
John.Lewis13 小时前
C++进阶(8)智能指针
开发语言·c++·笔记
無限進步D13 小时前
蓝桥杯赛前刷题
c++·算法·蓝桥杯·竞赛
小贾要学习13 小时前
【Linux】应用层自定义协议与序列化
linux·服务器·c++·json
CoderCodingNo13 小时前
【GESP】C++二级真题 luogu-B4497, [GESP202603 二级] 数数
开发语言·c++·算法
郝学胜-神的一滴14 小时前
[简化版 GAMES 101] 计算机图形学 04:二维变换上
c++·算法·unity·godot·图形渲染·unreal engine·cesium
来日可期131414 小时前
C/C++ 反常识记录(1)—— 那些容易踩坑的语法细节
c语言·开发语言·c++