如果你的其他逻辑必须在线程 t1
和 t2
之后执行,但你又希望这些线程能够同时运行,你可以在主线程中使用 std::thread::detach
将线程分离,让它们在后台运行。这样,主线程不会等待这些线程的完成,而可以继续执行其他逻辑。
这里是一个示例:
#include <iostream>
#include <thread>
#include <ctime>
#include <chrono>
#include <windows.h>
void test_thread_1()
{
while (true) {
std::cout << "test1" << std::endl;
std::this_thread::sleep_for(std::chrono::seconds(5));
}
}
void test_thread_2()
{
while (true) {
std::cout << "test2" << std::endl;
std::this_thread::sleep_for(std::chrono::seconds(3));
}
}
int main()
{
std::cout << "Hello World!\n";
std::thread t1(test_thread_1);
std::thread t2(test_thread_2);
// 分离线程,让它们在后台运行
t1.detach();
t2.detach();
// 执行其他逻辑,这里不会等待t1和t2的完成
// 等待用户输入或其他操作,确保程序不会立即退出
std::cin.get();
return 0;
}
这样,t1
和 t2
将在后台运行,主线程可以继续执行其他逻辑。请注意,一旦线程被分离,你就不能再使用 join
来等待它们的完成。但要注意,线程分离后,程序退出时这些线程可能仍在运行。确保在程序退出前适当地等待或结束这些线程。