source: molecuilder/src/Helpers/MemDebug.hpp@ 2b0041

Last change on this file since 2b0041 was 5d1a94, checked in by Tillmann Crueger <crueger@…>, 15 years ago

Improved comments for the memory tracker

  • Property mode set to 100644
File size: 1.6 KB
Line 
1/*
2 * MemDebug.hpp
3 *
4 * Created on: Apr 28, 2010
5 * Author: crueger
6 */
7
8#ifndef MEMDEBUG_HPP_
9#define MEMDEBUG_HPP_
10
11/**
12 * @file
13 * This module allows easy automatic memory tracking. Link this module to replace the
14 * operators new, new[], delete and delete[] with custom versions that add tracking
15 * information to allocated blocks.
16 *
17 * All tracking is done in O(1) for new and delete operators. Summaries for the
18 * used memory take O(N), where N is the number of currently allocated memory chunks.
19 *
20 * To use full tracking including file name and line number include this file in
21 * your sourcefiles.
22 */
23
24namespace Memory {
25
26 /**
27 * Displays a short summary of the memory state.
28 */
29 void getState();
30
31 void _ignore(void*);
32
33 /**
34 * Use this to disable memory for a certain pointer on the heap.
35 * This is useful for pointers which should live over the run of the
36 * program, and which are deleted automatically at the end. Usually these
37 * pointers should be wrapped inside some kind of smart pointer to
38 * ensure destruction at the end.
39 */
40 template <typename T>
41 T *ignore(T* ptr){
42 _ignore((void*)ptr);
43 return ptr;
44 }
45}
46
47void *operator new (size_t nbytes,const char* file, int line) throw(std::bad_alloc);
48void *operator new[] (size_t nbytes,const char* file, int line) throw(std::bad_alloc);
49void operator delete (void *ptr,const char*, int) throw();
50void operator delete[] (void *ptr,const char*, int) throw();
51
52/**
53 * This macro replaces all occurences of the keyword new with a replaced
54 * version that allows tracking.
55 */
56#define new new(__FILE__,__LINE__)
57
58#endif /* MEMDEBUG_HPP_ */
Note: See TracBrowser for help on using the repository browser.