Open Source Tomb Raider Engine
您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

memory_test.cpp 4.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. /*!
  2. * \file test/memory_test.cpp
  3. * Memory testing Toolkit Unit test
  4. *
  5. * \author Mongoose
  6. */
  7. #include <string.h>
  8. #include <stdio.h>
  9. #include <stdlib.h>
  10. #include <memory_test.h>
  11. extern rbtree_t *MEMORY_INFO;
  12. extern meminfo_filename_t *MEMORY_FILENAME;
  13. extern long MEMORY_USED;
  14. extern long MEMORYA_USED;
  15. extern long MEMORYC_USED;
  16. extern long MAX_MEMORY_USED;
  17. extern long MAX_MEMORYA_USED;
  18. extern long MAX_MEMORYC_USED;
  19. void tree_valid_report(rbtree_t *root);
  20. #define PRINT_TEST_BREAK_LINE printf("\n############################################################\n\n");
  21. int memory_test_unit_test(int argc, char *argv[])
  22. {
  23. int *i, *j, *k, *l, *m, *n, *o;
  24. PRINT_TEST_BREAK_LINE
  25. printf("Memory test\n");
  26. PRINT_TEST_BREAK_LINE
  27. i = new int;
  28. printf(">\ti = new int; (%p) %s:%i\n", i, __FILE__, __LINE__);
  29. dump_memory_report();
  30. tree_valid_report(MEMORY_INFO);
  31. delete i;
  32. printf(">\tdelete i; (%p) %s:%i\n", i, __FILE__, __LINE__);
  33. dump_memory_report();
  34. tree_valid_report(MEMORY_INFO);
  35. PRINT_TEST_BREAK_LINE
  36. i = new int[3];
  37. printf(">\ti = new int[3]; (%p) %s:%i\n", i, __FILE__, __LINE__);
  38. dump_memory_report();
  39. tree_valid_report(MEMORY_INFO);
  40. delete [] i;
  41. printf(">\tdelete [] i; (%p) %s:%i\n", i, __FILE__, __LINE__);
  42. dump_memory_report();
  43. tree_valid_report(MEMORY_INFO);
  44. PRINT_TEST_BREAK_LINE
  45. i = new int[3];
  46. printf(">\ti = new int[3]; (%p) %s:%i\n", i, __FILE__, __LINE__);
  47. j = new int;
  48. printf(">\tj = new int; (%p) %s:%i\n", j, __FILE__, __LINE__);
  49. k = new int[3];
  50. printf(">\tk = new int[3]; (%p) %s:%i\n", k, __FILE__, __LINE__);
  51. dump_memory_report();
  52. tree_valid_report(MEMORY_INFO);
  53. delete [] i;
  54. printf(">\tdelete [] i; (%p) %s:%i\n", i, __FILE__, __LINE__);
  55. delete j;
  56. printf(">\tdelete j; (%p) %s:%i\n", j, __FILE__, __LINE__);
  57. delete [] k;
  58. printf(">\tdelete [] k; (%p) %s:%i\n", k, __FILE__, __LINE__);
  59. dump_memory_report();
  60. tree_valid_report(MEMORY_INFO);
  61. PRINT_TEST_BREAK_LINE
  62. i = new int[3];
  63. printf(">\ti = new int[3]; (%p) %s:%i\n", i, __FILE__, __LINE__);
  64. j = new int;
  65. printf(">\tj = new int; (%p) %s:%i\n", j, __FILE__, __LINE__);
  66. k = new int[3];
  67. printf(">\tk = new int[3]; (%p) %s:%i\n", k, __FILE__, __LINE__);
  68. dump_memory_report();
  69. tree_valid_report(MEMORY_INFO);
  70. delete j;
  71. printf(">\tdelete j; (%p) %s:%i\n", j, __FILE__, __LINE__);
  72. dump_memory_report();
  73. tree_valid_report(MEMORY_INFO);
  74. j = new int[3];
  75. printf(">\tj = new int[3]; (%p) %s:%i\n", j, __FILE__, __LINE__);
  76. dump_memory_report();
  77. tree_valid_report(MEMORY_INFO);
  78. l = new int[3];
  79. printf(">\tl = new int[3]; (%p) %s:%i\n", l, __FILE__, __LINE__);
  80. dump_memory_report();
  81. tree_valid_report(MEMORY_INFO);
  82. m = new int[3];
  83. printf(">\tm = new int[3]; (%p) %s:%i\n", m, __FILE__, __LINE__);
  84. dump_memory_report();
  85. tree_valid_report(MEMORY_INFO);
  86. n = new int[3];
  87. printf(">\tn = new int[3]; (%p) %s:%i\n", n, __FILE__, __LINE__);
  88. dump_memory_report();
  89. tree_valid_report(MEMORY_INFO);
  90. o = new int[3];
  91. printf(">\to = new int[3]; (%p) %s:%i\n", o, __FILE__, __LINE__);
  92. dump_memory_report();
  93. tree_valid_report(MEMORY_INFO);
  94. delete [] k;
  95. printf(">\tdelete [] k; (%p) %s:%i\n", k, __FILE__, __LINE__);
  96. dump_memory_report();
  97. tree_valid_report(MEMORY_INFO);
  98. delete [] j;
  99. printf(">\tdelete [] j; (%p) %s:%i\n", j, __FILE__, __LINE__);
  100. dump_memory_report();
  101. tree_valid_report(MEMORY_INFO);
  102. delete [] l;
  103. printf(">\tdelete [] l; (%p) %s:%i\n", l, __FILE__, __LINE__);
  104. dump_memory_report();
  105. tree_valid_report(MEMORY_INFO);
  106. delete [] m;
  107. printf(">\tdelete [] m; (%p) %s:%i\n", m, __FILE__, __LINE__);
  108. dump_memory_report();
  109. tree_valid_report(MEMORY_INFO);
  110. delete [] n;
  111. printf(">\tdelete [] n; (%p) %s:%i\n", n, __FILE__, __LINE__);
  112. dump_memory_report();
  113. tree_valid_report(MEMORY_INFO);
  114. delete [] o;
  115. printf(">\tdelete [] o; (%p) %s:%i\n", o, __FILE__, __LINE__);
  116. dump_memory_report();
  117. tree_valid_report(MEMORY_INFO);
  118. delete [] i;
  119. printf(">\tdelete [] i; (%p) %s:%i\n", i, __FILE__, __LINE__);
  120. dump_memory_report();
  121. tree_valid_report(MEMORY_INFO);
  122. PRINT_TEST_BREAK_LINE
  123. return 0;
  124. }
  125. int main(int argc, char *argv[])
  126. {
  127. printf("[memory_test test]\n");
  128. return memory_test_unit_test(argc, argv);
  129. }