ifdef,=,+=:=,?=

equal:

ifdef ($(HUAN))
        RESULT = YES
else
        RESULT = NO
endif

ifeq ($(HUAN1),)
        RESULT1 = YES
else
        RESULT1 = NO
endif
all:
    @echo $(RESULT)



equal2:

ifdef DEFINE_VRE
    VRE = “Hello World!”
else
endif

ifeq ($(OPT),define)
    VRE ?= “Hello World! First!”
endif

ifeq ($(OPT),add)
    VRE += “Kelly!”
endif

ifeq ($(OPT),recover)
    VRE := “Hello World! Again!”
endif

all:
    @echo $(VRE)

          



equal是测试ifdef到底应该如何输入可以进入分支

测试用例是:
make HUAN=HUNA1=DEFINE
输出yes
make HUAN= HUNA1=define
输出NO
make HUAN=true HUNA1=DEFINE
输出yes

equal2是测试= := ?= +=
测试用例:
make DEFINE_VRE=true OPT=define 输出:Hello World!
make DEFINE_VRE=true OPT=add 输出:Hello World! Kelly!
make DEFINE_VRE=true OPT=recover 输出:Hello World! Again!
make DEFINE_VRE= OPT=define 输出:Hello World! First!
make DEFINE_VRE= OPT=add 输出:Kelly!
make DEFINE_VRE= OPT=recover 输出:Hello World! Again!

从上面的结果中我们可以清楚的看到他们的区别了
= 是最基本的赋值
:= 是覆盖之前的值
?= 是如果没有被赋值过就赋予等号后面的值
+= 是添加等号后面的值

      1、“=”

      make会将整个makefile展开后,再决定变量的值。也就是说,变量的值将会是整个makefile中最后被指定的值。看例子:

            x = foo
            y = $(x) bar
            x = xyz

      在上例中,y的值将会是 xyz bar ,而不是 foo bar 。

      2、“:=”

      “:=”表示变量的值决定于它在makefile中的位置,而不是整个makefile展开后的最终值。

            x := foo
            y := $(x) bar
            x := xyz

      在上例中,y的值将会是 foo bar ,而不是 xyz bar 了。


### 关于 `std::chrono` 命名空间中的错误分析 当使用 C++ 的 `std::chrono` 命名空间时,常见的报错可能源于以下几个方面: #### 编译器版本不兼容 如果使用的 g++ 版本低于 4.6,则需要显式指定 `-std=c++0x` 或者更高标准的编译选项来启用 C++11 功能[^1]。对于现代编译器(如 GCC 4.9 及以上),推荐使用 `-std=c++11` 或更高的标准。 ```bash g++ -std=c++11 your_code.cpp -o output_program ``` #### 替代实现的选择 在某些旧版本的 g++ 中,可能会遇到缺少 `std::chrono::steady_clock` 支持的情况。此时可以考虑使用 `boost::asio` 提供的功能作为替代方案,并通过定义宏 `BOOST_ASIO_DISABLE_STD_CHRONO` 来禁用标准库的支持[^1]。 ```cpp #define BOOST_ASIO_DISABLE_STD_CHRONO #include <boost/asio.hpp> #include <iostream> int main() { auto now = boost::asio::steady_timer::clock_type::now(); std::cout << "Current time: " << now.time_since_epoch().count() << "\n"; } ``` #### 错误原因排查 以下是可能导致 `std::chrono::steady_clock` 和 `std::chrono::duration_cast` 报错的一些常见场景及其解决方案: 1. **未正确包含头文件** 如果忘记包含 `<chrono>` 头文件,会导致无法识别 `std::chrono` 名字空间下的任何功能。 ```cpp #include <chrono> // Ensure this line exists at the top of your file. ``` 2. **类型转换问题** 使用 `std::chrono::duration_cast` 进行时间单位之间的转换时,需确保源时间和目标时间类型的匹配性。例如,尝试将秒数转换为毫秒数时应如下操作: ```cpp using namespace std::chrono; steady_clock::time_point start_time = steady_clock::now(); duration<int, std::milli> elapsed_ms = duration_cast<milliseconds>(steady_clock::now() - start_time); std::cout << "Elapsed milliseconds: " << elapsed_ms.count() << "\n"; ``` 3. **跨平台差异** 不同的操作系统对 `std::chrono::steady_clock` 的实现可能存在细微差别。因此,在移植代码到其他环境前务必测试其行为一致性。 --- ### 示例程序展示如何正确运用 `std::chrono` 下面给出一段完整的示例代码演示了如何利用 `std::chrono` 记录一段时间间隔并将其转化为不同单位表示形式。 ```cpp #include <iostream> #include <thread> #include <chrono> using namespace std::chrono; int main(){ high_resolution_clock::time_point t1 = high_resolution_clock::now(); std::this_thread::sleep_for(seconds(2)); high_resolution_clock::time_point t2 = high_resolution_clock::now(); duration<double> time_span = duration_cast<duration<double>>(t2-t1); std::cout << "It took me " << time_span.count() << " seconds.\n"; return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值