質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.34%

  • C#

    7680questions

    C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

  • Windows 7

    386questions

    Microsoft Windows 7は過去にリリースされたMicrosoft WindowsのOSであり、Windows8の1代前です。2009年の7月にリリースされ販売されました。Windows7の前はWindowsVistaで、その更に3年前にリリースされました。

メモリリークするアプリケーションでガベージコレクトを頻繁に実行すると処理が遅くなるか

受付中

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 631

fuoh

score 10

24時間365日稼働させているとアプリケーションの処理が遅延する状況があり、その要因について
以下のように考えました。

以下、問題点が判明しています。

  1. キューにデータを格納するが取り出さない問題がある。
  2. 画面表示の更新周期でガベージコレクト(GC.Collect()の呼び出し)を実行する問題がある。

アプリケーションの処理が遅くなる理由を考えました。

  • キューへデータを格納して取り出さないため、日々使用可能メモリを圧迫していく。
  • 表示更新時にガベージコレクトを実行するが、蓄積した量により徐々に処理時間が長くなる。
    処理時間が長くなる理由は、回収可能かの判定処理が蓄積したデータ全てに行われるため、
    蓄積量に比例して時間がかかると考えています。
  • 上記によりアプリケーションの処理が、徐々に遅延していく。
    アプリケーションの処理が遅延する理由は、ガベージコレクト中は、メモリへのアクセスが
    ブロックされ、アプリケーションの処理が待たされると考え、ガベージコレクトの時間が
    長くなることで待たされる時間も長くなると考えています。

上記要因は、考えにくいでしょうか、的外れでしょうか?
お教えいただければ幸いです。


OS:Windows7 Professional
.NET Framework 2.0

開発環境:VisualStudio 2005
言語:C#

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • hmmm

    2018/06/28 19:54 編集

    これは具体的に遅くなる箇所の特定はできているんですか?GC.Collectに時間がかかるとか。そうではなくなんとなく遅いとかですか。

    キャンセル

回答 2

+3

こんにちは。

 はじめに

古い.NET Frameworkを用いる場合(今回であれば2.0)、ガーベージコレクションの処理に問題を抱えており、メモリリークのリスクが、新しいそれと比べて高くなります。

こちらのサイトがわかりやすく説明されておりますのでご確認ください。
.NETのメモリ管理と断片化問題

キューイングしているオブジェクトの詳細がわかりませんが、メモリリークせずとも断片化したメモリ領域がGCおよび、その他の処理に影響を与える可能性は考えられます。

 本題

これは質問者様の意見や考えを否定するものではないことをご理解ください。

先に記載した通り、質問者様の考察は的外れではないと思います。ですが、憶測の域を出ません。
すでに明示的にGCの実行を指示している場合は、その個所で処理コストを計測してください。
稼働時間に応じてそこのコストが増しているのではあれば、質問者様の考察が外れていないことがわかります。

また、個人的なスタンスで恐縮ではございますが、GCは自動的に行われることが望ましく、GCを強制的に動かさないといけない状況というのは、何か別の要因があると考えます。
今回の質問で言えば、キューにデータがたまり続けるということがそれにあたります。

質問の回答ではないかもしれませんが、問題をもう少し細かくしたほうが解決が早いように思います。

参考になれば幸いです。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/06/28 14:38

    ご回答ありがとうございます。
    ご提示いただいたサイトを参考にさせていただきます。

    確認方法としては、ガベージコレクト(GC.Collect()呼び出し)の前後でStopwatchのStart()とStop()を
    実施して時間計測するで認識で間違いないでしょうか?

    キャンセル

  • 2018/06/28 14:45

    コメントありがとうございます。
    はい、その認識で問題ありません。ただ、StopWatchクラスのインスタンスは計測の度に作らないようにしてください。(クラスのメンバとして定義)
    調査用のコードが、調査対象の事象に大きく影響することを防ぐためです。

    キャンセル

  • 2018/06/28 14:57

    アドバイスありがとうござます。
    早速、確認したいと思います。

    キャンセル

+1

キューにデータを格納するが取り出さない問題がある。 

取り出さない=取り出せない なんでしょうかね?
直接的な原因は取り出せない方にありそうですが・・・

画面表示の更新周期でガベージコレクト(GC.Collect()の呼び出し)を実行する問題がある。 

一般的にコードでGC.Collect()を呼んでしまうと、本来早めに開放されるべきオブジェクトが開放され辛くなってしまうという話をよく聞きます

明示的に呼び出すのを辞める事でパフォーマンスに影響が出る可能性もあります。
(ガベコレのタイミングはフレームワーク任せのほうがマシの可能性があります)

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/06/28 14:00

    早速のご回答、ありがとうございます。
    説明足らずで申し訳ありません。
    ご指摘の通りなのですが、

    ・キューから取り出さない問題(=バグ)。
    ・ガベージコレクトを明示的に呼び出す問題(=バグ)。

    との認識はあります。
    そのうえで、処理が遅延する要因として黒丸の内容は、
    的外れなのかというところを確認したかったのです。

    キャンセル

同じタグがついた質問を見る

  • C#

    7680questions

    C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

  • Windows 7

    386questions

    Microsoft Windows 7は過去にリリースされたMicrosoft WindowsのOSであり、Windows8の1代前です。2009年の7月にリリースされ販売されました。Windows7の前はWindowsVistaで、その更に3年前にリリースされました。

  • トップ
  • C#に関する質問
  • メモリリークするアプリケーションでガベージコレクトを頻繁に実行すると処理が遅くなるか