Click here to Skip to main content
Click here to Skip to main content

Memory leak finder

, 22 Feb 2012 MIT
Rate this:
Please Sign up or sign in to vote.
Custom memory handler with memory leak reporting and no-mans-land checking. Leaks are reported with call stack of allocation.

Sample Image - Memory_leak_finder.jpg

Introduction

Have you ever had a memory leak? Wished you knew where you allocated it and how? Is your boss cheap and refuses to buy Boundchecker or another debugging tool?

Here is the solution for you. A memory leak detector compiled directly into your code. It reports memory leaks with call stack of the allocation down to a user defined depth.

As an add-on, it does simple checks of the memory before and after the memory block, to track buffer overwrites.

Usage

Include tracealloc.cpp in your project. Define DETECT_LEAKS in the project settings. Compile. Run your application. Memory leaks are reported into your debug output window when the application terminates. Just click the memory leak and the correct file and line will be shown.

You can find further instructions in the source code.

How is it done?

The code overrides operator new and operator delete. For each allocation made, the code allocates extra space for tracking, call stack and no-mans-land. The current call stack is fetched and remembered, finally the code puts the newly allocated block in a linked list and the requested memory is returned.

When a memory block is deleted, the header is found and checked for buffer overwrites. The memory block is then removed from the linked list and deallocated.

When the program terminates, the global memory tracker object is deleted. The destructor traverses the linked list for memory blocks that isn’t deleted (= leaked memory). It then fetches symbol information for the call stacks and dumps the information in the debug console.

Limitations

The code is Microsoft Visual Studio and Win32 specific. It requires a debug build. The code is C++ specific. It handles new/delete but not malloc/free. The code will run slower with leak detection active (roughly at half normal debug build speed).

Finally

I want to thank Zoltan Csizmadia who wrote ExtendedTrace. I have used parts of his code for stack walking and symbol lookups.

I also want to thank the Code Project community. I have found many solutions or pointers in the right direction here. I hope I have given something back with this contribution.

Thank you!

History

February 22, 2012:

  • Inclusion of contributed bug fixes (author acknowledged in read me file)
  • Upgrade of solution to Visual Studio 2010.

License

This article, along with any associated source code and files, is licensed under The MIT License

Share

About the Author

Erik Rydgren
Software Developer (Senior)
Sweden Sweden
B.Sc in Software engineering
 
Writing software for the finance market.
Languages known: C/C++, SQL, Java, Perl, M68000 assembly and more. Give me the syntax and I'll program in it.
 
In my spare time i like to watch movies, read books and play computergames.

Comments and Discussions

 
QuestionCrash In WriteStackTrace PinmemberSivaji156517-Apr-14 22:55 
QuestionSolution updated to Visual Studio 2010 and inclusion of fixes by PEK PinmemberErik Rydgren22-Feb-12 13:07 
AnswerRe: Solution updated to Visual Studio 2010 and inclusion of fixes by PEK PinmemberRohit Dubey from Hyderabad3-Mar-12 13:39 
QuestionSomething like PinmemberMast Avalons4-Jan-12 5:14 
AnswerRe: Something like PinmemberJohnDepth20-Feb-12 6:32 
GeneralRe: Something like PinmemberErik Rydgren20-Feb-12 10:07 
GeneralRe: Something like PinmemberMember 428961327-Feb-12 3:29 
GeneralRe: Something like PinmemberSuperMegaCoder14-Mar-12 6:23 
GeneralRe: Something like PinmemberMast Avalons5-Jun-12 12:19 
GeneralRe: Something like PinmemberJohnDepth13-Jul-12 8:11 
GeneralBugfix: GetStackTrace writing data in nomans land, and some improvements. PinmemberPEK18-Mar-10 20:24 
GeneralRe: Bugfix: GetStackTrace writing data in nomans land, and some improvements. PinmemberTardi S1-Jun-10 3:16 
I got "MEMORYERROR_STUFF_WRITTEN_IN_NOMANSLAND_LEAD" on large allocations.
Now it is fixed.
The solution itself is a great job however.
 
Thanks for it!!!!!
Generalmemory leak finder for java. Pinmemberdpmpardhu9-Jun-09 22:11 
GeneralRe: memory leak finder for java. PinmemberErik Rydgren9-Jun-09 23:37 
GeneralWorks great with VS 6 C++ Pinmemberfeanorgem31-May-09 3:42 
NewsCode now upgraded to Visual Studio 2008 PinmemberErik Rydgren12-Oct-08 20:33 
GeneralRe: Code now upgraded to Visual Studio 2008 PinmemberMember 307553127-Nov-08 20:02 
GeneralRe: Code now upgraded to Visual Studio 2008 PinmemberEiswuxe216-Apr-09 12:38 
GeneralRe: Code now upgraded to Visual Studio 2008 PinmemberErik Rydgren16-Apr-09 22:59 
GeneralLinker Errors PinmemberSuper Garrison14-Jan-08 14:10 
GeneralRe: Linker Errors Pinmembermatakk@126.com10-Oct-08 18:22 
GeneralRe: Linker Errors PinmemberErik Rydgren12-Oct-08 20:29 
GeneralThanks. Pinmembermark-w12-Sep-07 14:55 
GeneralCompile errors in VC8 PinmemberDavid_Leikis5-Jun-07 9:16 
GeneralRe: Compile errors in VC8 PinmemberDavid_Leikis5-Jun-07 9:26 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

| Advertise | Privacy | Mobile
Web04 | 2.8.141022.2 | Last Updated 22 Feb 2012
Article Copyright 2003 by Erik Rydgren
Everything else Copyright © CodeProject, 1999-2014
Terms of Service
Layout: fixed | fluid