スタック上の可変サイズ配列: プログラミング神話の誤りを暴く
実行時にサイズが決定される配列の概念は、長い間考えられてきました。特に C ではプログラミングはタブーです。一般通念では、自動配列と静的配列のサイズを定義できるのは定数だけであると考えられています。しかし、最近のコード スニペットはこの概念に疑問を投げかけています。
次のコードを考えてみましょう:
int main(int argc, char **argv) { size_t size; cin >> size; int array[size]; ... }
new や malloc などの動的メモリ割り当て演算子がないにもかかわらず、このコードはコンパイルされ、実行されます。エラー。これはどのように可能ですか?
鍵は、スタック上の可変サイズ配列のサポートを導入した C99 標準にあります。この場合、コンパイラは、int array[100] として宣言された一定サイズの配列の場合と同様に、配列をスタック上に動的に割り当てます。
これはヒープ割り当てとは根本的に異なることに注意することが重要です。 malloc または new を使用します。特に GCC はスタック上に配列を割り当て、それに応じてスタック ポインタを変更します。これにより、ヒープ割り当ての必要がなくなり、_alloca 関数の動作に似ています。
この構造は古いコンパイラではサポートされていませんが、最新の C 実装では普及しつつあります。これは、実行時に既知のサイズの配列を割り当てる便利で効率的な方法を提供します。
以上がC で可変サイズの配列をスタックに割り当てることはできますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。