Go Basics

Variables

Strictly Typed and Compiled

1var a bool
2a = false
3b := true
4
5fmt.Println(a, "and", b) // false and true
1type banana int
2var b banana
3fmt.Println(b)
4// 0
5fmt.Printf("%T\n", b)
6// main.banana

Functions

function singature func functionname(parametername type) returntype {

1func addNum(a int, b int) int {
2  var sum = a + b
3  return sum
4}

hello world

1package main
2
3import (
4  "fmt"
5)
6
7func main() {
8  fmt.Printf("Hello, Chris.\n")
9}

Composite Data Types

Arrays

Arrays are fixed length

ArrayType = [length]ElementType

1var list [5]int
2fmt.Println(list)
3// [0 0 0 0 0]

Slices

Numbered lists of a single type. They can be resized. Slices are built on top of arrays and passed by reference

Composite literal syntax t := type{values}

1listX := []int{1, 2, 5, 8}
2fmt.Println(listX)
3// [1 2 5 8]

Iterate through slice

 1// range allows looping through slices 
 2// (as well as arrays, maps, strings, 
 3// and reading from channels)
 4for index, value := range listX {
 5    fmt.Println(index, value)
 6}
 7//0 1
 8//1 2
 9//2 5
10//3 8

Working with Slices

Make function will create a new slice

1var listY = make([]string, 3, 5)

Shorthand for creating a new slice and iterating through it

1for i, v := range []string{"foo", "bar", "baz"} {
2    listY[i] = v
3}

Append items to slice.

1listOdd := []int{1, 3, 5, 7, 8}
2listOdd = append(listOdd, 9, 11, 13, 15)
3fmt.Println(listOdd)
4
5newOddNumbers := []int{17, 19, 21}
6listOdd = append(listOdd, newOddNumbers...)

... will unfurl a list. It is useful for passing in variadic parameters from list data types (like above.)

Slicing a slice

 1fmt.Println(listOdd[0])
 2// 1
 3fmt.Println(listOdd[1])
 4// 2
 5fmt.Println(listOdd[2:5])
 6// [5 7 8]
 7// From the beginning to the specified index
 8fmt.Println(listOdd[:5])
 9// [1 3 5 7 8]
10// From the specified index to the end
11fmt.Println(listOdd[5:])
12// [9 11 13 15 17 19 21]

Deleting from a slice

1// Deleting element from slice.
2listOdd = append(listOdd, 22, 24, 23, 25)
3fmt.Println(listOdd)
4// [1 3 5 7 8 9 11 13 15 17 19 21 22 24 23 25]
5realOdd := append(listOdd[:12], listOdd[14:]...)
6fmt.Println(realOdd)
7// [1 3 5 7 8 9 11 13 15 17 19 21]

Maps

hash table data type

MAPS CAN ONLY BE INITIATED USING make() or A LITERAL. cannot appent to a zero valued maps!

 1// m = make(map[string]int)
 2m["route"] = 66
 3
 4// receive map value
 5i := m["route"]
 6
 7// if value DNE, types zero value is returned
 8j := m["foo"]
 9// j == 0
10
11// delete item from map
12delete(m, "route")

Check if map value exist

the second value ok is a bool that is true if key exists in map

1i, ok := m["route"]

Maps Passed by reference

Maps are passed by reference;

i.e. when passed to a function, operations are performed on the underlying map

comments powered by Disqus