write-copy.h 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. #ifndef _WRITE_COPY_HPP_
  2. #define _WRITE_COPY_HPP_
  3. #include <unordered_map>
  4. #include <algorithm>
  5. #include <memory>
  6. #include <mutex>
  7. #include "visit.h"
  8. template<typename T,typename K,typename V>
  9. struct write_copy_base:acceptor<V>
  10. {
  11. std::unordered_map<K,V> m_map;
  12. write_copy_base()
  13. {
  14. }
  15. V get(K k)const
  16. {
  17. return m_map[k];
  18. }
  19. std::shared_ptr<T> clone()const
  20. {
  21. std::shared_ptr<T> ret=std::make_shared<T>();
  22. ret->m_map.insert(m_map.begin(),m_map.end());
  23. return ret;
  24. }
  25. std::shared_ptr<T> clone_add(const std::unordered_map<K,V>&m)const
  26. {
  27. std::shared_ptr<T> ret=std::move(clone());
  28. ret->_add(m);
  29. return ret;
  30. }
  31. std::shared_ptr<T> clone_add(K k,V v)const
  32. {
  33. std::shared_ptr<T> ret=std::move(clone());
  34. ret->_add(k,v);
  35. return ret;
  36. }
  37. std::shared_ptr<T> clone_remove(K k)const
  38. {
  39. std::shared_ptr<T> ret=std::move(clone());
  40. ret->_remove(k);
  41. return ret;
  42. }
  43. std::shared_ptr<T> clone_remove(const std::vector<K>&list)const
  44. {
  45. std::shared_ptr<T> ret=std::move(clone());
  46. ret->_remove(list);
  47. return ret;
  48. }
  49. virtual ~write_copy_base()
  50. {
  51. // std::for_each(m_list.begin(),m_list.end(),[](K*it){ });
  52. }
  53. private:
  54. void _remove(K k)
  55. {
  56. m_map.erase(k);
  57. }
  58. void _remove(const std::vector<K>& v)
  59. {
  60. for(K&k:v)
  61. {
  62. m_map.erase(k);
  63. }
  64. }
  65. void _add(K k,V v)
  66. {
  67. m_map.insert(std::make_pair(k,v));
  68. }
  69. void _add(const std::unordered_map<K,V>&m)
  70. {
  71. m_map.insert(m.begin(),m.end());
  72. }
  73. };
  74. template<typename T,typename K,typename V>
  75. struct single_base:write_copy_base<T,K,V>
  76. {
  77. typedef write_copy_base<T,K,V> base;
  78. static std::shared_ptr<T> m_instance;
  79. static std::shared_ptr<T> instance()
  80. {
  81. return m_instance;
  82. }
  83. std::mutex m_mutex;
  84. void add(K k,V c)
  85. {
  86. std::lock_guard<std::mutex> lock(m_mutex);
  87. m_instance=std::move(base::clone_add(k,c));
  88. }
  89. void add(const std::unordered_map<K,V>&c)
  90. {
  91. std::lock_guard<std::mutex> lock(m_mutex);
  92. m_instance=std::move(base::clone_add(c));
  93. }
  94. void remove(K k,V c)
  95. {
  96. std::lock_guard<std::mutex> lock(m_mutex);
  97. m_instance=std::move(base::clone_remove(k,c));
  98. }
  99. void remove(const std::unordered_map<K,V>&c)
  100. {
  101. std::lock_guard<std::mutex> lock(m_mutex);
  102. m_instance=std::move(base::clone_remove(c));
  103. }
  104. };
  105. #endif