golang-基础

1.go的特点

兼具动态语言的开发效率与C,C++,java的性能安全性 ,内置编译器

2.go的安装

go的sdk下载:  https://studygolang.com/dl

go的IDE下载: https://www.jetbrains.com/go/ 

3.go run与go build

go run 编译后直接执行

go build 编译成二进制文件 ,源码文件会小于编译文件 ,编译文件包含了其他依赖

4.数据类型

数据类型是让编程语言,编译器,数据库,代码环境知道如何去操作处理数据的

强类型语言:错误的使用数据类型将会报错 ,数据类型变换需要强制转换(go,python)

弱类型语言:为了程序的执行,在运行时将一种数据类型转换为另一种(bash-shell ,js)

静态语言:编译执行性能高 ,编译器检查数据类型正确, 安全性与性能(go)

动态语言:快速的开发效率 ,可移植性和兼容性好 ,简单与开发速度(python)

5.go声明变量

显示声明:全局变量必须使用显示声明 ,也可用于函数中

简短声明:函数内变量多使用简短声明 ,不用于全局

6.go的内置基本数据类型

布尔类型 :在go中布尔值仅仅是 "true" 和 "false" ,任何零值都无法作为布尔值直接判断

数值类型 :整形带符号int和不带符号uint ,带符号是首位0,1用来表示符号有无 ,go中是用int会自动判断是int64还是int32 

      浮点型单精度双精度浮点数 ,float32和float64

字符串类型 :string

数组 :go的数组是类型和长度固定的

7.检查变量的类型

标准库的reflect包

package main

import (
    "fmt"
    "reflect"
)

func main() {
    a := 1
    b:= "1"
    c := true
    d := [3]string{"1","2","3"}
    fmt.Println(a,reflect.TypeOf(a))
    fmt.Println(a,reflect.TypeOf(b))
    fmt.Println(a,reflect.TypeOf(c))
    fmt.Println(a,reflect.TypeOf(d))
}

8.数值类型转换

整数与浮点的转换

package main

import (
    "fmt"
    "reflect"
)

func main() {
    i := 1
    n := 2.7
    fmt.Println(i,reflect.TypeOf(i),n,reflect.TypeOf(n))
    i1 := float64(i)
    n1 := int(n)
    fmt.Println(i1,reflect.TypeOf(i1),n1,reflect.TypeOf(n1))
}

浮点数的计算问题处理

  浮点数存储在内存时 ,此方不能精准表示小数部分 使用第三方decimal包来解决

package main

import (
   "fmt"
   "github.com/shopspring/decimal"
)

func main() {
   var m,n float64 = 14.1,13.5
   //浮点数存储在内存,次方不能精准表示浮点数就会出现偏差  (除法乘法问题)
   fmt.Println(m-n)   
   fmt.Println(m*n)
   fmt.Println(m/n)
   fmt.Println(m+n)
   q1 := decimal.NewFromFloat(m).Sub(decimal.NewFromFloat(n))
   q2 := decimal.NewFromFloat(m).Add(decimal.NewFromFloat(n))
   q3 := decimal.NewFromFloat(m).Mul(decimal.NewFromFloat(n))
   q4 := decimal.NewFromFloat(m).Div(decimal.NewFromFloat(n))
   fmt.Println(q1,q2,q3,q4)
}

字符串与整型之间的转换 使用标准库的strconv包

  字符串转整数可能会出现异常 ,根据go的错误处理机制 ,调用者需要接收错误处理 ,所以Atoi函数有两个返回值接收

package main

import (
    "fmt"
    "reflect"
    "strconv"
)

func main() {
    str1 := "192"
    int1 := 192
    fmt.Println(str1, reflect.TypeOf(str1), int1, reflect.TypeOf(int1))
    str2, err := strconv.Atoi(str1)
    fmt.Println(str2, reflect.TypeOf(str2), err)  //str2是字符串被转换为整型
    int2 :=strconv.Itoa(int1)
    fmt.Println(int2, reflect.TypeOf(int2), err)  //int2是整数被转为字符串
}

Parse类函数 :将string转换为其他类型(bool int float uint) 

  base: 转换为多少进制 basesize: 转化为多少位 

  返回的错误由" _ "黑盒子收走

package main

import (
    "fmt"
    "reflect"
    "strconv"
)

func main() {
    a, b, c, d := "true", "-12", "10", "3.14"
    a1, _ := strconv.ParseBool(a)
    b1, _ := strconv.ParseFloat(d, 64)    //指定转为64或32类型
    c1, _ := strconv.ParseInt(b, 10, 64)  //指定base:进制,basesize:64或43
    d1, _ := strconv.ParseUint(c, 10, 64)  //指定base:进制,basesize:64或43
    fmt.Println(reflect.TypeOf(a1), reflect.TypeOf(b1), reflect.TypeOf(c1), reflect.TypeOf(d1))
}

Format类函数 :将其他类型转换为string类型

  base: 转换为多少进制 basesize :64

  只能对int64 ,float64 ,uint64做转换 ,其中浮点转为字符串会格式化

package main

import (
    "fmt"
    "reflect"
    "strconv"
)

func main() {
    var (
        a bool    = true
        b int64   = -12
        c uint64  = 6
        d float64 = 3.14
    )
    a1 := strconv.FormatBool(a)
    b1 := strconv.FormatInt(b, 10)
    c1 := strconv.FormatUint(c, 10)
    d1 := strconv.FormatFloat(d, ‘E‘, -1, 64)
    fmt.Println(reflect.TypeOf(a1), reflect.TypeOf(b1), reflect.TypeOf(c1), reflect.TypeOf(d1), )
}

 9.变量

变量由字母数字下划线组成 ,开头不能是数字

声明变量:关键字var声明 ,快速声明 ,简短声明

package main

var StartNum int = 1970  //var声明
func main() {
    var (                //快速声明
        a string = "a"
        b string = "b"
    )
    c,d,e:= 1,2,3        //简短声明 (只能在函数中使用)
    //......
}

 10.零值

变量声明不赋值 ,此时等于该类型的零值

不同数据类型零值不同: bool(false) ,int(0) ,float(0.0) ,string("") ,剩下的slice ,array ,map ,function ,interface ,pointer..都是nil 

对于复合类型 ,go会对每个元素初始化为其零值

判断变量是否赋值 ,可以检查它是否等于该类型的零值!!!

11.常量

常量就是本次编译后无法在程序运行中改变的量

const StartTime int = 1970        #StartTime就是常量

12.变量的作用域

go中一个大括号 "{}" 就是一个块 ,在块内声明变量 ,该块内任意使用 (go的文件也是块 ,相当于声明全局变量)

对于嵌套块来说 ,内部块可以访问外部块变量 ,外部块无法访问内部块变量

13.指针

指针也是一种类型pointer ,用来存储变量内存地址

go语言中 ,如果直接赋值 ,或将变量传到函数 ,就会开辟内存复制副本 

指针可以指向原有变量访问 ,而无需复制副本 ,指针引用会修改源值 ,值引用不会

创建指针 : prt := &变量       #其中&可以获得变量的内存地址

使用指针 : *ptr         #获得指针指向的变量的值

package main

import "fmt"

func main() {
    a := []int{}
    a = append(a, 1, 2, 3, 4)
    ptra := &a                       #创建指针存储a的内存 
    vala := a                         #创建a的副本
    fmt.Printf("a内存地址为%p,ptra内存地址为%p,vala内存地址为%p", &a, &*ptra, &vala)
}

相关推荐