这是我参与「第三届青训营 -后端场」笔记创作活动的的第1篇笔记
Go的特性
-
高性能、高并发
-
丰富的标准库
-
完善工具链
-
静态链接
-
快速编译
-
跨平台
-
垃圾回收
三个样例
1 猜数游戏
func main() {
maxNum := 100
secretNumber := rand.Intn(maxNum)
fmt.Println("The secret number is ", secretNumber)
}
在未改进之前,发现每一次取得的“随机数”实际上值都是一样的,为了改进这一点需要加入种子
func main() {
maxNum := 100
//随机数种子,用时间戳
rand.Seed(time.Now().UnixNano())
secretNumber := rand.Intn(maxNum)
fmt.Println("The secret number is ", secretNumber)
}
用时间戳加入种子(以每次运行的当前时间),就可以实现目标数值每一次都是随机的了,接下来就可以加入逻辑代码
func main() {
maxNum := 100
rand.Seed(time.Now().UnixNano())
secretNumber := rand.Intn(maxNum)
// fmt.Println("The secret number is ", secretNumber)
fmt.Println("Please input your guess")
//reader := bufio.NewReader(os.Stdin)
for {
//input, err := reader.ReadString('\n')
//if err != nil {
// fmt.Println("An error occured while reading input. Please try again", err)
// continue
//}
//input = strings.TrimSuffix(input, "\r\n")
//
//guess, err := strconv.Atoi(input)
var guess int
_, err := fmt.Scanf("%d", &guess)
if err != nil {
fmt.Println("Invalid input. Please enter an integer value")
continue
}
fmt.Println("You guess is", guess)
if guess > secretNumber {
fmt.Println("Your guess is bigger than the secret number. Please try again")
} else if guess < secretNumber {
fmt.Println("Your guess is smaller than the secret number. Please try again")
} else {
fmt.Println("Correct, you Legend!")
break
}
}
}
利用for循环进行每一轮次的猜数,直到猜中目标数值为止;这里用Scanf进行读取,使代码更简洁。
2 在线词典
将curl转为go代码(curlconverter.com/#go)
将json格式转为go代码(oktools.net/json2go)
//请求结构体,用于转成json
type DictRequest struct {
TransType string `json:"trans_type"`
Source string `json:"source"`
UserID string `json:"user_id"`
}
//响应构造体
type DictResponse struct {
Rc int `json:"rc"`
Wiki struct {
KnownInLaguages int `json:"known_in_laguages"`
Description struct {
Source string `json:"source"`
Target interface{} `json:"target"`
} `json:"description"`
ID string `json:"id"`
Item struct {
Source string `json:"source"`
Target string `json:"target"`
} `json:"item"`
ImageURL string `json:"image_url"`
IsSubject string `json:"is_subject"`
Sitelink string `json:"sitelink"`
} `json:"wiki"`
Dictionary struct {
Prons struct {
EnUs string `json:"en-us"`
En string `json:"en"`
} `json:"prons"`
Explanations []string `json:"explanations"`
Synonym []string `json:"synonym"`
Antonym []string `json:"antonym"`
WqxExample [][]string `json:"wqx_example"`
Entry string `json:"entry"`
Type string `json:"type"`
Related []interface{} `json:"related"`
Source string `json:"source"`
} `json:"dictionary"`
}
json转换得到的响应体
func query(word string) {
client := &http.Client{}
//请求数据
request := DictRequest{TransType: "en2zh", Source: word}
//Json Marshal:将数据编码成json字符串
//转后得到的buf是[]byte类型
buf, err := json.Marshal(request)
if err != nil {
log.Fatal(err)
}
//字符数组转成字符串
var data = bytes.NewReader(buf)
req, err := http.NewRequest("POST", "https://api.interpreter.caiyunai.com/v1/dict", data)
if err != nil {
log.Fatal(err)
}
//请求头
req.Header.Set("Connection", "keep-alive")
req.Header.Set("DNT", "1")
req.Header.Set("os-version", "")
req.Header.Set("sec-ch-ua-mobile", "?0")
req.Header.Set("User-Agent", "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/99.0.4844.51 Safari/537.36")
req.Header.Set("app-name", "xy")
req.Header.Set("Content-Type", "application/json;charset=UTF-8")
req.Header.Set("Accept", "application/json, text/plain, */*")
req.Header.Set("device-id", "")
req.Header.Set("os-type", "web")
req.Header.Set("X-Authorization", "token:qgemv4jr1y38jyq6vhvi")
req.Header.Set("Origin", "https://fanyi.caiyunapp.com")
req.Header.Set("Sec-Fetch-Site", "cross-site")
req.Header.Set("Sec-Fetch-Mode", "cors")
req.Header.Set("Sec-Fetch-Dest", "empty")
req.Header.Set("Referer", "https://fanyi.caiyunapp.com/")
req.Header.Set("Accept-Language", "zh-CN,zh;q=0.9")
req.Header.Set("Cookie", "_ym_uid=16456948721020430059; _ym_d=1645694872")
//发起请求
resp, err := client.Do(req)
if err != nil {
log.Fatal(err)
}
//关闭流
defer resp.Body.Close()
//获取响应,把流读入内存
bodyText, err := ioutil.ReadAll(resp.Body)
if err != nil {
log.Fatal(err)
}
//HTTP响应状态码
if resp.StatusCode != 200 {
//如果不是200,打印状态码和返回的报文 方便调错
log.Fatal("bad StatusCode:", resp.StatusCode, "body", string(bodyText))
}
var dictResponse DictResponse
//把响应的json封装成DictResponse结构体
//Json Unmarshal:将json字符串解码到相应的数据结构
//第二个参数是接受json解析的数据结构,且第二个参数必须是指针,否则无法接受解析的数据
err = json.Unmarshal(bodyText, &dictResponse)
if err != nil {
log.Fatal(err)
}
//打印音标
fmt.Println(word, "UK:", dictResponse.Dictionary.Prons.En, "US:", dictResponse.Dictionary.Prons.EnUs)
//循环打印数组
for _, item := range dictResponse.Dictionary.Explanations {
fmt.Println(item)
}
}
func main() {
if len(os.Args) != 2 {
//如果后面没有接一个单词,打印错误并退出
fmt.Fprintf(os.Stderr, `usage: simpleDict WORD
example: simpleDict hello `)
os.Exit(1)
}
word := os.Args[1]
query(word)
}
业务代码,对单词进行查询,这里也学习了其他一些小伙伴添加了一些注释
可以在EDIT Configurations中为程序传参,如下图
或者在终端中输入
因为之前基本没有接触过go语言,所以在两个小时的基础讲解中起初感觉还是很吃力,对于给的三个样例也有很多地方看不懂、不理解。通过课下去查资料、去看相关的语法以及看其他小伙伴的分享也总算是搞明白了一点,感觉这一个月的学习会非常紧凑,需要我们自己去翻阅大量资料、文档来阅读,是一次非常好的学习机会也是一个不小的挑战,抓紧时间好好学习!