DataManager.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. #ifndef DATA_MANAGER_H
  2. #define DATA_MANAGER_H
  3. #include <string>
  4. #include <unordered_map>
  5. #include <memory>
  6. #include "DataPipe.h" // 假设 DataPipe 类定义在这个头文件中
  7. #include "DataPackage.h" // 假设 DataPackage 类定义在这个头文件中
  8. #include "../DataBuffer/DataBuffer.h"
  9. class DataManager
  10. {
  11. public:
  12. static DataManager &getInstance()
  13. {
  14. static DataManager instance;
  15. return instance;
  16. }
  17. // add data pipe
  18. template <typename T>
  19. void addDataPipe(std::string name);
  20. // erase data pipe
  21. void eraseDataPipe(std::string name);
  22. // get data pipe by name
  23. template <typename T>
  24. std::shared_ptr<DataPipe<T>> getDataPipe(std::string name);
  25. // push data to the data pipe
  26. template <typename T>
  27. void pushData(std::string name, T *data);
  28. // pop data from the data pipe
  29. template <typename T>
  30. bool popData(std::string name, T *&data);
  31. template <typename T>
  32. MemoryPool<T> *getDataBuffer();
  33. // get a data buffer from the memory pool
  34. template <typename T>
  35. T *acquireDataBuffer();
  36. // release a data buffer to the memory pool
  37. template <typename T>
  38. void releaseDataBuffer(T *buffer);
  39. private:
  40. DataManager() = default;
  41. ~DataManager() = default;
  42. DataManager(const DataManager &) = delete;
  43. DataManager &operator=(const DataManager &) = delete;
  44. private:
  45. std::unordered_map<std::string, std::shared_ptr<void>> m_dataPipes;
  46. int width{3840};
  47. int height{2160};
  48. };
  49. template <typename T>
  50. void DataManager::addDataPipe(std::string name)
  51. {
  52. // Check if the data pipe already exists
  53. if (m_dataPipes.find(name) != m_dataPipes.end())
  54. {
  55. return;
  56. }
  57. auto dataPipe = std::make_shared<DataPipe<T>>();
  58. m_dataPipes[name] = dataPipe;
  59. }
  60. template <typename T>
  61. std::shared_ptr<DataPipe<T>> DataManager::getDataPipe(std::string name)
  62. {
  63. auto it = m_dataPipes.find(name);
  64. if (it != m_dataPipes.end())
  65. {
  66. return std::static_pointer_cast<DataPipe<T>>(it->second);
  67. }
  68. return nullptr;
  69. }
  70. template <typename T>
  71. void DataManager::pushData(std::string name, T *data)
  72. {
  73. auto dataPipe = getDataPipe<T>(name);
  74. if (dataPipe)
  75. {
  76. dataPipe->pushData(data);
  77. }
  78. }
  79. template <typename T>
  80. bool DataManager::popData(std::string name, T *&data)
  81. {
  82. auto dataPipe = getDataPipe<T>(name);
  83. if (dataPipe)
  84. {
  85. return dataPipe->popData(data);
  86. }
  87. return false;
  88. }
  89. template <typename T>
  90. MemoryPool<T> *DataManager::getDataBuffer()
  91. {
  92. static MemoryPool<T> memoryPool(BUFFER_SIZE, width, height);
  93. return &memoryPool;
  94. }
  95. template <typename T>
  96. T *DataManager::acquireDataBuffer()
  97. {
  98. // static MemoryPool<T> memoryPool(BUFFER_SIZE, width, height);
  99. return getDataBuffer<T>()->acquire();
  100. }
  101. template <typename T>
  102. void DataManager::releaseDataBuffer(T *buffer)
  103. {
  104. // static MemoryPool<T> memoryPool(BUFFER_SIZE, width, height);
  105. getDataBuffer<T>()->release(buffer);
  106. }
  107. #endif // DATA_MANAGER_H