【Go语言基础语法】

标识符与关键字

  go变量、常量、自定义类型、包、函数的命名方式必须遵循以下规则:

  1. 首字符可以是任意Unicode字符或下划线。
  2. 首字符之外的部分可以是Unicode字符、下划线或数字。
  3. 名字的长度无限制。

理论上名字里可以有汉字,甚至可以全是汉字,但实际中不要这么做。

Go语言关键字

break  default  func  interface  select  case  defer  go  map  struct  chan  else  goto  package  switch  const  if  range  type  continue  for  import  return  fallthrough  var

常量

true  false  iota  nil   

数据类型

int  int8  int16  int32  int64  uint  uint8  uint16  uint32  uint64  uintptr  float32  float64  complex128  complex64  bool  byte  rune  string  error

函数

make  len  cap  new  append  copy  close  delete  complex  real  imag  panic  recover

操作符与表达式

算法术运算符

运算符描述
+相加
-相减
*相乘
/相除
%求余
例子:
package main

import "fmt"

func compute() {
	var a float32 = 7
	var b float32 = 2
	var c float32 = a + b
	d := a - b
	e := a * b
	f := a / b
	fmt.Printf("a=%.3f, b=%.3f, c=%.3f, d=%0.3f, e=%.3f, f=%0.3f", a, b, c, d, e, f)

}
func main() {
	compute()
}

关系运算符

运算符描述
==检查两个值是否相等,如果相等返回 True 否则返回 False
!=检查两个值是否不相等,如果不相等返回 True 否则返回 False
>检查左边值是否大于右边值,如果是返回 True 否则返回 False
>=检查左边值是否大于等于右边值,如果是返回 True 否则返回 False
<检查左边值是否小于右边值,如果是返回 True 否则返回 False
<=检查左边值是否小于等于右边值,如果是返回 True 否则返回 False

例:

package main

import "fmt"

func test01() {
	a := 7
	b := 6
	c := 7
	fmt.Printf("a等于b,结果=%t\n", a == b)
	fmt.Printf("a大于等于b,结果=%t\n", a >= b)
	fmt.Printf("a等于c,结果=%t\n", a == c)
	fmt.Printf("a不等于b,结果=%t\n", a != b)
	fmt.Printf("a小于等于c,结果=%t\n", a <= b)
}
func main() {
	test01()
}

逻辑运算符

运算符描述
&逻辑 AND 运算符。 如果两边的操作数都是 True,则为 True,否则为 False
||逻辑 OR 运算符。 如果两边的操作数有一个 True,则为 True,否则为 False
!逻辑 NOT 运算符。 如果条件为 True,则为 False,否则为 True

例:

package main

import "fmt"

func test01() {
	a := 7
	b := 6
	c := 7
	fmt.Printf("a等于b结果不成立,结果=%t\n", !(a == b))
	fmt.Printf("a大于b,或者a小于b,结果=%t\n", (a > b) || (a < b))
	fmt.Printf("a等于c与a小于b结果=%t\n", (a == c) && (a < b))
}
func main() {
	test01()
}

变量、常量、字面量

变量类型

类型go变量类型fmt输出
整型int int8 int16 int32 int64 uint uint8 uint16 uint32 uint64%d
浮点型float32 float64%f %e %g
布尔型bool%t
指针uintptr%p
引用map slice channel%v
字节byte%c
任意字符rune%c
字符串string%s
错误error%v

变量声明

 Go语言变量必须先声明再使用,所谓使用指读取或修改。
标题声明

var str string 
var number int 
var isOk bool

批量声明

var ( 
	str string 
	number int 
	isOk bool 
)

变量初始化
 如果声明后未显式初始化,数值型初始化0,字符串初始化为空字符串,布尔型初始化为false,引用类型、函数、指针、接口初始化为nil。

var a string="liang"  
var a="liang"  
var a,b int=2,4  
var a,b="liang",7

  函数内部的变量(非全局变量)可以通过:=声明并初始化。

a:=3

  下划线表示匿名变量。匿名变量不占命名空间,不会分配内存,因此可以重复使用。

_=2+4

常量

  常量在定义时必须赋值,且程序运行期间其值不能改变。

const PI float32=3.14

const(
    PI=3.14
    E=2.71
)

const(
    a=100
    b	//100,跟上一行的值相同
    c	//100,跟上一行的值相同
)

iota

const(
    a=iota	//0
    b		//1
    c		//2
    d		//3
)

const(
    a=iota 	//0
    b		//1
    _		//2
    d		//3
)

const(
    a=iota 	//0
    b=30    
    c=iota 	//2
    d		//3
)

变量作用域

  对于全局变量,如果以大写字母开头,所有地方都可以访问,跨package访问时需要带上package名称;如果以小写字母开头,则本package内都可以访问。
  函数内部的局部变量,仅本函数内可以访问。{}可以固定一个作用域。内部声明的变量可以跟外部声明的变量有冲突,以内部的为准–就近原则。

var (
    A=1	//所有地方都可以访问
    b=2	//本package内可以访问
)

func foo(){
    b:=3  //本函数内可以访问
    {
        b:=4  //本作用域内可以访问
    }
}

注释与godoc

注释的形式

  • 单行注释,以//打头。
  • 多行注释有2种形式:
    1. 连续多行以//打头,注意多行注释之间不能出现空行。
    2. 在段前使用/*,段尾使用*/。
  • 注释行前加缩进即可写go代码。
  • 注释中给定的关键词。NOTE: 引人注意,TODO: 将来需要优化,Deprecated: 变量或函数强烈建议不要再使用。
package main

import "fmt"

//NOTE:测试NOTE注释
func test01() {
	fmt.Println("测试NOTEz注释")
}

//TODO:测试TODO注释
func test02() {
	fmt.Println("测试TODO注释")
}

//Deprecated:测试TODO注释
func test03() {
	fmt.Println("测试Deprecated注释")
}
func main() {
	test01()
	test02()
	test03()
}

注释的位置

  针对行的注释在行上方或右侧。函数的上方在func xxx()上方。结构体的注释在type xxx struct上方。包注释在package xxx的上方。一个包只需要在一个地方写包注释,通常会专门写一个doc.go,里面只有一行package xxx和关于包的注释。

// FormatBool, FormatFloat, FormatInt, and FormatUint convert values to strings:
//
//	s := strconv.FormatBool(true)
//	s := strconv.FormatFloat(3.1415, 'E', -1, 64)
//	s := strconv.FormatInt(-42, 16)
//	s := strconv.FormatUint(42, 16)
package fmt

go doc

  go doc是go自带的命令。

go doc entrance_class/util

上述命令查看entrance_class/util包的注释。

godoc

  godoc是第三方工具,可以为项目代码导出网页版的注释文档。安装godoc命令如下

go get -u golang.org/x/tools/cmd/godoc
go install golang.org/x/tools/cmd/godoc@latest

启动http服务:

godoc -http=:6060

用浏览器访问http://127.0.0.1:6060 ,可以查看go标准库的文档。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值