热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Go开发基础入门——1

请关注我的个人博客Go开发入门变量的定义,赋值变量声明:Go的变量名首字母不能为数字未初始化的变量声明:var变量名变量类型varaint声明int类型的变量varb






请关注我的个人博客


Go开发入门


变量的定义,赋值


变量声明:Go的变量名首字母不能为数字


  • 未初始化的变量声明:

    var 变量名 变量类型
    var a int // 声明 int 类型的变量
    var b [10] int // 声明 int 类型数组
    var c []int // 声明 int 类型的切片 [] 内赋初值是数组,不赋值是切片
    var d *int // 声明 int 类型的指针
    打印结果为
    //a={0},b={[0 0 0 0 0 0 0 0 0 0]},c={[]},d={}
    那么未初始化的变量默认值为:
    整型和浮点型变量: 0
    字符串: 0
    布尔: false
    函数,指针: nil


  • 初始化的变量声明:

    var 变量名 变量类型 = 表达式
    var a int = 10
    //编译器自动推断格式
    var 变量名 = 表达式
    //简短声明格式(短变量声明格式)
    变量名 := 表达式
    := 可以高效的创建新变量,在内存中开辟空间
    var 省略
    编译器自动推断类型
    声明变量首选这种形式
    只能用在函数体内,不能作为全局变量来声明
    变量名不能是被定义过的,不然会报错


  • 变量多重赋值

go可以进行多变量赋值,变量与变量之间逗号隔开
a, b, c, d := 1, 2, true, "def"
fmt.Printf("a={%d},b={%d},c={%v},d={%v} \n", a, b, c, d)
a, b = b, a // a,b互换位置

  • 匿名变量

    主要用于函数返回值,返回我们需要的字段



数据类型


  • 布尔型

    布尔型的值只可以是常量 true 或者 false。一个简单的例子:var b bool = true。

  • 数字类型

    整型 int 和浮点型 float32、float64,Go 语言支持整型和浮点型数字,并且支持复数,其中位的运算采用补码。

  • 字符串类型:

    字符串就是一串固定长度的字符连接起来的字符序列。Go 的字符串是由单个字节连接起来的。Go 语言的字符串的字节使用 UTF-8 编码标识 Unicode 文本。

  • 派生类型:

    包括:
    (a) 指针类型(Pointer)
    (b) 数组类型
    (c) 结构化类型(struct)
    (d) Channel 类型
    (e) 函数类型
    (f) 切片类型
    (g) 接口类型(interface)
    (h) Map 类型


更详细的可以参考这篇博文,写的非常详细


格式化输出语句


  • 通用

    %v value,值的默认表示
    %+v 类似%v,但输出结构体时会添加字段名
    %#v 值的 Go 语法表示
    %T 值的数据类型Go语法表示,如: int , string等


  • 布尔

    %t true或false


  • 整数

    %b 二进制表示
    %c 相应Unicode码点所表示的字符
    %d 十进制表示
    %8d 整形长度为8,不足8则在数值前补空格 超出以实际为准
    %08d 数字长度是8,不足8位的,数字前补0 超出以实际为准
    %o 八进制表示
    %q 单引号围绕的字符字面值,由Go语法安全地转义
    %x 十六进制表示,字母形式为小写 a-f
    %X 十六进制表示,字母形式为大写 A-F
    %U Unicode格式:U+1234,等同于 "U+%04X"


  • 浮点,复数

    %b 无小数部分的,指数为二的幂的科学计数法,与 strconv.FormatFloat中的 'b' 转换格式一致。例如 -123456p-78
    %e 科学计数法,例如 -1234.456e+78
    %E 科学计数法,例如 -1234.456E+78
    %f 有小数点而无指数,例如 123.456
    %g 根据情况选择 %e 或 %f 以产生更紧凑的(无末尾的0)输出
    %G 根据情况选择 %E 或 %f 以产生更紧凑的(无末尾的0)输出


  • 字符串和bytes的slice表示:

    %q 双引号围绕的字符串,由Go语法安全地转义
    %x 十六进制,小写字母,每字节两个字符
    %X 十六进制,大写字母,每字节两个字符


  • 指针:

    %p 十六进制表示,前缀 0x
    这里没有 'u' 标记。若整数为无符号类型,他们就会被打印成无符号的。类似地,这里也不需要指定操作数的大小(int8,int64)。
    对于%v来说默认的格式是:
    bool: %t
    int, int8 etc.: %d
    uint, uint8 etc.: %d, %x if printed with %#v
    float32, complex64, etc: %g
    string: %s
    chan: %p
    pointer: %p
    由此可以看出,默认的输出格式可以使用%v进行指定,除非输出其他与默认不同的格式,否则都可以使用%v进行替代(但是不推荐使用)


  • 对于复合对象:

    里面的元素使用如下规则进行打印:
    struct: {field0 field1 ...}
    array, slice: [elem0 elem1 ...]
    maps: map[key1:value1 key2:value2]
    pointer to above: &{}, &[], &map[]


  • 宽度和精度:

    宽度是在%之后的值,如果没有指定,则使用该值的默认值,精度是跟在宽度之后的值,如果没有指定,也是使用要打印的值的默认精度.例如:%9.2f,宽度9,精度2
    %f: default width, default precision
    %9f width 9, default precision
    %.2f default width, precision 2
    %9.2f width 9, precision 2
    %9.f width 9, precision 0


这里有一些练习


弟弟从事java开发,学习go纯属个人爱好,喜欢go的语法和特点,点击这里移步我的个人博客





推荐阅读
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • LeetCode笔记:剑指Offer 41. 数据流中的中位数(Java、堆、优先队列、知识点)
    本文介绍了LeetCode剑指Offer 41题的解题思路和代码实现,主要涉及了Java中的优先队列和堆排序的知识点。优先队列是Queue接口的实现,可以对其中的元素进行排序,采用小顶堆的方式进行排序。本文还介绍了Java中queue的offer、poll、add、remove、element、peek等方法的区别和用法。 ... [详细]
  • 本文介绍了Java高并发程序设计中线程安全的概念与synchronized关键字的使用。通过一个计数器的例子,演示了多线程同时对变量进行累加操作时可能出现的问题。最终值会小于预期的原因是因为两个线程同时对变量进行写入时,其中一个线程的结果会覆盖另一个线程的结果。为了解决这个问题,可以使用synchronized关键字来保证线程安全。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • 本文介绍了一个Java猜拳小游戏的代码,通过使用Scanner类获取用户输入的拳的数字,并随机生成计算机的拳,然后判断胜负。该游戏可以选择剪刀、石头、布三种拳,通过比较两者的拳来决定胜负。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • Java String与StringBuffer的区别及其应用场景
    本文主要介绍了Java中String和StringBuffer的区别,String是不可变的,而StringBuffer是可变的。StringBuffer在进行字符串处理时不生成新的对象,内存使用上要优于String类。因此,在需要频繁对字符串进行修改的情况下,使用StringBuffer更加适合。同时,文章还介绍了String和StringBuffer的应用场景。 ... [详细]
  • 判断数组是否全为0_连续子数组的最大和的解题思路及代码方法一_动态规划
    本文介绍了判断数组是否全为0以及求解连续子数组的最大和的解题思路及代码方法一,即动态规划。通过动态规划的方法,可以找出连续子数组的最大和,具体思路是尽量选择正数的部分,遇到负数则不选择进去,遇到正数则保留并继续考察。本文给出了状态定义和状态转移方程,并提供了具体的代码实现。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • Android JSON基础,音视频开发进阶指南目录
    Array里面的对象数据是有序的,json字符串最外层是方括号的,方括号:[]解析jsonArray代码try{json字符串最外层是 ... [详细]
author-avatar
集束群
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有