すみません教えてください。
VCを始めたばかりで、メモリ等の事が良くわかりません。
(2)で、Invalid Address specified to RtlValidateHeap( 340000, 344978 )やHEAP: Free Heap block 344970 modified at 344998 after it was freed
のメモリエラーが出力されます。
調べてみると(1)で解放されていないのですが、delete pBufが処理されていないと思います。
記述等に問題があるのでしょうか? 調べてみると問題ないように思えるのですが・・・ ご存知の方教えてください。
<ソース>
HANDLE hEventLog = NULL;
EVENTLOGRECORD *pBuf = NULL;
/* イベントログのオープン処理 */
:
:
:
/* イベントログの最大数 */
bResult = GetNumberOfEventLogRecords(hEventLog, &EventNum);
//最大サイズを取得
BufSize = 1;
pBuf = new EVENTLOGRECORD;
bResult = ::ReadEventLog(hEventLog,EVENTLOG_FORWARDS_READ | EVENTLOG_SEQUENTIAL_READ,0,pBuf,BufSize,&ReadBytes,&NextSize);
if(!bResult && GetLastError() != ERROR_INSUFFICIENT_BUFFER) {
eMsg = "ファイルリードエラー2" ;
CloseEventLog(hEventLog);
delete pBuf;
return -1;
}
delete pBuf; --->(1)メモリが解放されない。
BufSize = NextSize;
bResult = ::ReadEventLog(hEventLog,EVENTLOG_FORWARDS_READ | EVENTLOG_SEQUENTIAL_READ,0,pBuf,BufSize,&ReadBytes,&NextSize);
if(!bResult && GetLastError() != ERROR_INSUFFICIENT_BUFFER){
eMsg = "ファイルリードエラー3";
CloseEventLog(hEventLog);
delete pBuf;
return -1;
}
}
delete pBuf; --->(2)ここでエラー
No.2ベストアンサー
- 回答日時:
ちょっと順番が前後しますが、
>コンパイルしても定義されていない見たいだし、MSDNで調べてもLPEVENTLOGRECORDが無かったものですから・・
すみません。PEVENTLOGRECORDの間違いですね。
EVENTLOGRECORD*のことです。
という前提で、
>これはヒープメモリがオーバーしたため足りない60サイズを要求しているって意味ですよね?
そうです。
>だとすると、記載してあった
>char * pBuf2 = new char[NextSize];
>pBuf = (LPEVENTLOGRECORD)pBuf2;
>で確保するのでしょうか?
そうなります。
>また、なぜchar型でメモリ領域を作成し、
>EVENTLOGRECORD型でpBufにキャストするのでしょうか?
>pBufはEVENTLOGRECORDですよね?
new EVENTLOGRECORD;
で確保可能な領域は、EVENTLOGRECORDのサイズを単位としてしか確保できませんよね。
charであれば、1バイト単位で必要なサイズ分を確保することが可能なのでこのような方法を取ります。
No.1
- 回答日時:
このエラーは、確保した領域を越えて書き込みが行われているときや、解放済みの領域に書き込みが行われた際に出るエラーです。
なんで、
>調べてみると(1)で解放されていないのですが、delete pBufが処理されていないと思います。
ではなく、
2回目のReadEventLogでpBufが指す領域が既に解放されている領域を渡しているため、ここに書き込まれてエラーになっています。
つまり、領域を確保してないですよってことです。
で、今回のエラーとは直接関係無いんですが、
1度目のReadEventLogで取得したNextSizeは、EVENTLOGRECORDのサイズより大きいことがあるので、
char * pBuf2 = new char[NextSize];
pBuf = (LPEVENTLOGRECORD)pBuf2;
というように確保する必要があり、
delete[] pBuf2;
と解放する必要があります。おそらくひっかかる個所だと思いますんで。
この回答への補足
ご回答
ありがとうございます。
間違ってコメントアウトして記入忘れしていたのですが、
:
:
delete pBuf;
---------------------ここから2回目のREADEVENTLOG
BufSize = NextSize;
pBuf = new EVENTLOGRECORD; <-- 記述を忘れていました。
bResult = ::ReadEventLog
(hEventLog,EVENTLOG_FORWARDS_READ | EVENTLOG_SEQUENTIAL_READ,0,pBuf,BufSize,&ReadBytes,&NextSize);
で、コンパイルしてみたところ、Heap block at 00344970 modified at 003449D8 past requested size of 60とでます。
これはヒープメモリがオーバーしたため足りない60サイズを要求しているって意味ですよね?
だとすると、記載してあった
char * pBuf2 = new char[NextSize];
pBuf = (LPEVENTLOGRECORD)pBuf2;
で確保するのでしょうか?
また、なぜchar型でメモリ領域を作成し、EVENTLOGRECORD型でpBufにキャストするのでしょうか?
pBufはEVENTLOGRECORDですよね?
因みに(LPEVENTLOGRECORD)って(EVENTLOGRECORD)が正しいのですよね?(間違っていたらすみません。)
コンパイルしても定義されていない見たいだし、MSDNで調べてもLPEVENTLOGRECORDが無かったものですから・・
たびたび聞いて申し訳ありません。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
10代と話して驚いたこと
先日10代の知り合いと話した際、フロッピーディスクの実物を見たことがない、と言われて驚きました。今後もこういうことが増えてくるのかと思うと不思議な気持ちです。
-
一回も披露したことのない豆知識
あなたの「一回も披露したことのない豆知識」を教えてください。 「そうなんだね」と「確かに披露する場所ないね」で評価します。
-
初めて自分の家と他人の家が違う、と意識した時
子供の頃、友達の家に行くと「なんか自分の家と匂いが違うな?」って思いませんでしたか?
-
牛、豚、鶏、どれか一つ食べられなくなるとしたら?
牛肉、豚肉、鶏肉のうち、どれか一種類をこの先一生食べられなくなるとしたらどれを我慢しますか?
-
ギリギリ行けるお一人様のライン
おひとり様需要が増えているというニュースも耳にしますが、 あなたが「ギリギリ一人でも行ける!」という場所や行為を教えてください
-
deleteで開放するとエラーになる原因がわからない
C言語・C++・C#
-
関数から配列を返すには?
C言語・C++・C#
-
unsigned long long 型のフォーマット指定子
C言語・C++・C#
-
-
4
CString型 全角半角を意識せずに「1文字」ずつ取り出す
C言語・C++・C#
-
5
メモリリークの件
C言語・C++・C#
-
6
画面を強制的に再描画させる方法
C言語・C++・C#
-
7
DWORDの実際の型は何でしょうか
C言語・C++・C#
-
8
CStringのFindで文字列検索を行いたいのですが
C言語・C++・C#
-
9
MFC ダイアログ上のID取得について
C言語・C++・C#
-
10
ダイアログ内コントロールの位置取得について
C言語・C++・C#
-
11
Debug Assertion Failed?
C言語・C++・C#
-
12
MFCのワーカースレッドとUIスレッドの使い分け
C言語・C++・C#
-
13
適切な変換関数が存在しない???
C言語・C++・C#
-
14
ボタンの表示の色、フォントを変更したい
C言語・C++・C#
-
15
VC++にてボタン等のサイズ取得
C言語・C++・C#
-
16
エディットボックスのフォントを変えたい
C言語・C++・C#
-
17
C++のfor文について
C言語・C++・C#
-
18
【MFC】Version情報の取得
C言語・C++・C#
-
19
デバッグ中のエラーのことで教えてください。
C言語・C++・C#
-
20
読み込み中にアクセス違反が発生しました、と出ます。これを回避することは
C言語・C++・C#
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・10秒目をつむったら…
- ・人生のプチ美学を教えてください!!
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
c言語のポインタへの文字列入力...
-
C++で、メンバもヒープに確保さ...
-
行列内の行の交換,列の交換を...
-
GetCommandLineを使用しました。
-
Win32APIでのメモリ管理について
-
DLLのマルチスレッドの動作につ...
-
CでOpenMP、パラレル内での共有...
-
ビットをローテートするプログ...
-
C言語 配列の長さの上限
-
配列の要素数に変数を入れたい...
-
関数から配列を返すには?
-
配列を使わずに、変数名を動的...
-
プログラムによく出てくるst...
-
C言語でのconstを返す関数
-
define で 配列
-
System.IO.Directory.GetFiles...
-
構造体のextern方法
-
C言語 数値の連続入力について
-
CStringからchar*への型変換に...
-
整数型の配列をランダムに並べ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
c言語のポインタへの文字列入力...
-
newしないオブジェクトについて
-
allocってなんですか?
-
malloc呼び出し時のセグメンテ...
-
ヒープメモリの解放について
-
配列の添え字の最大数とは?
-
C++で、メンバもヒープに確保さ...
-
ビットをローテートするプログ...
-
プログラムが途中で強制終了し...
-
構造体でchar name[]と*nameの...
-
stringの最大サイズ
-
C言語 mallocとfreeについて
-
mallocで確保するメモリの領域...
-
void*型のデータサイズ
-
DLLのマルチスレッドの動作につ...
-
大容量の静的な確保の限界値
-
スタック破壊の上手な見つけ方...
-
C++のnewで確保したメモリーの...
-
行列内の行の交換,列の交換を...
-
文字列ポインタとgets関数の関...
おすすめ情報