Skip to main content

Do you support us?

Business address
0x1D24D8f27ea73ff604C7685246bdC6ae55bddaEF

Will you friendship with maps?

Maps is a collection of keys and values. [K] represent keys, all the keys have same type V represent values. Just like keys, all values have same types, but both keys and values are not comparable. You can compare keys with other keys.

           make(maps[K]V)  you can create maps like this. 
            
              ages := make(maps[string]int)
              ages["ali"] = 24
         If key doesn't found in a maps then it return zero value. You can applied any operation such as 
       ages["ali"]++ 
       ages["ali"]+= 1
        
 You can delete maps using built-in function delete. If a key doesn't found and you store value then it return panic error. 

package main
import (
"fmt"
)
func main() {
//slices
names := [...]string{"ali","haider","johny"}
name := make([]string, 0, len(names))
for _ , v := range names{
name = append(name, v)
fmt.Println(name)
}
}

make([]string, 0, len(names)):
                        return a new string slice having 3 size capacity.
 append():
                  go provide append function which takes two parameter one slice-array and other is value. name is already a slice-array and empty array. 
"_" : 
         blank identifier is used because I omit "i"

In this example slice-array copy one by one element into another array. 

Slices and Maps values are interchangeable:
package main
import (
"fmt"
)
func main() {
//slices to maps
names := [...]string{"ali","haider","johny"}
person := make(map[string]int)
for _, v := range names{
person[v] = 24
fmt.Println(person)
}
}
     
Sometimes we want to check particular key values is either zero or present.
package main
import (
"fmt"
)
func main() {
//slices to maps
person := make(map[string]int)
person["ali"] = 24
person["haider"] =23
if details , ok := person["haider"]; ok{
fmt.Println(ok)
}
} if details , ok := person["haider"]; ok: ok return bool value. details contain haider age and ok contain true. This condition tells us that haider is a valid key Warning: Always remember comparable two maps must be slice, otherwise comparison is possible. var m = make(map[string]int)

func k(list []string) string { return fmt.Sprintf("%q", list)}
func Add(list []string) {  m[k(list)]++ }
func Count(list []string) int { return m[k(list)] }
Maps are not variables, so you don't it's address Composite Maps: You can create composite maps make(maps[string]maps[string]bool) gopl.io/ch4/graph
var graph = make(map[string]map[string]bool)
func addEdge(from, to string) {
         edges := graph[from]
if edges == nil {
      edges = make(map[string]bool)
      graph[from] = edges }
        edges[to] = true
}
func hasEdge(from, to string) bool { return graph[from][to] }
This is the best composite example which Go Programming Book. Now you can understand maps in deep.

Comments

Popular posts from this blog

Rosicrucian cipher

In 1513 Cornelius Agrippa introduce early form Rosicrucian Cipher in his books Occult of Philosophy. Geometric and simple substitution cipher are well known ciphers      Pigpen , Freemason, Napoleon and tic tac toe ciphers in which alphabets or symbols arrange in grids.  This is an anagram, "How to reconstruct a data " lets encode the message.       Pigpen cipher , Rosicrucian and Tic tac toe Cipher                      Thank you have a good day.    

Life is all about decisions and repeat your routine

Life is all about Decisions and repeat our routine is an excellent idea which i show you within a moment. Everyday we take so many decisions based on environment conditions, circumstances. Each decision based on cause and effect philosophy. Programmer are wizards who create own world with data and structures. Without data or structure our world is nothing. Conditions: Conditions help us to take decision based under certain circumstances, such as if a number divisible by 2 at least two times then it's said to be double even. package main import ( "fmt" ) func main() { const divisible =2 var even int = 4 if even%divisible == 0 { n := even/divisible n /= divisible if n ==1 { fmt.Println("Doubly Even")  } }   } If you're a developer then you you know this code quite different from other languages syntax. In most languages, you see like this "if (condition)". Yeah it's different but this language compilati

Enumerate

Golang provide  own enumerate method which is easy and very powerful. I will show you enumerate with in a sec. When i code enumerate in java, believe me i don't understand why it's used? So i never play from this card at that time, but recently when i start learning go. Now i used where it's used and why? Enumerate basically a counting method. Code   package main import ( " fmt " ) type Weekend int const ( Sunday Weekend = iota Monday Tuesday Wednesday Thursday Friday Saturday ) func main () { fmt. Printf ( " %d " ,Saturday) } If you remember adding color layer then you familiar from this code.  First i create my own type called weekend then used this type.  Iota-generator:   Things that confuse you Sunday Weekend = iota & Monday without value. Before we start Iota-generator first we understand monday without type or value         const ( c = 1 // c : 1 d      // d : 1 ) fmt.Pr