mirror of
https://gitee.com/johng/gf
synced 2026-06-07 02:12:11 +08:00
This pull request standardizes the use of the Go 1.18+ `any` type alias
instead of `interface{}` throughout the codebase. The change improves
code readability and aligns with modern Go best practices. The update
touches many files, including core data structures, code generation
templates, logging utilities, and test data, ensuring consistency across
all usages.
**Type alias migration to `any`:**
* Replaced all instances of `interface{}` with `any` in core data
structures such as `garray` and in generated model structs (e.g.,
`TableUser`, `User1`, `User2`) to modernize type usage.
[[1]](diffhunk://#diff-3a1259e160a4dfa5fe49dfe739fbdb986c0d0a2220a709882ea48d3ae1b8f911L31-R31)
[[2]](diffhunk://#diff-6c19859cb32c7516ea95ddc8f8235460818eb2f24d2204308e0d9e1b19e7d90fL15-R19)
[[3]](diffhunk://#diff-a15ba2f5e830b4833c47b902515a4f9e5a4f83a3707698f3229b307ec3776b41L15-R18)
[[4]](diffhunk://#diff-52e0837e84d49221d1b810d88fdf78221f36cffcd664fb42f8aba49a79b974dcL15-R19)
[[5]](diffhunk://#diff-11c3457d1a23a4ca6ecd00d6b856289774936b6a708384cf03aff164044e7546L15-R19)
[[6]](diffhunk://#diff-2cff9cf8e6a0cc34087326d8c8149c3bbaf74c76fdbdf5a73daed13cc04249e1L15-R19)
* Updated function signatures, method parameters, and return types from
`interface{}` to `any` in various parts of the codebase, including code
generation, service logic, and logging utilities (e.g., `mlog`).
[[1]](diffhunk://#diff-175edfeea54490b8fe4e18ffcbea5835efaf8f0b8acf623359073987cae7eb76L48-R55)
[[2]](diffhunk://#diff-2b1953fb78cf3593d8c2c7d911e95b65fd0b847c30ed0b4d167d16fe6d781235L54-R74)
[[3]](diffhunk://#diff-e001b7a4b63603b9b14f00de78a4d570bb76c5f57d856a24643f071032e12356L66-R73)
[[4]](diffhunk://#diff-5582954e8a9983988dc8854ad82067fb2ac6269b988e07357ad8db1dfec5f1a0L39-R41)
[[5]](diffhunk://#diff-c5d51d56f487779a2b6207c7ad26c7a20bbadcc846ce094fe60ab4cabff58c51L107-R107)
[[6]](diffhunk://#diff-f96e6a9fdb416eb1804ceaba1fe0ac637bff22c43837f8bb849c2366ce72d4a1L116-R121)
[[7]](diffhunk://#diff-f94c83a1b08ae060d9346f4a6031fc4a7b9a0b894e02d9afaa09018b6598eac0L112-R112)
[[8]](diffhunk://#diff-748b11dbe8828dd4c040ec23cae0b8fe57ecf0a2d1b7694ea39102294e633c64L36-R36)
[[9]](diffhunk://#diff-748b11dbe8828dd4c040ec23cae0b8fe57ecf0a2d1b7694ea39102294e633c64L74-R74)
[[10]](diffhunk://#diff-748b11dbe8828dd4c040ec23cae0b8fe57ecf0a2d1b7694ea39102294e633c64L96-R96)
**Generated code and templates:**
* Adjusted generated files and code generation templates to output `any`
instead of `interface{}` for relevant struct fields and function
signatures, ensuring that new code generation aligns with the updated
convention.
[[1]](diffhunk://#diff-6c19859cb32c7516ea95ddc8f8235460818eb2f24d2204308e0d9e1b19e7d90fL15-R19)
[[2]](diffhunk://#diff-a15ba2f5e830b4833c47b902515a4f9e5a4f83a3707698f3229b307ec3776b41L15-R18)
[[3]](diffhunk://#diff-52e0837e84d49221d1b810d88fdf78221f36cffcd664fb42f8aba49a79b974dcL15-R19)
[[4]](diffhunk://#diff-11c3457d1a23a4ca6ecd00d6b856289774936b6a708384cf03aff164044e7546L15-R19)
[[5]](diffhunk://#diff-2cff9cf8e6a0cc34087326d8c8149c3bbaf74c76fdbdf5a73daed13cc04249e1L15-R19)
[[6]](diffhunk://#diff-175edfeea54490b8fe4e18ffcbea5835efaf8f0b8acf623359073987cae7eb76L48-R55)
[[7]](diffhunk://#diff-e001b7a4b63603b9b14f00de78a4d570bb76c5f57d856a24643f071032e12356L66-R73)
[[8]](diffhunk://#diff-5582954e8a9983988dc8854ad82067fb2ac6269b988e07357ad8db1dfec5f1a0L39-R41)
**Container and utility updates:**
* Refactored the `garray` container implementation and related
constructors/methods to use `[]any` instead of `[]interface{}`, along
with corresponding function signatures.
[[1]](diffhunk://#diff-3a1259e160a4dfa5fe49dfe739fbdb986c0d0a2220a709882ea48d3ae1b8f911L31-R31)
[[2]](diffhunk://#diff-3a1259e160a4dfa5fe49dfe739fbdb986c0d0a2220a709882ea48d3ae1b8f911L52-R52)
[[3]](diffhunk://#diff-3a1259e160a4dfa5fe49dfe739fbdb986c0d0a2220a709882ea48d3ae1b8f911L62-R62)
[[4]](diffhunk://#diff-3a1259e160a4dfa5fe49dfe739fbdb986c0d0a2220a709882ea48d3ae1b8f911L73-R86)
[[5]](diffhunk://#diff-3a1259e160a4dfa5fe49dfe739fbdb986c0d0a2220a709882ea48d3ae1b8f911L96-R97)
[[6]](diffhunk://#diff-3a1259e160a4dfa5fe49dfe739fbdb986c0d0a2220a709882ea48d3ae1b8f911L107-R114)
[[7]](diffhunk://#diff-3a1259e160a4dfa5fe49dfe739fbdb986c0d0a2220a709882ea48d3ae1b8f911L124-R124)
[[8]](diffhunk://#diff-3a1259e160a4dfa5fe49dfe739fbdb986c0d0a2220a709882ea48d3ae1b8f911L135-R143)
[[9]](diffhunk://#diff-3a1259e160a4dfa5fe49dfe739fbdb986c0d0a2220a709882ea48d3ae1b8f911L167-R167)
These changes collectively modernize the codebase and prepare it for
future Go developments by using the idiomatic `any` type.
675 lines
10 KiB
Go
675 lines
10 KiB
Go
// Copyright GoFrame Author(https://goframe.org). All Rights Reserved.
|
|
//
|
|
// This Source Code Form is subject to the terms of the MIT License.
|
|
// If a copy of the MIT was not distributed with gm file,
|
|
// You can obtain one at https://github.com/gogf/gf.
|
|
|
|
package gmap_test
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/gogf/gf/v2/container/gmap"
|
|
"github.com/gogf/gf/v2/frame/g"
|
|
"github.com/gogf/gf/v2/internal/json"
|
|
"github.com/gogf/gf/v2/util/gconv"
|
|
)
|
|
|
|
func ExampleAnyAnyMap_Iterator() {
|
|
m := gmap.New()
|
|
for i := 0; i < 10; i++ {
|
|
m.Set(i, i*2)
|
|
}
|
|
|
|
var totalKey, totalValue int
|
|
m.Iterator(func(k any, v any) bool {
|
|
totalKey += k.(int)
|
|
totalValue += v.(int)
|
|
|
|
return totalKey < 10
|
|
})
|
|
|
|
fmt.Println("totalKey:", totalKey)
|
|
fmt.Println("totalValue:", totalValue)
|
|
|
|
// May Output:
|
|
// totalKey: 11
|
|
// totalValue: 22
|
|
}
|
|
|
|
func ExampleAnyAnyMap_Clone() {
|
|
m := gmap.New()
|
|
|
|
m.Set("key1", "val1")
|
|
fmt.Println(m)
|
|
|
|
n := m.Clone()
|
|
fmt.Println(n)
|
|
|
|
// Output:
|
|
// {"key1":"val1"}
|
|
// {"key1":"val1"}
|
|
}
|
|
|
|
func ExampleAnyAnyMap_Map() {
|
|
// non concurrent-safety, a pointer to the underlying data
|
|
m1 := gmap.New()
|
|
m1.Set("key1", "val1")
|
|
fmt.Println("m1:", m1)
|
|
|
|
n1 := m1.Map()
|
|
fmt.Println("before n1:", n1)
|
|
m1.Set("key1", "val2")
|
|
fmt.Println("after n1:", n1)
|
|
|
|
// concurrent-safety, copy of underlying data
|
|
m2 := gmap.New(true)
|
|
m2.Set("key1", "val1")
|
|
fmt.Println("m2:", m2)
|
|
|
|
n2 := m2.Map()
|
|
fmt.Println("before n2:", n2)
|
|
m2.Set("key1", "val2")
|
|
fmt.Println("after n2:", n2)
|
|
|
|
// Output:
|
|
// m1: {"key1":"val1"}
|
|
// before n1: map[key1:val1]
|
|
// after n1: map[key1:val2]
|
|
// m2: {"key1":"val1"}
|
|
// before n2: map[key1:val1]
|
|
// after n2: map[key1:val1]
|
|
}
|
|
|
|
func ExampleAnyAnyMap_MapCopy() {
|
|
m := gmap.New()
|
|
|
|
m.Set("key1", "val1")
|
|
m.Set("key2", "val2")
|
|
fmt.Println(m)
|
|
|
|
n := m.MapCopy()
|
|
fmt.Println(n)
|
|
|
|
// Output:
|
|
// {"key1":"val1","key2":"val2"}
|
|
// map[key1:val1 key2:val2]
|
|
}
|
|
|
|
func ExampleAnyAnyMap_MapStrAny() {
|
|
m := gmap.New()
|
|
m.Set(1001, "val1")
|
|
m.Set(1002, "val2")
|
|
|
|
n := m.MapStrAny()
|
|
fmt.Printf("%#v", n)
|
|
|
|
// Output:
|
|
// map[string]interface {}{"1001":"val1", "1002":"val2"}
|
|
}
|
|
|
|
func ExampleAnyAnyMap_FilterEmpty() {
|
|
m := gmap.NewFrom(g.MapAnyAny{
|
|
"k1": "",
|
|
"k2": nil,
|
|
"k3": 0,
|
|
"k4": 1,
|
|
})
|
|
m.FilterEmpty()
|
|
fmt.Println(m.Map())
|
|
|
|
// Output:
|
|
// map[k4:1]
|
|
}
|
|
|
|
func ExampleAnyAnyMap_FilterNil() {
|
|
m := gmap.NewFrom(g.MapAnyAny{
|
|
"k1": "",
|
|
"k2": nil,
|
|
"k3": 0,
|
|
"k4": 1,
|
|
})
|
|
m.FilterNil()
|
|
fmt.Printf("%#v", m.Map())
|
|
|
|
// Output:
|
|
// map[interface {}]interface {}{"k1":"", "k3":0, "k4":1}
|
|
}
|
|
|
|
func ExampleAnyAnyMap_Set() {
|
|
m := gmap.New()
|
|
|
|
m.Set("key1", "val1")
|
|
fmt.Println(m)
|
|
|
|
// Output:
|
|
// {"key1":"val1"}
|
|
}
|
|
|
|
func ExampleAnyAnyMap_Sets() {
|
|
m := gmap.New()
|
|
|
|
addMap := make(map[any]any)
|
|
addMap["key1"] = "val1"
|
|
addMap["key2"] = "val2"
|
|
addMap["key3"] = "val3"
|
|
|
|
m.Sets(addMap)
|
|
fmt.Println(m)
|
|
|
|
// Output:
|
|
// {"key1":"val1","key2":"val2","key3":"val3"}
|
|
}
|
|
|
|
func ExampleAnyAnyMap_Search() {
|
|
m := gmap.New()
|
|
|
|
m.Set("key1", "val1")
|
|
|
|
value, found := m.Search("key1")
|
|
if found {
|
|
fmt.Println("find key1 value:", value)
|
|
}
|
|
|
|
value, found = m.Search("key2")
|
|
if !found {
|
|
fmt.Println("key2 not find")
|
|
}
|
|
|
|
// Output:
|
|
// find key1 value: val1
|
|
// key2 not find
|
|
}
|
|
|
|
func ExampleAnyAnyMap_Get() {
|
|
m := gmap.New()
|
|
|
|
m.Set("key1", "val1")
|
|
|
|
fmt.Println("key1 value:", m.Get("key1"))
|
|
fmt.Println("key2 value:", m.Get("key2"))
|
|
|
|
// Output:
|
|
// key1 value: val1
|
|
// key2 value: <nil>
|
|
}
|
|
|
|
func ExampleAnyAnyMap_Pop() {
|
|
var m gmap.Map
|
|
m.Sets(g.MapAnyAny{
|
|
"k1": "v1",
|
|
"k2": "v2",
|
|
"k3": "v3",
|
|
"k4": "v4",
|
|
})
|
|
|
|
fmt.Println(m.Pop())
|
|
|
|
// May Output:
|
|
// k1 v1
|
|
}
|
|
|
|
func ExampleAnyAnyMap_Pops() {
|
|
var m gmap.Map
|
|
m.Sets(g.MapAnyAny{
|
|
"k1": "v1",
|
|
"k2": "v2",
|
|
"k3": "v3",
|
|
"k4": "v4",
|
|
})
|
|
fmt.Println(m.Pops(-1))
|
|
fmt.Println("size:", m.Size())
|
|
|
|
m.Sets(g.MapAnyAny{
|
|
"k1": "v1",
|
|
"k2": "v2",
|
|
"k3": "v3",
|
|
"k4": "v4",
|
|
})
|
|
fmt.Println(m.Pops(2))
|
|
fmt.Println("size:", m.Size())
|
|
|
|
// May Output:
|
|
// map[k1:v1 k2:v2 k3:v3 k4:v4]
|
|
// size: 0
|
|
// map[k1:v1 k2:v2]
|
|
// size: 2
|
|
}
|
|
|
|
func ExampleAnyAnyMap_GetOrSet() {
|
|
m := gmap.New()
|
|
m.Set("key1", "val1")
|
|
|
|
fmt.Println(m.GetOrSet("key1", "NotExistValue"))
|
|
fmt.Println(m.GetOrSet("key2", "val2"))
|
|
|
|
// Output:
|
|
// val1
|
|
// val2
|
|
}
|
|
|
|
func ExampleAnyAnyMap_GetOrSetFunc() {
|
|
m := gmap.New()
|
|
m.Set("key1", "val1")
|
|
|
|
fmt.Println(m.GetOrSetFunc("key1", func() any {
|
|
return "NotExistValue"
|
|
}))
|
|
fmt.Println(m.GetOrSetFunc("key2", func() any {
|
|
return "NotExistValue"
|
|
}))
|
|
|
|
// Output:
|
|
// val1
|
|
// NotExistValue
|
|
}
|
|
|
|
func ExampleAnyAnyMap_GetOrSetFuncLock() {
|
|
m := gmap.New()
|
|
m.Set("key1", "val1")
|
|
|
|
fmt.Println(m.GetOrSetFuncLock("key1", func() any {
|
|
return "NotExistValue"
|
|
}))
|
|
fmt.Println(m.GetOrSetFuncLock("key2", func() any {
|
|
return "NotExistValue"
|
|
}))
|
|
|
|
// Output:
|
|
// val1
|
|
// NotExistValue
|
|
}
|
|
|
|
func ExampleAnyAnyMap_GetVar() {
|
|
m := gmap.New()
|
|
m.Set("key1", "val1")
|
|
|
|
fmt.Println(m.GetVar("key1"))
|
|
fmt.Println(m.GetVar("key2").IsNil())
|
|
|
|
// Output:
|
|
// val1
|
|
// true
|
|
}
|
|
|
|
func ExampleAnyAnyMap_GetVarOrSet() {
|
|
m := gmap.New()
|
|
m.Set("key1", "val1")
|
|
|
|
fmt.Println(m.GetVarOrSet("key1", "NotExistValue"))
|
|
fmt.Println(m.GetVarOrSet("key2", "val2"))
|
|
|
|
// Output:
|
|
// val1
|
|
// val2
|
|
}
|
|
|
|
func ExampleAnyAnyMap_GetVarOrSetFunc() {
|
|
m := gmap.New()
|
|
m.Set("key1", "val1")
|
|
|
|
fmt.Println(m.GetVarOrSetFunc("key1", func() any {
|
|
return "NotExistValue"
|
|
}))
|
|
fmt.Println(m.GetVarOrSetFunc("key2", func() any {
|
|
return "NotExistValue"
|
|
}))
|
|
|
|
// Output:
|
|
// val1
|
|
// NotExistValue
|
|
}
|
|
|
|
func ExampleAnyAnyMap_GetVarOrSetFuncLock() {
|
|
m := gmap.New()
|
|
m.Set("key1", "val1")
|
|
|
|
fmt.Println(m.GetVarOrSetFuncLock("key1", func() any {
|
|
return "NotExistValue"
|
|
}))
|
|
fmt.Println(m.GetVarOrSetFuncLock("key2", func() any {
|
|
return "NotExistValue"
|
|
}))
|
|
|
|
// Output:
|
|
// val1
|
|
// NotExistValue
|
|
}
|
|
|
|
func ExampleAnyAnyMap_SetIfNotExist() {
|
|
var m gmap.Map
|
|
fmt.Println(m.SetIfNotExist("k1", "v1"))
|
|
fmt.Println(m.SetIfNotExist("k1", "v2"))
|
|
fmt.Println(m.Map())
|
|
|
|
// Output:
|
|
// true
|
|
// false
|
|
// map[k1:v1]
|
|
}
|
|
|
|
func ExampleAnyAnyMap_SetIfNotExistFunc() {
|
|
var m gmap.Map
|
|
fmt.Println(m.SetIfNotExistFunc("k1", func() any {
|
|
return "v1"
|
|
}))
|
|
fmt.Println(m.SetIfNotExistFunc("k1", func() any {
|
|
return "v2"
|
|
}))
|
|
fmt.Println(m.Map())
|
|
|
|
// Output:
|
|
// true
|
|
// false
|
|
// map[k1:v1]
|
|
}
|
|
|
|
func ExampleAnyAnyMap_SetIfNotExistFuncLock() {
|
|
var m gmap.Map
|
|
fmt.Println(m.SetIfNotExistFuncLock("k1", func() any {
|
|
return "v1"
|
|
}))
|
|
fmt.Println(m.SetIfNotExistFuncLock("k1", func() any {
|
|
return "v2"
|
|
}))
|
|
fmt.Println(m.Map())
|
|
|
|
// Output:
|
|
// true
|
|
// false
|
|
// map[k1:v1]
|
|
}
|
|
|
|
func ExampleAnyAnyMap_Remove() {
|
|
var m gmap.Map
|
|
m.Set("k1", "v1")
|
|
|
|
fmt.Println(m.Remove("k1"))
|
|
fmt.Println(m.Remove("k2"))
|
|
fmt.Println(m.Size())
|
|
|
|
// Output:
|
|
// v1
|
|
// <nil>
|
|
// 0
|
|
}
|
|
|
|
func ExampleAnyAnyMap_Removes() {
|
|
var m gmap.Map
|
|
m.Sets(g.MapAnyAny{
|
|
"k1": "v1",
|
|
"k2": "v2",
|
|
"k3": "v3",
|
|
"k4": "v4",
|
|
})
|
|
|
|
removeList := make([]any, 2)
|
|
removeList = append(removeList, "k1")
|
|
removeList = append(removeList, "k2")
|
|
|
|
m.Removes(removeList)
|
|
|
|
fmt.Println(m.Map())
|
|
|
|
// Output:
|
|
// map[k3:v3 k4:v4]
|
|
}
|
|
|
|
func ExampleAnyAnyMap_Keys() {
|
|
var m gmap.Map
|
|
m.Sets(g.MapAnyAny{
|
|
"k1": "v1",
|
|
"k2": "v2",
|
|
"k3": "v3",
|
|
"k4": "v4",
|
|
})
|
|
fmt.Println(m.Keys())
|
|
|
|
// May Output:
|
|
// [k1 k2 k3 k4]
|
|
}
|
|
|
|
func ExampleAnyAnyMap_Values() {
|
|
var m gmap.Map
|
|
m.Sets(g.MapAnyAny{
|
|
"k1": "v1",
|
|
"k2": "v2",
|
|
"k3": "v3",
|
|
"k4": "v4",
|
|
})
|
|
fmt.Println(m.Values())
|
|
|
|
// May Output:
|
|
// [v1 v2 v3 v4]
|
|
}
|
|
|
|
func ExampleAnyAnyMap_Contains() {
|
|
var m gmap.Map
|
|
m.Sets(g.MapAnyAny{
|
|
"k1": "v1",
|
|
"k2": "v2",
|
|
"k3": "v3",
|
|
"k4": "v4",
|
|
})
|
|
|
|
fmt.Println(m.Contains("k1"))
|
|
fmt.Println(m.Contains("k5"))
|
|
|
|
// Output:
|
|
// true
|
|
// false
|
|
}
|
|
|
|
func ExampleAnyAnyMap_Size() {
|
|
var m gmap.Map
|
|
m.Sets(g.MapAnyAny{
|
|
"k1": "v1",
|
|
"k2": "v2",
|
|
"k3": "v3",
|
|
"k4": "v4",
|
|
})
|
|
|
|
fmt.Println(m.Size())
|
|
|
|
// Output:
|
|
// 4
|
|
}
|
|
|
|
func ExampleAnyAnyMap_IsEmpty() {
|
|
var m gmap.Map
|
|
fmt.Println(m.IsEmpty())
|
|
|
|
m.Set("k1", "v1")
|
|
fmt.Println(m.IsEmpty())
|
|
|
|
// Output:
|
|
// true
|
|
// false
|
|
}
|
|
|
|
func ExampleAnyAnyMap_Clear() {
|
|
var m gmap.Map
|
|
m.Sets(g.MapAnyAny{
|
|
"k1": "v1",
|
|
"k2": "v2",
|
|
"k3": "v3",
|
|
"k4": "v4",
|
|
})
|
|
|
|
m.Clear()
|
|
|
|
fmt.Println(m.Map())
|
|
|
|
// Output:
|
|
// map[]
|
|
}
|
|
|
|
func ExampleAnyAnyMap_Replace() {
|
|
var m gmap.Map
|
|
m.Sets(g.MapAnyAny{
|
|
"k1": "v1",
|
|
})
|
|
|
|
var n gmap.Map
|
|
n.Sets(g.MapAnyAny{
|
|
"k2": "v2",
|
|
})
|
|
|
|
fmt.Println(m.Map())
|
|
|
|
m.Replace(n.Map())
|
|
fmt.Println(m.Map())
|
|
|
|
n.Set("k2", "v1")
|
|
fmt.Println(m.Map())
|
|
|
|
// Output:
|
|
// map[k1:v1]
|
|
// map[k2:v2]
|
|
// map[k2:v1]
|
|
}
|
|
|
|
func ExampleAnyAnyMap_LockFunc() {
|
|
var m gmap.Map
|
|
m.Sets(g.MapAnyAny{
|
|
"k1": 1,
|
|
"k2": 2,
|
|
"k3": 3,
|
|
"k4": 4,
|
|
})
|
|
|
|
m.LockFunc(func(m map[any]any) {
|
|
totalValue := 0
|
|
for _, v := range m {
|
|
totalValue += v.(int)
|
|
}
|
|
fmt.Println("totalValue:", totalValue)
|
|
})
|
|
|
|
// Output:
|
|
// totalValue: 10
|
|
}
|
|
|
|
func ExampleAnyAnyMap_RLockFunc() {
|
|
var m gmap.Map
|
|
m.Sets(g.MapAnyAny{
|
|
"k1": 1,
|
|
"k2": 2,
|
|
"k3": 3,
|
|
"k4": 4,
|
|
})
|
|
|
|
m.RLockFunc(func(m map[any]any) {
|
|
totalValue := 0
|
|
for _, v := range m {
|
|
totalValue += v.(int)
|
|
}
|
|
fmt.Println("totalValue:", totalValue)
|
|
})
|
|
|
|
// Output:
|
|
// totalValue: 10
|
|
}
|
|
|
|
func ExampleAnyAnyMap_Flip() {
|
|
var m gmap.Map
|
|
m.Sets(g.MapAnyAny{
|
|
"k1": "v1",
|
|
})
|
|
m.Flip()
|
|
fmt.Println(m.Map())
|
|
|
|
// Output:
|
|
// map[v1:k1]
|
|
}
|
|
|
|
func ExampleAnyAnyMap_Merge() {
|
|
var m1, m2 gmap.Map
|
|
m1.Set("key1", "val1")
|
|
m2.Set("key2", "val2")
|
|
m1.Merge(&m2)
|
|
fmt.Println(m1.Map())
|
|
|
|
// May Output:
|
|
// map[key1:val1 key2:val2]
|
|
}
|
|
|
|
func ExampleAnyAnyMap_String() {
|
|
var m gmap.Map
|
|
m.Sets(g.MapAnyAny{
|
|
"k1": "v1",
|
|
})
|
|
|
|
fmt.Println(m.String())
|
|
|
|
var m1 *gmap.Map = nil
|
|
fmt.Println(len(m1.String()))
|
|
|
|
// Output:
|
|
// {"k1":"v1"}
|
|
// 0
|
|
}
|
|
|
|
func ExampleAnyAnyMap_MarshalJSON() {
|
|
var m gmap.Map
|
|
m.Sets(g.MapAnyAny{
|
|
"k1": "v1",
|
|
"k2": "v2",
|
|
"k3": "v3",
|
|
"k4": "v4",
|
|
})
|
|
|
|
bytes, err := json.Marshal(&m)
|
|
if err == nil {
|
|
fmt.Println(gconv.String(bytes))
|
|
}
|
|
|
|
// Output:
|
|
// {"k1":"v1","k2":"v2","k3":"v3","k4":"v4"}
|
|
}
|
|
|
|
func ExampleAnyAnyMap_UnmarshalJSON() {
|
|
var m gmap.Map
|
|
m.Sets(g.MapAnyAny{
|
|
"k1": "v1",
|
|
"k2": "v2",
|
|
"k3": "v3",
|
|
"k4": "v4",
|
|
})
|
|
|
|
var n gmap.Map
|
|
|
|
err := json.Unmarshal(gconv.Bytes(m.String()), &n)
|
|
if err == nil {
|
|
fmt.Println(n.Map())
|
|
}
|
|
|
|
// Output:
|
|
// map[k1:v1 k2:v2 k3:v3 k4:v4]
|
|
}
|
|
|
|
func ExampleAnyAnyMap_UnmarshalValue() {
|
|
type User struct {
|
|
Uid int
|
|
Name string
|
|
Pass1 string `gconv:"password1"`
|
|
Pass2 string `gconv:"password2"`
|
|
}
|
|
|
|
var (
|
|
m gmap.AnyAnyMap
|
|
user = User{
|
|
Uid: 1,
|
|
Name: "john",
|
|
Pass1: "123",
|
|
Pass2: "456",
|
|
}
|
|
)
|
|
if err := gconv.Scan(user, &m); err == nil {
|
|
fmt.Printf("%#v", m.Map())
|
|
}
|
|
|
|
// Output:
|
|
// map[interface {}]interface {}{"Name":"john", "Uid":1, "password1":"123", "password2":"456"}
|
|
}
|