C++11多线程之yield
2016-06-10 21:10
246 查看
原文: http://en.cppreference.com/w/cpp/thread/yield
std::this_thread::yield
定义在头文件<thread>中
void yield(); (since C++11)
对具体实现(译注:具体实现指的是操作系统的调度器)提出一个提醒以重新规划线程的执行,即让其他线程先运行。
注意:
该方法的具体行为取决于实现,尤其是正在使用的操作系统调度器的机制以及系统的状态。比如,一个先进先出的实时调度器(Linux中的SCHED_FIFO)将会使当前线程暂停,并将其置于同优先级线程队列的末尾(如果同优先级线程队列里没有其他线程,yield就没有效果了。)
示例程序:
可能的输出:
(完)
std::this_thread::yield
定义在头文件<thread>中
void yield(); (since C++11)
对具体实现(译注:具体实现指的是操作系统的调度器)提出一个提醒以重新规划线程的执行,即让其他线程先运行。
注意:
该方法的具体行为取决于实现,尤其是正在使用的操作系统调度器的机制以及系统的状态。比如,一个先进先出的实时调度器(Linux中的SCHED_FIFO)将会使当前线程暂停,并将其置于同优先级线程队列的末尾(如果同优先级线程队列里没有其他线程,yield就没有效果了。)
示例程序:
#include <iostream> #include <chrono> #include <thread> // "busy sleep" while suggesting that other threads run // for a small amount of time void little_sleep(std::chrono::microseconds us) { auto start = std::chrono::high_resolution_clock::now(); auto end = start + us; do { std::this_thread::yield(); } while (std::chrono::high_resolution_clock::now() < end); } int main() { auto start = std::chrono::high_resolution_clock::now(); little_sleep(std::chrono::microseconds(100)); auto elapsed = std::chrono::high_resolution_clock::now() - start; std::cout << "waited for " << std::chrono::duration_cast<std::chrono::microseconds>(elapsed).count() << " microseconds\n"; }
可能的输出:
waited for 101 microseconds
(完)
相关文章推荐
- 使用C++实现JNI接口需要注意的事项
- Python3写爬虫(四)多线程实现数据爬取
- c++11 + SDL2 + ffmpeg +OpenAL + java = Android播放器
- 关于指针的一些事情
- c++ primer 第五版 笔记前言
- share_ptr的几个注意点
- C#实现多线程的同步方法实例分析
- Lua中调用C++函数示例
- 浅谈chuck-lua中的多线程
- Lua教程(一):在C++中嵌入Lua脚本
- Lua教程(二):C++和Lua相互传递数据示例
- C#简单多线程同步和优先权用法实例
- C#多线程学习之(四)使用线程池进行多线程的自动管理
- C#多线程编程中的锁系统(三)
- 解析C#多线程编程中异步多线程的实现及线程池的使用
- C#多线程学习之(六)互斥对象用法实例
- 基于一个应用程序多线程误用的分析详解
- C++联合体转换成C#结构的实现方法
- C#多线程学习之(三)生产者和消费者用法分析
- C#多线程学习之(一)多线程的相关概念分析