ホームページ >バックエンド開発 >C++ >C では再帰はどこまで深くできるのでしょうか?

C では再帰はどこまで深くできるのでしょうか?

Barbara Streisand
Barbara Streisandオリジナル
2024-10-31 10:46:02381ブラウズ

How Deep Can Recursion Go in C  ?

C は再帰の深さを制限しますか?

解釈されて最大の再帰の深さがある Python とは異なり、C はコンパイルされた言語です。したがって、再帰の深さは主にスタックの最大サイズによって制限されます。スタックの最大サイズは通常、利用可能な RAM よりもはるかに小さくなります。

スタックの制限は、多くの場合、オペレーティング システム レベルで調整できます。たとえば、macOS では、デフォルトのスタック サイズは 8 MB で、この制限は ulimit シェル コマンドを使用して調整できます。

ただし、スタック サイズだけでは最大再帰深さを完全に決定することはできません。再帰関数のアクティベーション レコード サイズ (スタック フレームとも呼ばれます) も考慮する必要があります。このサイズは、各関数の最初と最後にスタック ポインターの調整を表示するデバッガの逆アセンブラを使用して決定できます。

スタック サイズとアクティベーション レコード サイズを理解することで、最大深さを見積もることができます。スタック オーバーフロー例外が発生する前に、特定の C プログラムで再帰を達成できます。

以上がC では再帰はどこまで深くできるのでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。