调查 visual studio 汇编输出
investigating visual studio assembly output
在使用 /FA 选项编译使用此虚拟对象的代码时 class
class A {
public:
A() {}
int Initialize() {
return 0;
}
};
我查看了生成的 asm 文件,其中定义并使用了它,并在 asm 文件中看到了这个
PUBLIC ?Initialize@A@@QEAAHXZ ; A::Initialize
PUBLIC ??0A@@QEAA@H@Z ; A::A
??0A@@QEAA@H@Z PROC ; A::A, COMDAT
; File d:\dev\temp\consoleapplication1\consoleapplication1\consoleapp2.cpp
; Line 7
mov rax, rcx
ret 0
??0A@@QEAA@H@Z ENDP ; A::A
_TEXT ENDS
; Function compile flags: /Ogtpy
; COMDAT ?Initialize@A@@QEAAHXZ
_TEXT SEGMENT
this$dead$ = 8
?Initialize@A@@QEAAHXZ PROC ; A::Initialize, COMDAT
; File d:\dev\temp\consoleapplication1\consoleapplication1\consoleapp2.cpp
; Line 9
xor eax, eax
; Line 10
ret 0
?Initialize@A@@QEAAHXZ ENDP ; A::Initialize
如您所见,为构造函数和 Initialize 函数生成了 "trivial" 个实现函数。
起初我以为这个非内联实现将用于使用 class A 的地方,但调试显示情况并非如此(代码似乎是内联的)。 Class 除了这个 asm 文件之外,A 没有在其他任何地方使用,所以如果不使用,为什么会生成这些函数?
整个程序优化到位。
"so why are those functions generated if not used ?"
您正在检查为单个翻译单元生成的汇编代码,而不是链接后的最终汇编。
链接器最终会删除所有未使用的函数。
在使用 /FA 选项编译使用此虚拟对象的代码时 class
class A {
public:
A() {}
int Initialize() {
return 0;
}
};
我查看了生成的 asm 文件,其中定义并使用了它,并在 asm 文件中看到了这个
PUBLIC ?Initialize@A@@QEAAHXZ ; A::Initialize
PUBLIC ??0A@@QEAA@H@Z ; A::A
??0A@@QEAA@H@Z PROC ; A::A, COMDAT
; File d:\dev\temp\consoleapplication1\consoleapplication1\consoleapp2.cpp
; Line 7
mov rax, rcx
ret 0
??0A@@QEAA@H@Z ENDP ; A::A
_TEXT ENDS
; Function compile flags: /Ogtpy
; COMDAT ?Initialize@A@@QEAAHXZ
_TEXT SEGMENT
this$dead$ = 8
?Initialize@A@@QEAAHXZ PROC ; A::Initialize, COMDAT
; File d:\dev\temp\consoleapplication1\consoleapplication1\consoleapp2.cpp
; Line 9
xor eax, eax
; Line 10
ret 0
?Initialize@A@@QEAAHXZ ENDP ; A::Initialize
如您所见,为构造函数和 Initialize 函数生成了 "trivial" 个实现函数。
起初我以为这个非内联实现将用于使用 class A 的地方,但调试显示情况并非如此(代码似乎是内联的)。 Class 除了这个 asm 文件之外,A 没有在其他任何地方使用,所以如果不使用,为什么会生成这些函数?
整个程序优化到位。
"so why are those functions generated if not used ?"
您正在检查为单个翻译单元生成的汇编代码,而不是链接后的最终汇编。
链接器最终会删除所有未使用的函数。