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

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

ただいまの
回答率

89.21%

TextBoxBase.Clear でOut Of Memory 発生?

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 2,552

nobysanz

score 41

お世話になります。
C#にて、フォーム内のテキストボックスに、定期的にログを追加して表示しております。1日の日替わりでファイルへ出力し、テキストボックスの内容をクリアしてますが、その時に、Out Of Memory が発生しました。 Clear 処理(=メモリ解放する?)と思いますので、要因についてご教授をお願いいたします。

Exceptionの内容から推測すると、Memory不足に陥ってると思いますが、OS全体のメモリ不足なのか、アプリケーション内でのメモリ不足なのか?判断しかねております。

以下、スタックトレースと処理のソースです。

2016/01/03_00:00:01,303 - 理由種類 'System.OutOfMemoryException' の例外がスローされました。
2016/01/03_00:00:01,303 - スタックトレース
   場所 System.String.InternalCopy(String str)
   場所 System.Text.StringBuilder.ToString()
   場所 System.Windows.Forms.Control.get_WindowText()
   場所 System.Windows.Forms.TextBoxBase.get_WindowText()
   場所 System.Windows.Forms.Control.set_WindowText(String value)
   場所 System.Windows.Forms.TextBoxBase.set_WindowText(String value)
   場所 System.Windows.Forms.Control.set_Text(String value)
   場所 System.Windows.Forms.TextBoxBase.set_Text(String value)
   場所 System.Windows.Forms.TextBox.set_Text(String value)
   場所 System.Windows.Forms.TextBoxBase.Clear()
private void timer1_Tick(object sender, EventArgs e)
{
    try
    {
    // ログをキューから取出し表示する_
    DateTime dtNow = DateTime.Now;
    lock (_logBufferQue)
    {
        while (_logBufferQue.Count > 0)
        {
            txtMessage.AppendText(
                String.Format("{0} - {1}", dtNow.ToString("yyyy/MM/dd_HH:mm:ss"), _logBufferQue.Dequeue()));
            txtMessage.AppendText(Environment.NewLine);
        }
    }
    // 日替り判定_
    if (_dateTimeText.Substring(0, 10) != System.DateTime.Now.ToString("yyyy/MM/dd"))
    {
        //日替わりしたら、現在表示している情報をファイルに保存する_
        SaveSystemLog(true);     // 「前日」でファイルに保存
        txtMessage.Clear();
    }
    // 現在日付を保持_
    _dateTimeText = System.DateTime.Now.ToString("yyyy/MM/dd HH:mm");
    }
    catch (Exception exp)
    {
        Console.WriteLine("FormChild00000.timer1_Tick(): ログの表示、または日替り判定に失敗しました。",
                                                    exp.Message,
                                                    exp.StackTrace);
    }
}
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

checkベストアンサー

0

こんにちは。

スタックトレースを見ると、set_WindowText()からget_WindowText()が呼び出され、その中でInternalCopy()が呼ばれています。これを見る限り、コントロールのテキストを(たぶん)""へ変更する際に、現在記録されているテキストを一度どこかへコピーしている可能性があると思います。その時、メモリ不足が発生したのではないでしょうか?

Windowsは仮想記憶があるので物理メモリが不足するとHDDへスワップアウトし、メモリ不足は事実上起きないものと思っていました。
しかし、ここをみると32bit Windowsの場合、2GBytesのメモリ空間を使い切ると発生するようです。以前、catsforepawさんが確認して頂けたのですが、64bit Windowsでも発生するようです。

従って、メモリ空間を食い尽くしてしまったのではないでしょうか?
これが正しい場合、メモリ空間はプロセス毎に割り当てられますので、下記についてはアプリケーション内のメモリ不足として捉えて良いように思います。

Exceptionの内容から推測すると、Memory不足に陥ってると思いますが、OS全体のメモリ不足なのか、アプリケーション内でのメモリ不足なのか?判断しかねております。

つまり、他のプロセスは稼働可能と思います。ただし物理メモリが不足していると言う事実は変わりませんので、スワップが頻発し性能が劣化している可能性があります。

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2016/01/05 19:59

    コメントありがとうございます。
    自プロセスの利用メモリが肥大化してると考えたほうが良いですね。
    リークしていないか調査してみます。

    キャンセル

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

  • ただいまの回答率 89.21%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる