C++之std::condition_variable::wait_for

std::condition_variable::wait_for 是 C++11 引入的条件变量的一部分,用于在一定时间内等待通知。它是 std::condition_variable 类的成员函数之一,可以使线程在等待某条件变为真时,最多等待指定的时间段。

使用方法

std::condition_variable 中,wait_for 的主要形式如下:


cpp

template< class Rep, class Period >
std::cv_status wait_for( std::unique_lock<std::mutex>& lock,
                         const std::chrono::duration<Rep,Period>& rel_time );
 
template< class Rep, class Period, class Predicate >
bool wait_for( std::unique_lock<std::mutex>& lock,
               const std::chrono::duration<Rep,Period>& rel_time,
               Predicate pred );
  • 第一种形式无谓词,等待特定的时间段或直到被其他线程通知。
  • 第二种形式带有谓词,等待特定的时间段或直到谓词返回 true

参数说明

  • lock:一个 std::unique_lock<std::mutex> 对象,负责在等待期间持有互斥锁。
  • rel_time:等待的相对时间,是 std::chrono::duration 类型。
  • pred:谓词(lambda 或可调用对象),用于判断条件是否满足。

返回值

  • 如果无谓词版本的 wait_for 在指定时间段内被唤醒,则返回 std::cv_status::no_timeout;如果超时则返回 std::cv_status::timeout
  • 如果带有谓词的 wait_for 在指定时间段内被唤醒并且谓词返回 true,则返回 true;否则返回 false

示例代码

以下是一个简单的示例,展示了如何使用 std::condition_variable::wait_for 来实现限时等待:


cpp

#include <iostream>
#include <thread>
#include <mutex>
#include <condition_variable>
#include <chrono>

std::mutex mtx;
std::condition_variable cv;
bool ready = false;

void worker() {
    std::this_thread::sleep_for(std::chrono::seconds(1)); // 模拟工作
    {
        std::lock_guard<std::mutex> lock(mtx);
        ready = true;
    }
    cv.notify_one(); // 通知等待的线程
}

int main() {
    std::thread t(worker);

    std::unique_lock<std::mutex> lock(mtx);
    if (cv.wait_for(lock, std::chrono::seconds(2), []{ return ready; })) {
        std::cout << "Worker线程已完成工作。" << std::endl;
    } else {
        std::cout << "等待超时。" << std::endl;
    }

    t.join();
    return 0;
}

在这个示例中:

  1. worker 线程模拟了一些工作,睡眠 1 秒后设置 readytrue 并通知主线程。
  2. 主线程启动 worker 线程并等待条件变量至多 2 秒,检查 ready 是否变为 true
  3. 如果在 2 秒内 ready 变为 true,则输出 "Worker线程已完成工作。",否则输出 "等待超时。"
  4. 在调用 wait_for 函数时,会在内部解锁 lock,并在等待期间重新获取锁。这样做是为了避免死锁,并且符合条件变量的使用惯例。

    具体地说,wait_for 函数会在等待之前释放 lock,使得其他线程可以在需要时获取该锁。当条件变量满足等待条件或超时后,wait_for 函数会重新获取 lock,并继续执行。

    因此,在使用 wait_for 函数时,无需手动在等待之前释放锁或在等待结束后重新获取锁,这些操作都由 wait_for 函数在内部处理。

通过这个示例,可以看到 std::condition_variable::wait_for 如何用于实现限时等待和条件判断,从而使得多线程编程更加灵活和高效。

### 如何在 IntelliJ IDEA 中创建 Spring Boot 项目 #### 准备工作 为了顺利创建一个 Spring Boot 项目,在开始之前需要确认已经安装并配置好了以下环境: - **Java JDK**:确保本地已安装适合的 Java 版本。 - **IntelliJ IDEA**:推荐使用 Ultimate 版本,因为它内置了对 Spring 的支持[^1]。 --- #### 创建 Spring Boot 项目的具体步骤 1. 打开 IntelliJ IDEA 并点击 `File` -> `New` -> `Project...` 来启动新建项目向导。 2. 在弹出的新建项目窗口中,选择左侧列表中的 `Spring Initializr`。这一步是基于官方提供的模板服务自动生成基础结构[^1]。 3. 配置 Maven 或 Gradle 构建工具的相关参数: - **Group**: 定义 Maven 工程的 GroupId,通常为公司域名反写形式(如 com.example)。 - **Artifact**: 输入模块名作为 ArtifactId,注意不能包含大写字母[^2]。 - **Name**: 自定义项目名称。 - **Package Name**: 自动生成的基础包路径。 - **Packaging**: 默认选择 jar 包即可,因为 Spring Boot 内嵌 Tomcat 支持通过命令行直接运行 jar 文件。 4. 如果国内网络访问速度较慢,可以选择替换默认的初始化 URL 地址为阿里云镜像站点 https://start.aliyun.com/,从而提高下载效率[^3]。 5. 进入依赖管理界面后勾选所需的 Starter Dependencies,对于基本 Web 应用只需添加 `Spring Web` 即可完成核心功能引入。 6. 点击下一步直至最终生成完毕,此时应该能看到标准目录布局下的 src/main/java 和 resources 子文件夹[^1]。 7. 编辑器会自动加载 pom.xml (如果是 Maven) 或 build.gradle (如果是 Gradle),其中列出了所有必要的库版本号等信息。 8. 启动应用程序类上的 main 方法验证是否成功部署到内存中的服务器实例上。 --- ```java @SpringBootApplication public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } } ``` --- #### 常见问题排查 如果按照以上流程操作仍然遇到异常情况,则可以从以下几个角度入手解决: - 检查互联网连接状态良好与否; - 更改仓库源至更稳定的地址比如阿里的开源镜像站; - 查看日志输出定位具体的错误提示语句进一步分析原因所在。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值