sync_slice.go 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. package syncutils
  2. import "sync"
  3. type RangeFunc[T any] func(index int, e T) bool
  4. type SyncSlice[T any] struct {
  5. writeLocker sync.Locker
  6. readLocker sync.Locker
  7. s []T
  8. }
  9. func NewSyncSlice[T any](s []T, isRWMutex bool) *SyncSlice[T] {
  10. var writeLocker sync.Locker
  11. var readLocker sync.Locker
  12. if !isRWMutex {
  13. mutex := &sync.Mutex{}
  14. writeLocker = mutex
  15. readLocker = mutex
  16. } else {
  17. mutex := &sync.RWMutex{}
  18. writeLocker = mutex
  19. readLocker = mutex.RLocker()
  20. }
  21. return &SyncSlice[T]{
  22. writeLocker: writeLocker,
  23. readLocker: readLocker,
  24. s: s,
  25. }
  26. }
  27. func (syncSlice *SyncSlice[T]) Lock() {
  28. syncSlice.writeLocker.Lock()
  29. }
  30. func (syncSlice *SyncSlice[T]) Unlock() {
  31. syncSlice.writeLocker.Unlock()
  32. }
  33. func (syncSlice *SyncSlice[T]) RLock() {
  34. syncSlice.readLocker.Lock()
  35. }
  36. func (syncSlice *SyncSlice[T]) RUnlock() {
  37. syncSlice.readLocker.Unlock()
  38. }
  39. func (syncSlice *SyncSlice[T]) AppendNoLock(elements ...T) {
  40. if elements == nil || len(elements) == 0 {
  41. return
  42. }
  43. syncSlice.appendNoLock(elements...)
  44. }
  45. func (syncSlice *SyncSlice[T]) DeleteAtNoLock(index int) {
  46. if index < 0 {
  47. return
  48. }
  49. syncSlice.deleteAtNoLock(index)
  50. }
  51. func (syncSlice *SyncSlice[T]) RangeNoLock(rangeFunc RangeFunc[T]) {
  52. if rangeFunc == nil {
  53. return
  54. }
  55. syncSlice.rangeNoLock(rangeFunc)
  56. }
  57. func (syncSlice *SyncSlice[T]) Append(elements ...T) {
  58. if elements == nil || len(elements) == 0 {
  59. return
  60. }
  61. syncSlice.writeLocker.Lock()
  62. defer syncSlice.writeLocker.Unlock()
  63. syncSlice.appendNoLock(elements...)
  64. }
  65. func (syncSlice *SyncSlice[T]) DeleteAt(index int) {
  66. if index < 0 {
  67. return
  68. }
  69. syncSlice.writeLocker.Lock()
  70. defer syncSlice.writeLocker.Unlock()
  71. syncSlice.deleteAtNoLock(index)
  72. }
  73. func (syncSlice *SyncSlice[T]) Range(rangeFunc RangeFunc[T]) {
  74. if rangeFunc == nil {
  75. return
  76. }
  77. syncSlice.readLocker.Lock()
  78. defer syncSlice.readLocker.Unlock()
  79. syncSlice.rangeNoLock(rangeFunc)
  80. }
  81. func (syncSlice *SyncSlice[T]) appendNoLock(elements ...T) {
  82. syncSlice.s = append(syncSlice.s, elements...)
  83. }
  84. func (syncSlice *SyncSlice[T]) deleteAtNoLock(index int) {
  85. syncSlice.s = append(syncSlice.s[:index], syncSlice.s[index+1:]...)
  86. }
  87. func (syncSlice *SyncSlice[T]) rangeNoLock(rangeFunc RangeFunc[T]) {
  88. for i, e := range syncSlice.s {
  89. stop := rangeFunc(i, e)
  90. if stop {
  91. return
  92. }
  93. }
  94. }