4

我想要的是一个构建配置,其中函数没有内联,除了一些选定的函数(可能内联也可能不内联,这取决于编译器)。

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

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

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

4

2 回答 2

8

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

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

在 MSVC++ 上:

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

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

__forceinline具体有一些例外。请务必仔细阅读它们,以便了解它是否会对您的特定情况产生任何影响。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());
于 2012-06-12T20:10:00.683 回答
1

如果有一组你想要的函数inline,你可以使用#define一些宏(假设是 GCC 或 Clang)__attribute__(__always_inline__),这将

  1. 始终内联函数
  2. 如果由于技术原因无法实现,则给出编译错误。
于 2012-06-12T20:11:50.903 回答