• 如何在Go中使用操作符进行数学运算


    引言

    数字在编程中很常见。它们用于表示诸如:屏幕尺寸、地理位置、金钱和点数、视频中经过的时间、游戏角色的位置、分配数字代码的颜色等等。

    在编程中有效地执行数学运算是一项需要开发的重要技能,因为你经常会用到数字。虽然对数学的深入理解肯定可以帮助你成为更好的程序员,但这不是先决条件。如果你没有数学背景,试着把数学看作是一种工具来完成你想要达到的目标,是一种提高你逻辑思维的方法。

    我们将使用Go中最常用的两种数字[数据类型]整数浮点数:

    • [Integers]是整数,可以是积极的,消极的,或0(…,-101,…)。
    • [Floats]是包含小数点的实数,例如9.0-2.25

    本教程将回顾Go中可用于数字数据类型的运算符。

    运算符

    运算符是一个表示操作的符号或函数。例如,在数学中,加号或’ + '是表示加法的运算符。

    在Go中,我们将看到一些从数学中引入的熟悉的操作符。不过,我们将使用的其他操作符是计算机编程特有的。

    下面是Go中数学相关运算符的快速参考表。我们将在本教程中介绍以下所有操作。

    运算符返回什么
    x + yx与y的和
    x - yx和y的差值
    -x改变x的符号
    +xx的恒等式
    x * yx和y的乘积
    x / yx和y的商
    x % yx / y的余数

    我们还将介绍复合赋值运算符,包括+=*=,它们将算术运算符与=运算符结合在一起。

    加法和减法

    在Go中,加法和减法运算符的表现与数学中的一样。事实上,您可以将Go编程语言用作计算器。

    让我们看一些例子,从整数开始:

    fmt.Println(1 + 5)
    
    • 1
    Output6
    
    • 1

    除了直接将整数传递给fmt.Println语句之外,我们可以使用如下语法初始化变量以表示整数值:

    a := 88
    b := 103
    
    fmt.Println(a + b)
    
    • 1
    • 2
    • 3
    • 4
    Output191
    
    • 1

    因为整数既可以是正数,也可以是负数(0也是),所以可以将负数和正数相加:

    c := -36
    d := 25
    
    fmt.Println(c + d)
    
    • 1
    • 2
    • 3
    • 4
    Output-11
    
    • 1

    浮点数的加法操作类似:

    e := 5.5
    f := 2.5
    
    fmt.Println(e + f)
    
    • 1
    • 2
    • 3
    • 4
    Output8
    
    • 1

    因为我们将两个浮点数相加,所以Go返回了一个带小数点的浮点值。然而,由于在本例中小数点是零,fmt.Println删除了小数格式。为了正确格式化输出,我们可以使用fmt.Printf和动词%.2f,它将格式化为两位小数,如下例所示:

    fmt.Printf("%.2f", e + f)
    
    • 1
    Output8.00
    
    • 1

    减法的语法与加法相同,只是要把运算符从加号(+)改为减号(-):

    g := 75.67
    h := 32.0
    
    fmt.Println(g - h)
    
    • 1
    • 2
    • 3
    • 4
    Output43.67
    
    • 1

    在Go中,我们只能在相同的数据类型上使用操作符。我们不能将intfloat64相加

    i := 7
    j := 7.0
    fmt.Println(i + j)
    
    • 1
    • 2
    • 3
    Outputi + j (mismatched types int and float64)
    
    • 1

    试图在不相同的数据类型上使用运算符将导致编译器错误。

    一元数学表达式

    一元数学表达式只包含一个成分或元素。在Go中,我们可以使用加号和减号作为单个元素与值配对:返回值的单位符号(+),或更改值的符号(-)。

    虽然加号不常用,但它表示值的身份。我们可以使用加号来表示正数:

    i := 3.3
    fmt.Println(+i)
    
    • 1
    • 2
    Output3.3
    
    • 1

    当我们用加号表示一个负数时,它也会返回该值的标识符,在这个例子中,它会返回一个负数:

    j := -19
    fmt.Println(+j)
    
    • 1
    • 2
    Output-19
    
    • 1

    对于负数,加号返回相同的负数。

    然而,减号会改变值的正负号。因此,当我们传入一个正值时,我们会发现值之前的减号将返回负值:

    k := 3.3
    fmt.Println(-k)
    
    • 1
    • 2
    Output-3.3
    
    • 1

    或者,当使用减号操作符处理负数时,将返回一个正数:

    j := -19
    fmt.Println(-j)
    
    • 1
    • 2
    Output19
    
    • 1

    由加号和减号表示的一元算术运算将返回值的恒等符号(如+i),或相反的符号(如-i)。

    乘法和除法

    就像加法和减法一样,乘法和除法看起来很像数学中的运算。我们将在Go中用于乘法的符号是*,用于除法的符号是/

    下面是用两个浮点数在Go中做乘法的例子:

    k := 100.2
    l := 10.2
    
    fmt.Println(k * l)
    
    • 1
    • 2
    • 3
    • 4
    Output1022.04
    
    • 1

    在Go中,根据我们除法的数值类型,除法具有不同的特征。

    如果我们要除以整数,Go的/运算符会执行整除操作,对于商x,返回的是小于或等于x的最大整数。

    如果你运行以下除以80 / 6的例子,你将得到13作为输出,数据类型将是int:

    package main
    
    import (
    	"fmt"
    )
    
    func main() {
    	m := 80
    	n := 6
    
    	fmt.Println(m / n)
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    Output13
    
    • 1

    如果期望的输出是浮点数,则必须在除法之前显式转换值。

    你可以通过在你的值周围包装你想要的浮点类型float32()float64()来实现:

    package main
    
    import (
    	"fmt"
    )
    
    func main() {
    	s := 80
    	t := 6
    	r := float64(s) / float64(t)
    	fmt.Println(r)
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    Output13.333333333333334
    
    • 1

    %操作符是,它返回除法后的余数而不是商。这对于查找是同一个数的倍数的数很有用。

    来看一个求模的例子:

    o := 85
    p := 15
    
    fmt.Println(o % p)
    
    • 1
    • 2
    • 3
    • 4
    Output10
    
    • 1

    具体来说,85除以15返回的是5的商余数10。我们的程序在这里返回值10,因为求模运算符返回除法表达式的余数。

    要对float64数据类型进行模运算,你将使用math包中的Mod函数:

    package main
    
    import (
    	"fmt"
    	"math"
    )
    
    func main() {
    	q := 36.0
    	r := 8.0
    
    	s := math.Mod(q, r)
    
    	fmt.Println(s)
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    Output4
    
    • 1

    运算符优先级

    在Go中,就像在数学中一样,我们需要记住,运算符将按优先级顺序进行计算,而不是从左到右或从右到左。

    看看下面的数学表达式:

    u = 10 + 10 * 5
    
    • 1

    我们可以从左到右读取它,但乘法将首先执行,因此如果我们打印u,我们将收到以下值:

    Output60
    
    • 1

    这是因为10 * 5的计算结果是50,然后我们加上10来返回60作为最终结果。

    如果我们想将值10加到10,然后乘以5,我们在Go中使用括号,就像我们在数学中使用的那样:

    u := (10 + 10) * 5
    fmt.Println(u)
    
    • 1
    • 2
    Output100
    
    • 1

    记住运算顺序的一种方法是使用缩写PEMDAS:

    优先级标志代表
    1P括号
    2E指数
    3M乘法
    4D除法
    5A加法
    6S减法

    你可能熟悉另一个表示操作顺序的缩写,例如BEDMASBODMAS。无论哪种首字母缩写最适合您,在Go中执行数学操作时请尽量记住它,以便返回您期望的结果。

    赋值操作符

    最常见的赋值运算符已经用过:等号=。赋值运算符=将右边的值赋给左边的变量。例如,v = 23将整数23的值赋给变量v

    编程时,通常使用复合赋值操作符,对变量的值进行操作,然后将得到的新值赋给该变量。这些复合操作符结合了算术操作符和=操作符。因此,对于加法运算,我们将+=结合起来得到复合运算符+=。让我们看看它是什么样子:

    w := 5
    w += 1
    fmt.Println(w)
    
    • 1
    • 2
    • 3
    Output6
    
    • 1

    首先,我们将变量w的值设置为5,然后使用+=复合赋值操作符将右值与左值相加,然后将结果赋值给w

    复合赋值运算符经常用于for循环的情况,当你想多次重复一个过程时,你会使用它:

    package main
    
    import "fmt"
    
    func main() {
    
    	values := []int{0, 1, 2, 3, 4, 5, 6}
    
    	for _, x := range values {
    
    		w := x
    
    		w *= 2
    
    		fmt.Println(w)
    	}
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    Output0
    2
    4
    6
    8
    10
    12
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    通过使用for循环来迭代名为values的切片,你能够自动化*=操作符的处理,该操作符将变量w乘以数字2,然后将结果赋值给变量w

    对于本教程中讨论的每个算术运算符,Go都有一个复合赋值运算符。

    添加后再赋值:

    y += 1
    
    • 1

    减去后再赋值:

    y -= 1
    
    • 1

    相乘再赋值:

    y *= 2
    
    • 1

    相除再赋值:

    y /= 3
    
    • 1

    要返回余数,然后再赋值:

    y %= 3
    
    • 1

    当需要递增或递减操作时,或者需要自动化程序中的某些过程时,复合赋值操作符可能很有用。

    总结

    本教程介绍了许多用于整数和浮点数数据类型的运算符。

  • 相关阅读:
    UI Toolkit 计时器
    剑指 Offer II 034. 外星语言是否排序
    使用Linux下的“信号“实现一些简单功能
    【华为机试真题 JAVA】水仙花数 Ⅰ-100
    高数_第3章_重积分_习题
    深入理解虚拟/物理地址转换,页表--基于ARMV8
    根据店铺ID/店铺链接/店铺昵称获取京东店铺所有商品数据接口|京东店铺所有商品数据接口|京东API接口
    PHPStorm PHP-CS-Fixer
    Go语言的sync.Once()函数
    Java面试题03
  • 原文地址:https://blog.csdn.net/QIU176161650/article/details/133672895