Go 语言控制台输入&生成随机数

1. 不同基础类型之间的转化
对于不同的基础类型之间的转化,Go 提供了 strconv包。它实现了字符串与其他基本数据类型之间的转化。
其中最常用的数值转化函数是Atoi和ltoa
Atoi 方法可以将字符串类型的数值直接转化为int类型的数值,而 ltoa 可以将 int 类型的数值转化为string类型的值。
示例:控制台输入一个数值,进行数据大小的比较

package main

import (
"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("数值较小")
}
}

  

2. Go 语言随机数

go语言中的随机数应该说是伪随机

math/rand 包实现了伪随机数生成器

在go语言中随机数需要设置种子,如果不设置种子,随机数每次运行的结果相同

默认种子是1,且相同种子产生的随机数是相同的

为了保证种子不是固定的,使用time这个包来调取当前时间,采用当前时间的纳秒作为种子来生成随机数

示例

package main

import (
"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)
}
} //执行结果如下
0
4
4
4
5
8
9
4
4
7

  

这里有二个,不能选错

//猜商品价格,商品高低,商品价格随机生成[0-300)
//如果你输入的价格大于商品价格则提示价格过高
//如果你输入的价格低于商品价格提示价格过低,直到猜中商品价格为止,并统计猜的次数 package main import (
"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 main import (
"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 次!

  

3. 高并发输入解析

大致流程如下

用户往程序控制台进行输入,当出现高并发读写的时候,所以的线程不一定能处理过来,这时候就把请求收纳到缓冲区中;
使用bufio.NewReader(os.Stdin)可以建立缓冲区,并把数据从控制台拿到缓冲区);
使用ReadLine()方式把数据从缓冲区拿到程序中,判断数据中的是否存在报错,有错误交给Err()处理并输出报错信息,而正确的字符串则提取出来给程序去使用。

示例:

package main

import (
"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)
} //终端输出结果如下
请输入内容:
hello
hello

  

示例 
使用Scan()相比于上面的方法,可以自定义报错信息,代码更简洁方便

package main

import (
"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
} //结果如下
请输入内容:
hello
hello

  

Go 语言控制台输入&生成随机数的更多相关文章

  1. Java语言中自动生成随机数

    参考原文:http://zhidao.baidu.com/link?url=nB3BT69wmUAiSPfKGgK5Q7HOFFP9AIE04AthreRd9yYcwKhUQsQRWlMdMhW1Qm ...

  2. 猜随机数(控制台输入,字符串转int)

    package com.hanqi.suijishu; import java .util.Random; // main方法类 专门用来运行方法 public class Main { public ...

  3. Android JNI编程(四)——C语言多级指针、数组取值、从控制台输入数组

    版权声明:本文出自阿钟的博客,转载请注明出处:http://blog.csdn.net/a_zhon/. 目录(?)[+] 一:前面我们介绍了一级指针的相关概念和用发,今天我们就来说一说多级指针. 1 ...

  4. 生成随机数(Random类)和获取用户输入(Scanner类)

    生成指定范围内的随机数 Math.random() 生成随机数,随机数在0到1之间,类型是 double. public class randCase { public static void mai ...

  5. C语言实现数据机构链表的基本操作(从键盘输入生成链表、读取数组生成链表)

    利用头插法实现逆置 下面简单介绍一下,算法思想结合图示看 算法思想:"删除"头结点与链表其他结点的原有联系(即将头结点的指针置空),再逐个插入逆置链表的表头(即"头插&q ...

  6. C语言实现顺序表的基本操作(从键盘输入 生成线性表,读txt文件生成线性表和数组生成线性表----三种写法)

    经过三天的时间终于把顺序表的操作实现搞定了.(主要是在测试部分停留了太长时间) 1. 线性表顺序存储的概念:指的是在内存中用一段地址连续的存储单元依次存储线性表中的元素. 2. 采用的实现方式:一段地 ...

  7. loadrunner生成随机数

    loadrunner生成随机数一: 对网站注册进行压力测试时,需要对注册的用户名进行参数化,因为可以会用到大量的测试数据,所以选择通过生成随机数来进行参数化.最开始用loadrunner自带的参数随机 ...

  8. 游戏2048源代码 - C语言控制台界面版

    一.游戏介绍 <2048>是最近比较流行的一款数字游戏.原版2048首先在github上发布,原作者是Gabriele Cirulli.它是基于<1024>和<小3传奇& ...

  9. Visual Studio 2017 - Windows应用程序打包成exe文件(2)- Advanced Installer 关于Newtonsoft.Json,LINQ to JSON的一个小demo mysql循环插入数据、生成随机数及CONCAT函数 .NET记录-获取外网IP以及判断该IP是属于网通还是电信 Guid的生成和数据修整(去除空格和小写字符)

    Visual Studio 2017 - Windows应用程序打包成exe文件(2)- Advanced Installer   Advanced Installer :Free for 30 da ...

随机推荐

  1. 了解Spark

    Apache Spark是一个开源的集群计算框架,主要用来处理实时生成的数据. Spark是建立在Hadoop的MapReduce顶部.它被优化到了内存中运行,而MapReduce等替代方法是将数据写 ...

  2. 如何写出优雅又地道的Python代码?【转载】

    在Python社区文化的浇灌下,演化出了一种独特的代码风格,去指导如何正确地使用Python,这就是常说的pythonic.一般说地道(idiomatic)的python代码,就是指这份代码很pyth ...

  3. Solution -「AGC 002F」「AT 2000」Leftmost Ball

    \(\mathcal{Description}\)   Link.   给你 \(n\) 种颜色的球,每个球有 \(k\) 个,把这 \(n\times k\) 个球排成一排,把每一种颜色的最左边出现 ...

  4. 使用SpringBoot整合MybatisPlus出现 : java.lang.IllegalStateException: Unable to find a @SpringBootConfiguration, you need to use @ContextConfiguration or @SpringBootTest(classes=...) with your test

    解决方案一: 将测试类的包路径改为和主启动类的一致 解决方法二: 不想改测试类的路径 就在测试类上添加要测试的类的classes

  5. 『无为则无心』Python面向对象 — 59、魔法方法

    目录 1.魔法方法__new__() 2.魔法方法__init__() 3.魔法方法__del__() 4.魔法方法__str__()和__repr__() 5.魔法方法__call__() 6.魔法 ...

  6. 【C# 线程】 延迟初始化

    1. 简介 1.延迟初始化出现于.NET 4.0,主要用于提高性能,避免浪费计算,并减少程序内存要求.也可以称为,按需加载. 2.从net 4.0开始,C#开始支持延迟初始化,通过Lazy关键字,我们 ...

  7. Hadoop权威指南 - 学习笔记

    初识Hadoop.关于MapReduce Hadoop宏观介绍 相对于其他系统的优势 关系型数据库管理系统 为什么不能用配有大量硬盘的数据库进行大规模分析?为什么需要Hadoop? 因为计算机硬盘的发 ...

  8. 解决gpg failed to sign the data fatal: failed to write commit object解决方案

    今天有位新同事在comit代码的时候一直报这个错误: gpg failed to sign the data fatal: failed to write commit object. 看到网上说gp ...

  9. 『无为则无心』Python日志 — 67、logging日志模块处理流程

    目录 1.概括理解 2.详细说明 3.应用示例 1.概括理解 了解了四大组件的基本定义之后,我们通过图示的方式来理解下信息的传递过程: 也就是获取的日志信息,进入到Logger日志器中,传递给处理器确 ...

  10. mapreduce类型对应

    public class OrderBean implements WritableComparable<OrderBean> { private Integer order_id; // ...