mem.c 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. #include "__virtualmath.h"
  2. void *memFreeCore(void *p){
  3. if (p != NULL)
  4. free(p);
  5. return NULL;
  6. }
  7. void *memCalloc(size_t num, size_t size){
  8. if (num == 0 || size == 0)
  9. return NULL;
  10. void *tmp = calloc(num, size);
  11. return tmp;
  12. }
  13. void *memRealloc(void *old, size_t size){
  14. if (size == 0)
  15. return NULL;
  16. void *tmp;
  17. if (old == NULL)
  18. tmp = memCalloc(1,size);
  19. else
  20. tmp = realloc(old, size);
  21. return tmp;
  22. }
  23. size_t memStrlen(char *p){ // 可以读取NULL的strlen
  24. if (p == NULL)
  25. return 0;
  26. else
  27. return strlen(p);
  28. }
  29. char *memString(size_t size) { // 比memCalloc多了一个设置\0的步骤
  30. if (size == 0){
  31. return NULL;
  32. }
  33. char *tmp = (char *)memCalloc(size + 1, sizeof(char));
  34. tmp[size] = '\0';
  35. return tmp;
  36. }
  37. char *memStrcpy(char *str){
  38. return memStrCharcpy(str, 0, false ,false);
  39. }
  40. char *memStrCharcpy(char *str, size_t nsize, bool free_old, bool write, ...) { // 复制str到新的空间,nszie是要扩展的大小。该函数支持让str=NULL,则变为单纯的memString
  41. char *tmp = memString(memStrlen(str) + nsize + 1);
  42. if (str != NULL){
  43. strcpy(tmp, str);
  44. }
  45. if (write){
  46. va_list argp;
  47. va_start(argp, write);
  48. for (int i = 0; i < nsize; i++){
  49. tmp[memStrlen(str) + i] = (char)va_arg(argp, int);
  50. }
  51. va_end(argp);
  52. }
  53. if (free_old){
  54. memFree(str);
  55. }
  56. return tmp;
  57. }
  58. char *memStrcat(char *first, char *second, bool free_old) {
  59. if (first == NULL && second == NULL)
  60. return NULL;
  61. else if (first == NULL){
  62. first = second;
  63. second = NULL;
  64. free_old = false;
  65. }
  66. char *new = memStrCharcpy(first, memStrlen(second), false, false);
  67. if (second != NULL){
  68. strcat(new, second);
  69. }
  70. if (free_old)
  71. memFree(first);
  72. return new;
  73. }
  74. char *memStrcpySelf(char *str, NUMBER_TYPE times){
  75. bool need_free = false;
  76. if (times < 0){
  77. str = memStrrev(str);
  78. times = -times;
  79. need_free = true;
  80. }
  81. char *new_str = memStrcpy(str), *tmp;
  82. for (NUMBER_TYPE i=0; i < times - 1; i++){
  83. tmp = memStrcat(new_str, str, false);
  84. memFree(new_str);
  85. new_str = tmp;
  86. }
  87. if (need_free){
  88. memFree(str);
  89. }
  90. return new_str;
  91. }
  92. char *memStrrev(char *str){
  93. size_t len_str = memStrlen(str);
  94. char *new_str = memString(len_str);
  95. for (int i = 0;i < len_str;i++){
  96. new_str[i] = str[len_str - i - 1];
  97. }
  98. return new_str;
  99. }