source: src/memoryusageobserver.cpp@ b70721

Action_Thermostats Add_AtomRandomPerturbation Add_FitFragmentPartialChargesAction Add_RotateAroundBondAction Add_SelectAtomByNameAction Added_ParseSaveFragmentResults AddingActions_SaveParseParticleParameters Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_ParticleName_to_Atom Adding_StructOpt_integration_tests AtomFragments Automaking_mpqc_open AutomationFragmentation_failures Candidate_v1.5.4 Candidate_v1.6.0 Candidate_v1.6.1 Candidate_v1.7.0 ChangeBugEmailaddress ChangingTestPorts ChemicalSpaceEvaluator CombiningParticlePotentialParsing Combining_Subpackages Debian_Package_split Debian_package_split_molecuildergui_only Disabling_MemDebug Docu_Python_wait EmpiricalPotential_contain_HomologyGraph EmpiricalPotential_contain_HomologyGraph_documentation Enable_parallel_make_install Enhance_userguide Enhanced_StructuralOptimization Enhanced_StructuralOptimization_continued Example_ManyWaysToTranslateAtom Exclude_Hydrogens_annealWithBondGraph FitPartialCharges_GlobalError Fix_BoundInBox_CenterInBox_MoleculeActions Fix_ChargeSampling_PBC Fix_ChronosMutex Fix_FitPartialCharges Fix_FitPotential_needs_atomicnumbers Fix_ForceAnnealing Fix_IndependentFragmentGrids Fix_ParseParticles Fix_ParseParticles_split_forward_backward_Actions Fix_PopActions Fix_QtFragmentList_sorted_selection Fix_Restrictedkeyset_FragmentMolecule Fix_StatusMsg Fix_StepWorldTime_single_argument Fix_Verbose_Codepatterns Fix_fitting_potentials Fixes ForceAnnealing_goodresults ForceAnnealing_oldresults ForceAnnealing_tocheck ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_continued ForceAnnealing_with_BondGraph_continued_betteresults ForceAnnealing_with_BondGraph_contraction-expansion FragmentAction_writes_AtomFragments FragmentMolecule_checks_bonddegrees GeometryObjects Gui_Fixes Gui_displays_atomic_force_velocity ImplicitCharges IndependentFragmentGrids IndependentFragmentGrids_IndividualZeroInstances IndependentFragmentGrids_IntegrationTest IndependentFragmentGrids_Sole_NN_Calculation JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool JobMarket_unresolvable_hostname_fix MoreRobust_FragmentAutomation ODR_violation_mpqc_open PartialCharges_OrthogonalSummation PdbParser_setsAtomName PythonUI_with_named_parameters QtGui_reactivate_TimeChanged_changes Recreated_GuiChecks Rewrite_FitPartialCharges RotateToPrincipalAxisSystem_UndoRedo SaturateAtoms_findBestMatching SaturateAtoms_singleDegree StoppableMakroAction Subpackage_CodePatterns Subpackage_JobMarket Subpackage_LinearAlgebra Subpackage_levmar Subpackage_mpqc_open Subpackage_vmg Switchable_LogView ThirdParty_MPQC_rebuilt_buildsystem TrajectoryDependenant_MaxOrder TremoloParser_IncreasedPrecision TremoloParser_MultipleTimesteps TremoloParser_setsAtomName Ubuntu_1604_changes stable
Last change on this file since b70721 was c111db, checked in by Frederik Heber <heber@…>, 16 years ago

Merge branch 'new-delete-conversion' into CodeRefactoring

Conflicts:

molecuilder/src/Makefile.am
molecuilder/src/helpers.cpp
molecuilder/src/helpers.hpp
molecuilder/src/memoryusageobserver.cpp

  • FIX: performCriticalExit() was declared static but not defined a such.
  • Merge was basically only due to libmolecuilder which was not used in CodeRefactoring branch before.
  • added ActOnAll Unit test to new unittests sub folder and to Makefile.am
  • Property mode set to 100644
File size: 2.8 KB
Line 
1/*
2 * \file memoryusageobserver.cpp
3 *
4 * This class represents a Singleton for observing memory usage.
5 */
6#include "memoryusageobserver.hpp"
7
8MemoryUsageObserver* MemoryUsageObserver::instance = NULL;
9
10/**
11 * Constructor. Do not use this function. Use getInstance() instead.
12 *
13 * \return memory usage observer instance
14 */
15MemoryUsageObserver::MemoryUsageObserver() {
16 instance = NULL;
17 maximumSize = 0;
18 totalSize = 0;
19}
20
21/**
22 * Destructor. Better use purgeInstance().
23 */
24MemoryUsageObserver::~MemoryUsageObserver() {
25 for (map<void*, size_t>::iterator current = memoryUsers.begin(); current != memoryUsers.end(); current++) {
26 memoryUsers.erase(current);
27 }
28
29 maximumSize = 0;
30 totalSize = 0;
31}
32
33/**
34 * Returns the singleton memory usage observer instance.
35 *
36 * \return memory usage observer instance
37 */
38MemoryUsageObserver* MemoryUsageObserver::getInstance() {
39 if (instance == NULL) {
40 instance = new MemoryUsageObserver;
41 }
42
43 return instance;
44}
45
46/**
47 * Purges the current memory usage observer instance.
48 */
49void MemoryUsageObserver::purgeInstance() {
50 if (instance != NULL) {
51 delete instance;
52 }
53
54 instance = NULL;
55}
56
57/**
58 * Adds memory.
59 *
60 * \param pointer to the allocated piece of memory
61 * \param size of the allocated memory
62 */
63void MemoryUsageObserver::addMemory(void* pointer, size_t size) {
64 // Memory might become reseized so we need to check whether the provided pointer is already tracked.
65 map<void*, size_t>::iterator current = memoryUsers.find(pointer);
66 if (current != memoryUsers.end()) {
67 totalSize -= current->second;
68 }
69
70 memoryUsers[pointer] = size;
71 totalSize += size;
72 maximumSize = (totalSize > maximumSize) ? totalSize : maximumSize;
73}
74
75/**
76 * Removes tracked memory. Prints a warning if untracked memory is to be released.
77 *
78 * \param pointer to the allocated piece of memory
79 * \param *msg optional error message
80 */
81void MemoryUsageObserver::removeMemory(void* pointer, const char *msg) {
82 map<void*, size_t>::iterator current = memoryUsers.find(pointer);
83
84 if (current == memoryUsers.end()) {
85 cout << "WARNING: There is non-tracked memory to be freed. Pointer "
86 << pointer << " is not registered by MemoryUsageObserver: ";
87 if (msg != NULL)
88 cout << *msg;
89 cout << endl;
90 return;
91 }
92
93 totalSize -= current->second;
94 memoryUsers.erase(current);
95}
96
97/**
98 * Gets the size of currently allocated memory.
99 */
100size_t MemoryUsageObserver::getUsedMemorySize() {
101 return totalSize;
102}
103
104/**
105 * Gets the maximum size of allocated memory until now.
106 */
107size_t MemoryUsageObserver::getMaximumUsedMemory() {
108 return maximumSize;
109}
110
111/**
112 * Gets a map with pointers to the currently allocated memory ranges as keys and
113 * the allocated size as value.
114 */
115map<void*, size_t> MemoryUsageObserver::getPointersToAllocatedMemory() {
116 return memoryUsers;
117}
Note: See TracBrowser for help on using the repository browser.