我最近发现了这个GCC宏:
#define max(a,b) ({ typeof (a) _a = (a); typeof (b) _b = (b); _a > _b ? _a : _b; })
在我看到这段代码之前我没有意识到,代码块{...}
可以某种方式在C中返回值。
1)你能给我一个暗示它是如何工作的吗?
虽然,我通常可以通过滥用逗号运算符来实现相同的结果:
#define max(a,b) (typeof (a) _a = (a), typeof (b) _b = (b), (_a > _b ? _a : _b))
或者如果只是为了副作用,我会使用do { ... } while(0)
2)这样做的首选方式是什么?
({ ... })
构造是gcc扩展。
类型操作符也是如此。
MAX
宏(注意全部大写的常规用法)很容易编写:
#define MAX(a, b) ((a) > (b) ? (a) : (b))
它不止一次地评估它的一个参数,所以你不应该调用它,例如, MAX(x++, y--)
。 全部大写字母的使用用于提醒用户它是一个宏,而不是一个函数,并且要注意带有副作用的参数。
或者您可以为每种类型编写一个函数(可能是内联函数)。
这是GCC的延伸。 逗号运算符不起作用:
// C89, doesn't work... #define max(a,b) (typeof (a) _a = (a), typeof (b) _b = (b), (_a > _b ? _a : _b))
逗号运算符仅适用于表达式,而typeof(a) _a = (a);
是宣言,而不是表达。 没有GCC扩展或C11(具有_Generic
写入等效宏是不可能的。 请注意, typeof
也是一个GCC扩展,所以除非你也消除了typeof
否则你不会通过消除({...})
获得任何可移植性。
这是一个C11版本,通过比较注意它是多么冗长(它只处理两种类型!)。 C11甚至还不支持,祝你好好找一个编译器来测试这个:
// C11 static inline int maxi(int x, int y) { return x > y ? x : y; } static inline long maxl(long x, long y) { return x > y ? x : y; } #define max(x, y) _Generic((x), long: maxl(x,y), int:_Generic((y), int: maxi(x,y), long: maxl(x,y)))
在便携式C99中,您可以编写一个实现相同效果的宏或内联函数, 除了它只适用于每个宏一种类型。
// C99 static inline int maxi(int x, int y) { return x > y ? x : y; }
在C89 / C90中,我想不出以任何方式编写宏,以至于它不会两次评估x
或y
。
需要了解更多c/c++开发分享`({…})`如何返回一个值?,也可以关注C/ C++技术分享栏目—计算机技术网(www.ctvol.com)!
以上就是c/c++开发分享`({…})`如何返回一个值?相关内容,想了解更多C/C++开发(异常处理)及C/C++游戏开发关注计算机技术网(www.ctvol.com)!)。
本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。
ctvol管理联系方式QQ:251552304
本文章地址:https://www.ctvol.com/c-cdevelopment/978826.html