选择性内联函数(用于调试目的)?

时间:2012-06-12 19:59:06

标签: c++ inline

我喜欢的是一个构建配置,其中函数内联,除了一些选定的函数(可能会或可能不会内联,这将是直到编译器)。

更好的是某种“内联级别”,我可以为每个函数指定这样的级别,加上构建时的最低级别,并且只允许内联最高级别的函数。我知道没有标准的解决方案,但编译器特定的黑客也同样受欢迎。

我希望能够在调试器中逐步完成我的大多数非内联函数,但是应该内联其中一些函数,部分是出于性能原因,部分是为了避免疯狂深度调用堆栈。代码涉及一些非常令人讨厌的模板元编程,但这部分大部分已完成,所以我想专注于其余部分。因此,将属于模板元程序的函数内联,而不是其他内联函数会很好。

有没有办法实现这样的目标?

2 个答案:

答案 0 :(得分:8)

取决于您的编译器,是的。对于g ++,以下内容将起作用:

void foo() __attribute__ ((noinline));
void foo() __attribute__ ((always_inline));

在MSVC ++上:

__declspec(noinline) void foo();
__forceinline void foo();

请注意,g ++ 要求属性仅应用于原型,而不是定义。因此,如果您的函数只是定义(没有单独的原型),那么您必须创建一个原型才能应用该属性。 MSVC没有这个要求。

__forceinline具体为some exceptions。请务必仔细阅读,以便了解它是否会对您的特定情况产生任何影响。 g ++没有记录always_inline属性的任何异常,但有些事情很明显(内联对虚方法的调用仅在静态调用方法时才有效。)

您可以使用宏来概括:

#ifdef _MSC_VER
 #define NOINLINE(x) __declspec(noinline) x
 #define INLINE(X) __forceinline x
#else
 #ifdef __GNUC__
  #define NOINLINE(x) x __attribute__ ((noinline))
  #define INLINE(x) x __attribute__ ((always_inline))
 #else
  #error "I don't know how to force inline/noinline on your compiler."
 #endif
#endif

INLINE(void foo());
NOINLINE(void foo());

答案 1 :(得分:1)

如果您想要inline d的一组功能,您可以#define某个宏(假设GCC或Clang)到__attribute__(__always_inline__),这将

  1. 始终内联函数
  2. 如果出于技术原因无法进行编译错误。