2

プロファイラーを実装しています。関数に出入りするタイミングを追跡するために、コンストラクタ/デストラクタのイディオムを使用したいと思います。

私のコードの大まかな概要は次のとおりです。

class Profile
{
   Profile(void);   //Start timing
  ~Profile(void);   //Stop timer and log
};
//...
Game::Game(void) : m_Quit(false)
{
  Profile p();
  InitalizeModules();
  //...
}

ただし、実行すると、コンストラクタとデストラクタが呼び出されません。分解しても、Profile :: Profile()への参照はありません。標準では、重要なコンストラクターを持つインスタンスはコンパイラーによって最適化できないと指定されていることを理解しました。

コンパイラまたはリンカのコマンドラインに最適化フラグはありません。

属性((used))も指定してみましたが、役に立ちませんでした。

分解は次のとおりです。

(gdb) disassemble Ztk::Game::Game
Dump of assembler code for function Ztk::Game::Game():
   0x00000000004cd798 <+0>:     push   %rbp
   0x00000000004cd799 <+1>:     mov    %rsp,%rbp
   0x00000000004cd79c <+4>:     push   %r12
   0x00000000004cd79e <+6>:     push   %rbx
   0x00000000004cd79f <+7>:     sub    $0x30,%rsp
   0x00000000004cd7a3 <+11>:    mov    %rdi,-0x38(%rbp)
   0x00000000004cd7a7 <+15>:    mov    -0x38(%rbp),%rax
   0x00000000004cd7ab <+19>:    mov    %rax,%rdi
   0x00000000004cd7ae <+22>:    callq  0x4cdc6a <Ztk::Highlander<Ztk::Game, int>::Highlander()>
   /**   CALL SHOULD BE HERE   **/
   0x00000000004cd7b3 <+27>:    mov    -0x38(%rbp),%rax
   0x00000000004cd7b7 <+31>:    movb   $0x0,(%rax)
   0x00000000004cd7ba <+34>:    callq  0x4e59f0 <Ztk::InitializeModules()>

実際、実行可能ファイルに生成およびリンクされたコードがあります

(gdb) disassemble Ztk::Profile::Profile(void)
Dump of assembler code for function Ztk::Profile::Profile():
   0x0000000000536668 <+0>:     push   %rbp
   0x0000000000536669 <+1>:     mov    %rsp,%rbp
   0x000000000053666c <+4>:     sub    $0x20,%rsp
   0x0000000000536670 <+8>:     mov    %rdi,-0x18(%rbp)
   0x0000000000536674 <+12>:    mov    0x8(%rbp),%rax
   0x0000000000536678 <+16>:    mov    %rax,-0x8(%rbp)
   0x000000000053667c <+20>:    mov    -0x8(%rbp),%rax
   0x0000000000536680 <+24>:    mov    %rax,%rsi
   0x0000000000536683 <+27>:    mov    $0x802440,%edi
   0x0000000000536688 <+32>:    callq  0x5363ca <Ztk::Profiler::FindNode(void*)>
4

1 に答える 1

8
Profile p();

ここで行ったことは、Profile型のオブジェクトを返すpと呼ばれる関数として宣言されています。あなたが欲しいのはこれです:

Profile p;
于 2011-04-16T14:54:02.857 に答える