katapedia
  • README
  • doc
    • Ansible
    • Assert
    • Astah
    • Autohotkey
    • CI
    • C_Cpp
    • CentOS6x系でhttp認証に失敗する
    • Chef
    • Clipboard
    • コーディング
    • Configure
    • Console2_NYAOS
    • Debian系RedHat系の違い
    • DesignDoc目次サンプル
    • Docker
    • Doxygenコメント規約
    • Eclipse
    • Excel
    • FAQ
    • Footer
    • Git
    • GitBucket
    • GitBucketとJenkins連携
    • GitBucketとRocketChat連携
    • GitHub
    • GitLab
    • Gitで大量のファイルの中から必要ファイルのみをaddする方法
    • GitのGUI比較
    • Gitのリポジトリがでかくなったときの削減の昔のやり方
    • Gitワークフロー
    • Go
    • Googletest
    • Gradle
    • Grafana
    • Groovy
    • Haroopad
    • Haskell
    • Htmlpdfに直リンクする(ダウンロードしない)方法
    • IT業界
    • Java
    • Javascript
    • Javascriptrライブラリ・フレームワーク一覧
    • Jenkins
    • JetBrains_IDE
    • Linux
    • Linux Command
    • Linux Distribution
    • Makefile
    • Maven
    • MicrosoftProject
    • NoSQL
    • Omniauthによるアカウント統合
    • Outlook
    • PHP
    • Prometheus_Loki
    • Python
    • RDB
    • Redmine
    • RedmineDドライブへの保存
    • Redmineアップデート
    • Redmineプラグイン
    • Redmineメール通知
    • Redmine文字化け
    • Ruby
    • Rust
    • R言語
    • SVN
    • Sidebar
    • Solaris
    • Staticまとめ
    • Terraform
    • Thinkpad
    • Tmux
    • ToDoリスト
    • UML
    • Vagrant
    • Vim/Neovim
    • VirtualBox
    • Visio
    • Webアプリケーション
    • Webサーバ
    • Webブラウザ
    • Webブラウジング
    • Webページ備忘録
    • Windows
    • Word
    • Zabbix
    • Zsh
    • C#
    • dotfiles
    • html_css
    • Lua
    • sonarqube
    • terminal
    • tweetまとめ
    • xrdp
    • お預り証サンプル
    • その他Webサービス
    • その他ツール
    • よく使う英語
    • アジェンダサンプル
    • アジャイル宣言
    • アンチパターン
    • インシデント
    • エディタ・IDE
    • エンジニアリングスキル
    • オンプレミスサーバ管理
    • オープンソースライセンス
    • キックオフミーティング
    • コミットメッセージでよく使う英語
    • サーバデータ移行
    • サーバ環境構築
    • シェルスクリプト
    • セキュリティ
    • ソフトウェア開発
    • チャットツール
    • チーム構築
    • ツール調査履歴
    • テスト
    • デザイン
    • デザインパターン
    • ドキュメント
    • ネットワーク
    • ノート
    • バージョン番号
    • ビジネスモデル
    • プラクティス一覧
    • プラグイン調査
    • プログラマがやってはいけない97のこと
    • プログラミングテクニック
    • プログラム
    • プログラムエラー集
    • プロジェクトマネージメント
    • プロダクトマネージメント
    • ヘルプ文
    • ライフハック
    • リソース設計
    • リバースエンジニアリングツール
    • リリースノート
    • リリースノートサンプル1
    • リンク
    • レビュー
    • 人月の神話
    • 人間のあれこれ
    • 仕事のあれこれ
    • 会議
    • 作業報告項目サンプル
    • 例外処理
    • 勉強
    • 名言・教訓
    • 品質管理
    • 教育
    • 数学
    • 文書レビュー観点
    • 朝会
    • 未来技術
    • 林檎の木のものを持ってきた
    • 正規表現
    • 物理
    • 知識データベース
    • 紛らわしい・似たような用語
    • 経営
    • 経済
    • 自作template_class_でundefined_reference_to
    • 要求分析・要件定義
    • 見積もり
    • 設計
    • 評価
    • 認証
    • 議事録サンプル
    • 運用・保守
    • 開発インフラ
    • 開発環境
    • 開発計画
    • 関数名でよく使われる英単語
    • 関数命名規約
    • 関数型言語
    • 雑多メモ
    • 面接
Powered by GitBook
On this page
  • メモリ
  • スタックとヒープ
  1. doc

プログラム

メモリ

スタックとヒープ

ヒープのほうがスタックよりも遅い。遅い理由は領域の確保と解放が要因。

rust-jpのslackから転載

スタックは関数の呼び出しで確保(領域を拡張)して、関数の戻りで開放する(領域を巻き戻す)ので管理が非常に簡単です。たとえば巻き戻すときは(CPUのアーキテクチャに依存しますが)一般的にマシン語の命令一つで済みます。また(OSに依存しますが)スタック領域はスレッドごとに独立したものが用意されるのが一般的なので、確保・開放に関する排他制御も不要です。 ヒープは任意の時点で確保・開放できますし、複数のスレッドで共有できますので、管理が複雑になります。そのためヒープアロケータという種類のライブラリを通して管理します。 たとえば、プログラムの実行が始まってから時間が経つとヒープ用のメモリ領域の中には使用中のスペースと開放済みのスペースが混在した状態になってきます。プログラムがヒープに新たにスペースを確保したいとき、ヒープアロケータはこの開放済みのスペースを探索して、ちょうどいい大きさのスペースを見つけなければなりません。この管理が下手だとメモリの断片化(フラグメンテーション)が酷くなり、性能が劣化したり無駄にメモリを使ったりします。また、確保や開放の要求は複数のスレッドから同時に来るかもしれませんので、ヒープアロケータ内で排他制御も必要になります。 ヒープアロケータをナイーブに実装するとパフォーマンスがかなり悪くなります。そのため様々な設計や高速化のテクニックがあり、用途に応じたいろいろなヒープアロケータの実装があります。たとえばマルチスレッドなサーバープロセスに適したものがあったり、組み込みシステムやWebAssemblyに適したものがあったりという感じです。 どのような環境でどのヒープアロケータを使うのかによって性能が変わってきますが、いずれの場合でも、スタックよりもヒープの方が管理が複雑になり、確保と解放により長い時間がかかると考えてかまいません。 と、長々と書きましたが、ヒープであってもその管理にかかる時間はファイルシステムやネットワークのアクセスにかかる時間とは比べ物にならないくらい短いものです。ですからほとんどのプログラムでは、データをスタックとヒープのどちらに置いているかは気にする必要はなさそうです。もし違いが問題になるようなプログラムを書くときはこのことを思い出してください

PreviousプログラミングテクニックNextプログラムエラー集

Last updated 5 years ago