1. 不同基础类型之间的转化
对于不同的基础类型之间的转化,Go 提供了 strconv包。它实现了字符串与其他基本数据类型之间的转化。
其中最常用的数值转化函数是Atoi和ltoa
Atoi 方法可以将字符串类型的数值直接转化为int类型的数值,而 ltoa 可以将 int 类型的数值转化为string类型的值。
示例:控制台输入一个数值,进行数据大小的比较
package mainimport ( "fmt" "strconv")func main() { var number string fmt.Println("请输入一个整数:") //控制台输入,&指定一个地址 fmt.Scan(&number) fmt.Println("数值是: ", number) fmt.Printf("数据类型是:%T", number) //数据类型转换string——》int //空白标识符接受err数值 value, _ := strconv.Atoi(number) //数值判断 fmt.Printf("转换后的数据类型是: %T\n", value) if value > 100 { fmt.Println("数值较大") } else { fmt.Println("数值较小") }}



go语言中的随机数应该说是伪随机
math/rand 包实现了伪随机数生成器
在go语言中随机数需要设置种子,如果不设置种子,随机数每次运行的结果相同
默认种子是1,且相同种子产生的随机数是相同的
为了保证种子不是固定的,使用time这个包来调取当前时间,采用当前时间的纳秒作为种子来生成随机数
示例
package mainimport ( "fmt" "math/rand" "time")func main() { rand.Seed(time.Now().Unix()) for i := 0; i < 10; i++ { value := rand.Intn(10)//Intn(10) 左闭右开区间 [0,10) fmt.Println(value) }}//执行结果如下0444589447
这里有二个,不能选错

//猜商品价格,商品高低,商品价格随机生成[0-300)//如果你输入的价格大于商品价格则提示价格过高//如果你输入的价格低于商品价格提示价格过低,直到猜中商品价格为止,并统计猜的次数package mainimport ( "fmt" "math/rand" "time")func main() { var ( price int count int ) rand.Seed(time.Now().Unix()) real_price := rand.Intn(300) for { fmt.Println("请输入价格:") fmt.Scan(&price) switch { case price == real_price: count++ fmt.Println("恭喜你猜对价格,价格为:", real_price) goto TAG case price > real_price: count++ fmt.Println("价格过高,请重新输入!") continue default: count++ fmt.Println("价格过低,请重新输入!") continue } }TAG: fmt.Println("总共猜的次数为:", count)}//终端交互结果如下PS D:\goproject\src\dev_code\test01\example4\main> go run .\main.go请输入价格:100价格过低,请重新输入!请输入价格:200价格过低,请重新输入!请输入价格:280价格过高,请重新输入!请输入价格:270价格过高,请重新输入!请输入价格:260价格过高,请重新输入!请输入价格:250价格过高,请重新输入!请输入价格:240价格过低,请重新输入!请输入价格:245价格过高,请重新输入!请输入价格:243价格过高,请重新输入!请输入价格:242恭喜你猜对价格,价格为: 242总共猜的次数为: 10---------------------------------------------------------------------------------------------//方法二package mainimport ( "fmt" "math/rand" "time")func main() { var ( price int count int ) rand.Seed(time.Now().Unix()) real_price := rand.Intn(300) for { fmt.Println("请输入价格:") fmt.Scan(&price) if price == real_price { count++ fmt.Println("恭喜猜对价格!商品的价格为:", real_price) break } if price > real_price { count++ fmt.Println("价格过高,请重新输入!") } else { count++ fmt.Println("价格过低,请重新输入!") continue } } fmt.Println("总共猜了:", count, "次!")}//输出结果请输入价格:100价格过低,请重新输入!请输入价格:500价格过高,请重新输入!请输入价格:400价格过高,请重新输入!请输入价格:300价格过高,请重新输入!请输入价格:200价格过高,请重新输入!请输入价格:150价格过高,请重新输入!请输入价格:140价格过高,请重新输入!请输入价格:130价格过高,请重新输入!请输入价格:122价格过低,请重新输入!请输入价格:126价格过低,请重新输入!请输入价格:128恭喜猜对价格!商品的价格为: 128总共猜了: 11 次!
大致流程如下
用户往程序控制台进行输入,当出现高并发读写的时候,所以的线程不一定能处理过来,这时候就把请求收纳到缓冲区中;
使用bufio.NewReader(os.Stdin)可以建立缓冲区,并把数据从控制台拿到缓冲区);
使用ReadLine()方式把数据从缓冲区拿到程序中,判断数据中的是否存在报错,有错误交给Err()处理并输出报错信息,而正确的字符串则提取出来给程序去使用。
示例:
package mainimport ( "bufio" "fmt" "os")func main() { fmt.Println("请输入内容:") str1 := getInput() fmt.Println(str1)}//缓冲区控制台写入func getInput() string { //bufio 缓冲区从控制台中读取输入的信息,缓冲区名为in in := bufio.NewReader(os.Stdin) //从缓冲区读取字符串信息 str, _, err := in.ReadLine() if err != nil { return err.Error() } return string(str)}//终端输出结果如下请输入内容:hellohello
示例
使用Scan()相比于上面的方法,可以自定义报错信息,代码更简洁方便
package mainimport ( "bufio" "fmt" "os")func main() { fmt.Println("请输入内容:") str1 := getInputByScanner() fmt.Println(str1)}func getInputByScanner() string { var str string //使用os.Stdin开始输入流 in := bufio.NewScanner(os.Stdin) if in.Scan() { str = in.Text() } else { str = "Find input error" } return str}//结果如下请输入内容:hellohello