1
0
mirror of https://github.com/charlienet/go-mixed.git synced 2025-07-18 00:22:41 +08:00
This commit is contained in:
2022-05-12 10:03:07 +08:00
parent af7029133f
commit 3dc3fbb0f2
2 changed files with 17 additions and 14 deletions

View File

@ -1,6 +1,10 @@
package maps package maps
import "golang.org/x/exp/constraints" import (
"strings"
"golang.org/x/exp/constraints"
)
type Map[K constraints.Ordered, V any] interface { type Map[K constraints.Ordered, V any] interface {
Set(key K, value V) // 设置值 Set(key K, value V) // 设置值
@ -32,3 +36,14 @@ func Merge[K comparable, V any](mm ...map[K]V) map[K]V {
return ret return ret
} }
// 按照键值生成字符串
func Join[K constraints.Ordered, V any](m Map[K, V], sep string, f func(k K, v V) string) string {
slice := make([]string, 0, m.Count())
for _, k := range m.Keys() {
v, _ := m.Get(k)
slice = append(slice, f(k, v))
}
return strings.Join(slice, sep)
}

View File

@ -2,7 +2,6 @@ package maps
import ( import (
"fmt" "fmt"
"strings"
"golang.org/x/exp/constraints" "golang.org/x/exp/constraints"
"golang.org/x/exp/slices" "golang.org/x/exp/slices"
@ -32,7 +31,6 @@ func NewSortedMap[K constraints.Ordered, V any](maps ...map[K]V) *sorted_map[K,
} }
func NewSortedByMap[K constraints.Ordered, V any](m Map[K, V]) *sorted_map[K, V] { func NewSortedByMap[K constraints.Ordered, V any](m Map[K, V]) *sorted_map[K, V] {
return &sorted_map[K, V]{maps: m, keys: m.Keys()} return &sorted_map[K, V]{maps: m, keys: m.Keys()}
} }
@ -94,16 +92,6 @@ func (m *sorted_map[K, V]) Exist(key K) bool {
return m.Exist(key) return m.Exist(key)
} }
func (m *sorted_map[K, V]) Join(sep string, f func(k K, v V) string) string {
slice := make([]string, 0, m.maps.Count())
for _, k := range m.keys {
v, _ := m.maps.Get(k)
slice = append(slice, f(k, v))
}
return strings.Join(slice, sep)
}
func (m *sorted_map[K, V]) Keys() []K { func (m *sorted_map[K, V]) Keys() []K {
return m.keys return m.keys
} }
@ -123,7 +111,7 @@ func (s *sorted_map[K, V]) ToMap() map[K]V {
} }
func (m *sorted_map[K, V]) String() string { func (m *sorted_map[K, V]) String() string {
return fmt.Sprintf("map[%s]", m.Join(" ", func(k K, v V) string { return fmt.Sprintf("map[%s]", Join[K, V](m, " ", func(k K, v V) string {
return fmt.Sprintf("%v:%v", k, v) return fmt.Sprintf("%v:%v", k, v)
})) }))
} }