「末尾呼び出し最適化」の版間の差分
ナビゲーションに移動
検索に移動
imported>Administrator (ページの作成:「'''末尾呼び出し最適化'''(Tail Call Optimization、TCO)とは、ある関数の最後の処理が、別の関数呼び出しであれば、コストの...」) |
imported>Administrator 細 |
||
6行目: | 6行目: | ||
末尾呼び出し最適化のなかでも、最強に威力を発揮するのは[[再帰]]であり、[[末尾再帰最適化]]という言葉まである。やってることは基本的に末尾呼び出し最適化と同じである。 | 末尾呼び出し最適化のなかでも、最強に威力を発揮するのは[[再帰]]であり、[[末尾再帰最適化]]という言葉まである。やってることは基本的に末尾呼び出し最適化と同じである。 | ||
+ | |||
+ | == .NET Framework == | ||
+ | [[.NET Framework]]の[[CIL]]では末尾呼び出しを明示するtail命令があり、これを使うと現在の関数の[[フレームスタック]]を削除して(続く関数の引数は残す)、続く関数の呼び出しを行う。 | ||
+ | |||
+ | 関数呼び出し自体は消えないのでそれに伴うオーバーヘッドは残るが、そこへたどり着くまでのスタックは消去されるため、スタックオーバーフローは容易に回避できるようになる。 | ||
== 関連項目 == | == 関連項目 == |
2012年5月28日 (月) 01:31時点における版
末尾呼び出し最適化(Tail Call Optimization、TCO)とは、ある関数の最後の処理が、別の関数呼び出しであれば、コストの大きい関数呼び出しを消し去り、インライン展開してしまうことが比較的容易にできるよ、というコンパイラの最適化手法のひとつである。
たとえば、x86のニーモニックや.NETのCILであればCALLとなっている部分をJMPなどに置き換えれる。
プログラマーが最適化と称してgoto文を使いまくり、仕舞にはmain関数一本のプログラムを作った日には偉い人たちからボロクソ叩かれるが、その半分をコンパイラに任せると偉い人たちも怒らないので、コンパイラが容易に最適化ポイントを認識できるようにプログラムのソースコードを書くときに留意しておきましょうという話でもある。
末尾呼び出し最適化のなかでも、最強に威力を発揮するのは再帰であり、末尾再帰最適化という言葉まである。やってることは基本的に末尾呼び出し最適化と同じである。
.NET Framework
.NET FrameworkのCILでは末尾呼び出しを明示するtail命令があり、これを使うと現在の関数のフレームスタックを削除して(続く関数の引数は残す)、続く関数の呼び出しを行う。
関数呼び出し自体は消えないのでそれに伴うオーバーヘッドは残るが、そこへたどり着くまでのスタックは消去されるため、スタックオーバーフローは容易に回避できるようになる。
関連項目
参考文献