123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102 |
- package common
- import (
- "fmt"
- "math/rand"
- "sync"
- )
- func GetCode() string {
- res := Example(5, 10)
- for i := 0; i < len(res); i++ {
- fmt.Println(i+1, res[i])
- }
- return res[0]
- }
- func Example(length int, max int) []string {
- // Seeding with the same value results in the same random sequence each run.
- // For different numbers, seed with a different value, such as
- // time.Now().UnixNano(), which yields a constantly-changing number.
- //rand.Seed(42)
- digitNumber := []string{
- "1", "2", "3", "4", "5", "6", "7", "8", "9", "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z",
- }
- // 用make创建map
- set := New()
- for set.Len() < max {
- ranNumber := ""
- for j := 1; j < length; j++ {
- ranNumber += digitNumber[rand.Intn(len(digitNumber))]
- }
- if !set.Has(ranNumber) {
- set.Add(ranNumber)
- }
- }
- return set.List()
- }
- /*
- *
- 构造set类型
- */
- type Set struct {
- m map[string]bool
- sync.RWMutex
- }
- func New() *Set {
- return &Set{
- m: map[string]bool{},
- }
- }
- func (s *Set) Add(item string) {
- s.Lock()
- defer s.Unlock()
- s.m[item] = true
- }
- func (s *Set) Remove(item string) {
- s.Lock()
- s.Unlock()
- delete(s.m, item)
- }
- func (s *Set) Has(item string) bool {
- s.RLock()
- defer s.RUnlock()
- _, ok := s.m[item]
- return ok
- }
- func (s *Set) Len() int {
- return len(s.List())
- }
- func (s *Set) Clear() {
- s.Lock()
- defer s.Unlock()
- s.m = map[string]bool{}
- }
- func (s *Set) IsEmpty() bool {
- if s.Len() == 0 {
- return true
- }
- return false
- }
- func (s *Set) List() []string {
- s.RLock()
- defer s.RUnlock()
- list := []string{}
- for item := range s.m {
- list = append(list, item)
- }
- return list
- }
|