プログラムを書こう!

実務や自作アプリ開発で習得した役に立つソフトウェア技術情報を発信するブログ

MFCでメモリリークしている個所を表示する。

この記事は2019年03月17日に投稿しました。

f:id:paveway:20190914064630j:plain

目次

  1. はじめに
  2. MFCでメモリリークしている個所を表示する
  3. おわりに

かんたん Visual C++ [改訂2版] (プログラミングの教科書)

かんたん Visual C++ [改訂2版] (プログラミングの教科書)

1. はじめに

こんにちは、iOSのエディタアプリPWEditorの開発者の二俣です。
今回は業務で使用しているMFCでメモリリークしている個所を表示する方法についてです。

目次へ

2. MFCでメモリリークしている個所を表示する

MFCでメモリリークしている個所を表示する方法ですが、ソースコード(cppファイル)でヘッダをインクルードしている記述の後に以下の定義を追加します。

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

この定義を追加してVisual Studioでデバッグ実行します。
アプリ終了後に、Visual Studioの出力ウィンドウにメモリリークの情報が表示されます。
メモリリークした個所は

<ソースファイルパス名>(行番号) : {<メモリ取得回数>} normal block at 0xXXXXXXXX, n bytes long.
 Data: ???? XX XX XX

のように表示されます。

実行例

(サンプルのため、加工してあります)

Detected memory leaks!
Dumping objects ->
// ソースファイルパス名が表示された場合
c:\XXX\XXX.cpp(60) : {332098} normal block at 0x0158A5F8, 4 bytes long.
 Data: <ヘヘヘヘ> CD CD CD CD 

// ソースファイルパス名が表示されない場合
{331856} normal block at 0x00C08908, 672 bytes long. 
 Data: <       ?        > 00 00 00 00 00 00 F0 3F 00 00 00 00 00 00 00 00 

目次へ

3. おわりに

今回作成したアプリのメモリリークの調査のため、この定義を追加しました。
これによりいくつかのメモリリークしてる個所が特定できました。
しかし全てのメモリリークしてる個所が表示できるわけではないようです。

子ども向けプログラミング・ロボット教室【LITALICOワンダー】

標準講座MFC6.0―Visual C++による効率的なWindowsプログラミング (Programmer’s SELECTION)

標準講座MFC6.0―Visual C++による効率的なWindowsプログラミング (Programmer’s SELECTION)

  • 作者: ハーバートシルト,田中正造,Herbert Schildt,コスモワークス
  • 出版社/メーカー: 翔泳社
  • 発売日: 1999/04/01
  • メディア: 単行本
  • 購入: 11人 クリック: 39回
  • この商品を含むブログ (4件) を見る

紹介している一部の記事のコードはGitlabで公開しています。
興味のある方は覗いてみてください。

目次へ


私が勤務しているニューラルでは、主に組み込み系ソフトの開発を行っております。
弊社製品のハイブリッドOS Bi-OSは高い技術力を評価されており、特に制御系や通信系を得意としています。
私自身はiOSモバイルアプリウィンドウズアプリを得意としております。
ソフトウェア開発に関して相談などございましたら、お気軽にご連絡ください。

また一緒に働きたい技術者の方も随時募集中です。
興味がありましたらご連絡ください。

EMAIL : info-nr@newral.co.jp / m-futamata@newral.co.jp
TEL : 042-523-3663
FAX : 042-540-1688

目次へ