C++宏定义方法的返回值


这个人呐,面个试都会紧张,一紧张就忘东西。。。哎

其实究其原因在于自己对知识了解没有深入到一定程度(自己:怪我咯)。

起因


今天被问到使用C++语言中的宏来求一年的秒数。

分析问题,其实秒数很容易计算嘛-> 天数 x 小时数 x 秒数

1小时 = 3600秒
1天 = 24小时
1年 = 闰年 ? 366 : 365 天

所以这个宏要怎么写呢?

当时想法

算了,想个简便办法,反正题目中也没什么规定,那我就写个
#define SECOND_OF_YEAR 365*24*3600
好了

仔细想想,你tm是不是个程序员啊?如果需求不清楚,那就去确定需求啊!如果需求清楚了,那你就把逻辑写完整啊!(痛骂自己一顿,切忌侥幸心理)

马后炮


那么完整的答案该怎么写呢?

#include 
#define SECOND_OF_YEAR(__YEAR__)  \
do {  \
  if (__YEAR__ % 100 != 0 && __YEAR__ % 4 == 0) {  \
    std::cout << 366 * 24 * 3600 << std::endl;  \
  } else {  \
    std::cout << 365 * 24 * 3600 << std::endl;  \
  }  \
} while (false)

测试代码:

SECOND_OF_YEAR(2004);   //闰年
SECOND_OF_YEAR(2003);   //非闰年
SECOND_OF_YEAR(2000);   //非闰年
//        int a = SECOND_OF_YEAR(2003);//不能赋值呀

输出结果:
31622400
31536000
31536000

这样算是一个答案,输入年份,在控制台打印出当年的秒数。
如果要把答案再完善一些怎么办呢?在宏定义中去调库函数获取当前年份好了。

扩展一下


从上面的代码又想到一个问题,就是上面测试代码中被注释的一句,就是如果我需要这个宏作为一个方法来使用,要求通过宏获得一个返回值。

一开始我的想法:

。。宏哪有什么返回值咯?如果你强行要返回值,那就在宏中对__YEAR__的值作一个修改,或者传入一个另外的参数,将计算结果赋值给这个参数咯。这样在调用过宏之后,也能得到计算结果。

所以使用这个宏时,可能变成这样:

int year = 2003;
SECOND_OF_YEAR(year);
std::cout << year << std::endl;

结果是这样:
31536000

哈哈,这样其实也挺好的!(好你妹啊,你个弱鸡)

如题的答案


如果真的要返回值,其实是可以做到的啊!
童鞋,你可还记得这样的代码:

int a = 1;
int b = 2;
int c = 3;
a = b = c;  //写成这样想必会更好理解 a = (b = c);
std::cout << a << "," << b << "," << c << std::endl;

输出结果:
3,3,3

上面的写法看得懂,那就好说了啊,直接上代码咯:

#define SECOND_OF_YEAR(__YEAR__)  \
({  \
int bLeap = false;  \
if (__YEAR__ % 100 != 0 && __YEAR__ % 4 == 0) bLeap = true;  \
else bLeap = false;\
bLeap ? 366 * 24 * 3600 : 365 * 24 * 3600;   \
})

测试代码:

int a = SECOND_OF_YEAR(2003);
std::cout << a << std::endl;

结果:
31536000

因为上面包含了语句,所以表达式中要用{}来包含语句,不能直接在()中写完整的语句。那如果我不想写这么大一堆怎么办?
其实下面一行代码就能解决这个问题:

#define SECOND_OF_YEAR(__YEAR__)  (__YEAR__ % 100 != 0 && __YEAR__ % 4 == 0) ? 366 * 24 * 3600 : 365 * 24 * 3600

功能同上。

了解这一块之后,其实宏定义能做的事,真的炒鸡多啊~

你可能感兴趣的:(C++宏定义方法的返回值)