Stack_Overflowとは? わかりやすく解説

Weblio 辞書 > 辞書・百科事典 > 百科事典 > Stack_Overflowの意味・解説 

Stack Overflow

出典: フリー百科事典『ウィキペディア(Wikipedia)』 (2025/04/29 03:58 UTC 版)

Stack Overflow
URL stackoverflow.com(英語)
ja.stackoverflow.com(日本語)
言語 英語スペイン語ロシア語ポルトガル語日本語
タイプ 知識マーケット
運営者 Stack Exchange, Inc.
設立者 ジョエル・スポルスキジェフ・アトウッド英語版
営利性 あり
登録 任意、OpenID
開始 2008年5月
現在の状態 オンライン
ライセンス
  • CC BY-SA 2.5 (~2011年4月)
  • CC BY-SA 3.0 (~2018年5月)
  • CC BY-SA 4.0
[1]

Stack Overflow(スタックオーバーフロー)はStack Exchange Networkの一つ[2][3]で、コンピュータ情報技術、特にプログラミング技術に関するナレッジコミュニティである。サービスはジェフ・アトウッド英語版ジョエル・スポルスキ[4][5]によって2008年に開始された。Stack Overflowという名称は、2008年4月、Atwoodが運営するブログの読者による投票で決定された[6]

本サービスはコンピュータ・プログラミングの広範囲なトピックを扱っていることが特色である[7][8][9]。ウェブサイトは質問と回答を行う機能、またそれらに対する評価付け、wikidiggに似た文書の編集機能を備えており[10]、ユーザの活発な参加を促している。Stack Overflowのユーザは良質な回答を行うことによって、評価ポイントや「バッジ」を得ることができ[11]、本サービスは伝統的なQ&Aサイト・フォーラムにゲーミフィケーションを施したものと言える。全てのユーザによる記述内容はクリエイティブ・コモンズライセンス下にある[1][12]

2019年3月時点で、Stack Overflowの登録ユーザは約1020万人であり、2600万を超える質問が存在する[13]。質問に付加されたタグによると、Stack Overflowの一般的なトピックは、JavaScriptJavaC#PHPAndroidPythonjQueryHTMLC++等である[14][15]

2014年12月に日本語版であるスタック・オーバーフローが開設された[16]。2019年3月時点で、スタック・オーバーフローの登録ユーザは約2万人であり、2万を超える質問が存在する[13]。質問に付加されたタグによると、スタック・オーバーフローの一般的なトピックは、PythonJavaScriptSwiftiOSRuby on RailsPHPAndroidJavaC#等である[17][15]

脚注

  1. ^ a b What is the license for the content I post? - Help Center - Stack Overflow
  2. ^ Jeff Atwood (2008年4月16日). “Introducing Stackoverflow.com”. Coding Horror. 2009年3月11日閲覧。
  3. ^ Jeff Atwood (2008年9月16日). “None of Us is as Dumb as All of Us”. Coding Horror. 2009年3月11日閲覧。
  4. ^ Jeff Atwood (2008年4月6日). “Help Name Our Website”. Coding Horror. 2009年6月15日閲覧。
  5. ^ Alan Zeichick (2009年4月15日). “Secrets of social site success”. SD Times. 2009年4月16日閲覧。
  6. ^ Spolsky's Software Q-and-A Site”. Slashdot (2008年9月16日). 2009年5月23日閲覧。
  7. ^ Joel Spolsky (2009年4月24日). “Google Tech Talks: Learning from StackOverflow.com”. YouTube. 2009年5月23日閲覧。
  8. ^ Jeff Atwood (2008年9月21日). “The Gamification”. Coding Horror Blog. 2011年1月24日閲覧。
  9. ^ FAQ: What is Reputation?”. Stack Overflow. 2010年1月19日閲覧。
  10. ^ Creativecommons.org
  11. ^ a b All Sites - Stack Exchange”. Stack Overflow. 2019年3月25日閲覧。
  12. ^ Tags - Stack Overflow”. Stack Overflow. 2021年5月24日閲覧。
  13. ^ a b 上位9項目前後までを記載。
  14. ^ プログラマー向けのQ&Aサイト「Stack Overflow」、日本語版が一般公開 INTERNET Watch 2014-12-17
  15. ^ タグ - スタック・オーバーフロー”. Stack Overflow. 2021年5月24日閲覧。

スタックオーバーフロー

(Stack_Overflow から転送)

出典: フリー百科事典『ウィキペディア(Wikipedia)』 (2025/12/04 13:29 UTC 版)

スタックオーバーフロー (: stack overflow) は、コンピュータプログラムにおいて、コールスタック領域の限界を超えたデータプッシュにより発生する、バッファオーバーフローの一種である。スタックバッファオーバーフロー (: stack buffer overflow) とは別の概念である。

概要

一般的なプログラムの実行環境では、サブルーチン(関数、プロシージャ、あるいはメソッドとも)の呼び出しに関する情報を格納するためのスタックメモリ領域(コールスタック)が確保される。サブルーチン呼び出しのたびにデータがスタックに積まれ(プッシュ)、サブルーチンが終わって制御フローが呼び出し元に戻るとスタックからデータが降ろされる(ポップ)。また、コールスタックはサブルーチン内でのみ使用されるローカル変数を確保するための領域でもある。オペレーティングシステム (OS) や実行オプションにもよるが、コールスタックに格納できる情報量には上限がある。コールスタックに蓄積されるデータ量が限界を超えるとスタックは「オーバーフロー」し、未定義動作を引き起こす。OSにもよるが、プログラム側で対策をとっていなければ通常はプロセスがクラッシュしてしまう。ただし、スタックオーバーフローの原因となりうるコードパターンは比較的限定されている。

スタックオーバーフローの発生原因のうち、最も多いのはサブルーチンの再帰呼び出しによる無限ループ(無限再帰)である。また、ソースコードの設計上は無限再帰ではなく、終了条件を決めて有限回数で打ち切るような有限再帰になっていたとしても、再帰呼び出しの階層数が深すぎると実行環境におけるコールスタックの上限を超えてしまい、スタックオーバーフローとなってしまう場合もある。ただし、末尾最適化を実装したプログラミング言語では、末尾再帰の形で書かれたサブルーチンをループへ展開することができ、スタックオーバーフローは起こらなくなる。フラットなループ処理に変換されることで、再帰呼び出しによりスタックを消費することが無くなるからである。なお、再帰ではないサブルーチン呼び出しであっても、呼び出し階層数が深すぎる場合には、やはりスタックオーバーフローが起こりうる。

次によくある原因としては、スタック上に巨大な配列を確保しようとすることである。コールスタックに格納できる情報量には上限があるため、巨大なサイズのローカル変数を定義するのではなく、ヒープ領域などを明示的に利用すべきである。配列1つのサイズがそれほど大きくなくても、再帰呼び出しなどでサブルーチンの呼び出し階層が深くなることによってコールスタックを食いつぶし、スタックオーバーフローを引き起こすこともある。

C/C++ での例

再帰による無限ループ

/* 関数の戻り値が int の場合、C言語では前方宣言や前方定義がなくてもコンパイル可能だが、C++では前方宣言あるいは前方定義が必要。 */
int g(void);

int f(void) {
    return g();
}

int g(void) {
    return f();
}

関数 f() は関数 g() を呼び出しているが、g() もやはり f() を呼び出している。交互の呼び出しは終わることがなく、最終的にはスタックオーバーフローが発生する。以下のような終了条件のない自己再帰も無限再帰となる。

int foo(void) {
    return foo();
}

巨大な配列をスタックに配置した場合

C/C++において、関数内で定義されるローカル変数(ブロックスコープを持つ変数)は既定で(staticキーワードで修飾しない限り)自動変数となり、ブロックを抜けることで自動的に変数の寿命が尽きてメモリが解放される自動記憶域期間を持つ[1]。言語仕様では自動変数の実装形態について特に規定されていないが、一般的にはコールスタックを利用して実装される。

システムに実装されているメインメモリの容量にかかわらず、各プログラムのスタック領域のサイズはスレッドごとに既定でせいぜい数MiB程度[2][3][4][5][6][7]であり、大容量の配列を確保するのには向いていない。コンパイルオプションやスレッドの起動時オプションなどでスタックサイズの既定値を変更できる環境もあるが、スタックサイズを増やすにつれてプロセス内で起動可能なスレッドの最大数が減少することになる。

#include <stdio.h>
int main(void) {
    int ary[1000 * 1000 * 1000]; /* 配列が大きすぎる */
    printf("Hello!\n"); /* &"Hello!\n" のプッシュがスタックオーバーフローとなる */
}

この場合は、

#include <stdio.h>
int ary[1000 * 1000 * 1000];
int main(void) {
    printf("Hello!\n");
}

または

#include <stdio.h>
int main(void) {
    static int ary[1000 * 1000 * 1000];
    printf("Hello!\n");
}

のように配列を静的領域に移動するか、あるいは malloc などを使ってヒープ領域に動的確保すればスタックオーバーフローは回避できる。ただし32ビット環境ではアドレス空間の上限が4 GiBであるため、上記のように巨大な配列を静的確保しようとするとプログラムの起動が失敗してしまう可能性がある。通例、システムが利用できる空きメモリの量は必ずしも定かではないので、64ビット以上の環境であっても、実行時の動的メモリ確保と成否チェックを行なうことが望ましい。

#include <stdio.h>
#include <stdlib.h>
int main(void) {
    /* malloc() 関数が失敗した場合は NULL ポインタが返却されるため、実際にメモリ領域を利用する前に NULL チェックをする必要がある */
    int *ary = (int *)malloc(sizeof(int) * (size_t)(1000 * 1000 * 1000));
    printf("Hello!\n");
    /* NULL に対して free() 関数を実行しても何も起こらないことが C/C++ 規格で保証されているため、NULL チェックは不要 */
    free(ary);
}

JavaC#/VB.NETのような仮想マシンベースの実行環境を持つ言語では、OSではなく仮想マシンによって管理されているヒープ領域を使うことによって、動的メモリ確保のオーバーヘッドを低減している。これらの言語では、通常の(言語組み込みの)配列は常にヒープ領域に割り当てられるため、実行時にメモリ不足の例外をスローすることはあっても、スタックオーバーフローを引き起こすことはない。一方、C/C++の動的メモリ確保はそのような言語と比べてオーバーヘッドが大きいため、あらゆる配列をヒープに確保しようとするのは大きな速度損失を伴う。Microsoft Visual C++のランタイムライブラリでは、一定のしきい値を基準として、要求されるメモリサイズに応じてスタックとヒープを使い分ける_malloca()関数も用意されている[8]

脚注

関連項目




英和和英テキスト翻訳

英語⇒日本語日本語⇒英語

辞書ショートカット

すべての辞書の索引

「Stack_Overflow」の関連用語

Stack_Overflowのお隣キーワード
検索ランキング

   

英語⇒日本語
日本語⇒英語
   



Stack_Overflowのページの著作権
Weblio 辞書 情報提供元は 参加元一覧 にて確認できます。

   
ウィキペディアウィキペディア
All text is available under the terms of the GNU Free Documentation License.
この記事は、ウィキペディアのStack Overflow (改訂履歴)、スタックオーバーフロー (改訂履歴)の記事を複製、再配布したものにあたり、GNU Free Documentation Licenseというライセンスの下で提供されています。 Weblio辞書に掲載されているウィキペディアの記事も、全てGNU Free Documentation Licenseの元に提供されております。

©2026 GRAS Group, Inc.RSS