先说一下运算,运算符有:
* 算术运算符 * 关闭元算符 * 逻辑运算符 * 位运算符 * 赋值运算符 * 其他运算符
算术运算符
假如A值为10,B值为20
| 运算符 | 描述 | 实例 |
|---|---|---|
| + | 相加 | A + B 输出结果 30 |
| - | 相减 | A - B 输出结果 -10 |
| * | 相乘 | A * B 输出结果 200 |
| / | 相除 | B / A 输出结果 2 |
| % | 求余 | B % A 输出结果 0 |
| ++ | 自增 | A++ 输出结果 11 |
| -- | 自减 | A-- 输出结果 9 |
举例看一下
package main
//个人博客 http://www.wulaoer.org
import (
"fmt"
)
func main() {
var a int = 21 //定义变量a的值,为了养成一个好习惯,建议把类型也加上,方便以后处理
var b int = 10 //b也是一样的
var c int //申明变量c的类型
c = a + b
fmt.Println("计算a加b的和为c:",c) //运算符的加
c = a - b
fmt.Println("计算a减b的差为c:",c) //运算符的减
c = a * b
fmt.Println("计算a乘以b的积c为:",c) //运算符的乘
c = a / b
fmt.Println("计算a除以b的商c为:",c) //运算符的除
c = a % b
fmt.Println("计算a除以b的余为c:",c) //运算符求余
a++
fmt.Println("计算a的自增为",a) //运算符自增
a--
fmt.Println("a自减为",a) //运算符自减
}
打印结果:
计算a加b的和为c: 31 计算a减b的差为c: 11 计算a乘以b的积c为: 210 计算a除以b的商c为: 2 计算a除以b的余为c: 1 计算a的自增为 22 a自减为 21
关系运算符
假如A值为10,B值为20
| 运算符 | 描述 | 实例 |
|---|---|---|
| == | 检查两个值是否相等,如果相等返回True,否则返回False。 | (A == B)为False |
| != | 检查两个值是否不相等,如果不相等返回True,否则返回False。 | (A != B)为True |
| > | 检查左边值是否大于右边值,如果是返回 True 否则返回 False。 | (A > B) 为 False |
| < | 检查左边值是否小于右边值,如果是返回 True 否则返回 False。 | (A < B) 为 True |
| >= | 检查左边值是否大于等于右边值,如果是返回 True 否则返回 False。 | (A >= B) 为 False |
| <= | 检查左边值是否小于等于右边值,如果是返回 True 否则返回 False。 | (A <= B) 为 True |
因为举例的时候需要用到后面的判断,不过没关系,就当提前预习了,所以我们可以看一下例子
举例看一下:
package main
//关系原算符
//个人博客 http://www.wulaoer.org
import "fmt"
func main() {
var a int = 21
var b int = 10
if ( a == b) {
fmt.Println("判断a等于b的值==")
} else {
fmt.Println("a不等于b的值==")
}
if ( a != b) {
fmt.Println("a不等于b的值是!=")
} else {
fmt.Println("a等于b的值是!=")
}
if ( a > b ) {
fmt.Println("判断a大于b的值>")
} else {
fmt.Println("判断a不大于b的值>")
}
if ( a < b ) {
fmt.Println("a小于b的值<")
} else {
fmt.Println("a不小于b的值<")
}
if ( a >= b ) {
fmt.Println("a大于等于b的值>=")
} else {
fmt.Println("a不大于等于b的值>=")
}
if ( a <= b ) {
fmt.Println("a小于等于b的值<=")
} else {
fmt.Println("a不小于等于b的值")
}
}
打印结果:
a不等于b的值== a不等于b的值是!= 判断a大于b的值> a不小于b的值< a大于等于b的值>= a不小于等于b的值
逻辑运算符
假定A值为True,B值为False
| 运算符 | 描述 | 实例 |
|---|---|---|
| && | 逻辑 AND 运算符。 如果两边的操作数都是 True,则条件 True,否则为 False。 | (A && B) 为 False |
| || | 逻辑 OR 运算符。 如果两边的操作数有一个 True,则条件 True,否则为 False。 | (A || B) 为 True |
| ! | 逻辑 NOT 运算符。 如果条件为 True,则逻辑 NOT 条件 False,否则为 True。 | !(A && B) 为 True |
看下面的例子
package main
import "fmt"
//个人博客 http://www.wulaoer.org
func main() {
var a bool = true
var b bool = true
if ( a && b ) { //两者均为true,者为true,否为false
fmt.Println("逻辑a&&b的条件,两者均为true")
} else {
fmt.Println("逻辑a&&b的条件,其中有一个为false")
}
if ( a || b ) { //两者有一个为true,者为true,否为false
fmt.Println("逻辑a||b的条件,两者有一个为true")
} else {
fmt.Println("逻辑a||b的条件,两者都为false")
}
if ( !( a && b) ) { //如果条件为true,者逻辑NOT的条件为false
fmt.Println("逻辑a&&b的条件为false,!(a&&b)为true")
} else {
fmt.Println("逻辑a&&b的条件为true,!(a&&b)为false")
}
}
执行结果:
逻辑a&&b的条件,两者均为true 逻辑a||b的条件,两者有一个为true 逻辑a&&b的条件为true,!(a&&b)为false
位运算符
位运算符对整数在内存中的二进制进行操作。
| p | q | p&q | p|q | p^q |
|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 0 |
| 0 | 1 | 0 | 1 | 1 |
| 1 | 1 | 1 | 1 | 0 |
| 1 | 0 | 0 | 1 | 1 |
go支持的位运算如下:假定A为60,B为13
| 运算符 | 描述 | 实例 |
|---|---|---|
| & | 按位与运算符"&"是双目运算符。 其功能是参与运算的两数各对应的二进位相与。 | (A & B) 结果为 12, 二进制为 0000 1100 |
| | | 按位或运算符"|"是双目运算符。 其功能是参与运算的两数各对应的二进位相或 | (A | B) 结果为 61, 二进制为 0011 1101 |
| ^ | 按位异或运算符"^"是双目运算符。 其功能是参与运算的两数各对应的二进位相异或,当两对应的二进位相异时,结果为1。 | (A ^ B) 结果为 49, 二进制为 0011 0001 |
| << | 左移运算符"<<"是双目运算符。左移n位就是乘以2的n次方。 其功能把"<<"左边的运算数的各二进位全部左移若干位,由"<<"右边的数指定移动的位数,高位丢弃,低位补0。 | A << 2 结果为 240 ,二进制为 1111 0000 |
| >> | 右移运算符">>"是双目运算符。右移n位就是除以2的n次方。 其功能是把">>"左边的运算数的各二进位全部右移若干位,">>"右边的数指定移动的位数。 | A >> 2 结果为 15 ,二进制为 0000 1111 |
举个例子:
package main
import "fmt"
//个人博客 http://www.wulaoer.org
//位运算例子
func main() {
var a uint = 0
var b uint = 1
var c uint = 0
c = a & b //两位相与
fmt.Println("为运算&,c的值",c)
c = a | b //两位相或
fmt.Println("为运算|,c的值",c)
c = a ^ b //两位相异或
fmt.Println("为运算^,c的值",c)
}
执行结果:
为运算&,c的值 0 为运算|,c的值 1 为运算^,c的值 1
赋值运算符
| 运算符 | 描述 | 实例 |
|---|---|---|
| = | 简单的赋值运算符,将一个表达式的值赋给一个左值 | C = A + B 将 A + B 表达式结果赋值给 C |
| += | 相加后再赋值 | C += A 等于 C = C + A |
| -= | 相减后再赋值 | C -= A 等于 C = C - A |
| *= | 相乘后再赋值 | C *= A 等于 C = C * A |
| /= | 相除后再赋值 | C /= A 等于 C = C / A |
| %= | 求余后再赋值 | C %= A 等于 C = C % A |
| <<= | 左移后赋值 | C <<= 2 等于 C = C << 2 |
| >>= | 右移后赋值 | C >>= 2 等于 C = C >> 2 |
| &= | 按位与后赋值 | C &= 2 等于 C = C & 2 |
| ^= | 按位异或后赋值 | C ^= 2 等于 C = C ^ 2 |
| |= | 按位或后赋值 | C |= 2 等于 C = C | 2 |
举例看一下:
package main
import "fmt"
//个人博客 http://www.wulaoer.org
//赋值运算符
func main() {
var a int = 20
var c int
c = a
fmt.Println("把a的值赋值给c,为",c)
c += a
fmt.Println("c等于a加c的值",c)
c -= a
fmt.Println("c等于c减a的值",c)
c *= a
fmt.Println("c等于c乘以a的值",c)
c /= a
fmt.Println("c等于c除以a的值",c)
c %= a
fmt.Println("c等于c除以a的余数",c)
c = 200; //重新赋值c
c <<= 2
fmt.Println("c左移两位后的值赋值给c",c)
c >>= 2
fmt.Println("c右移两位后的值赋值给c",c)
c &= 2
fmt.Println("c按位与后的值赋值给c",c)
c ^= 2
fmt.Println("c按位异或后的值赋值给c",c)
c |= 2
fmt.Println("c按位或后的值赋值给c",c)
}
打印结果:
把a的值赋值给c,为 20 c等于a加c的值 40 c等于c减a的值 20 c等于c乘以a的值 400 c等于c除以a的值 20 c等于c除以a的余数 0 c左移两位后的值赋值给c 800 c右移两位后的值赋值给c 200 c按位与后的值赋值给c 0 c按位异或后的值赋值给c 2 c按位或后的值赋值给c 2
其他运算符
| 运算符 | 描述 | 实例 |
|---|---|---|
| & | 返回变量存储地址 | &a; 将给出变量的实际地址。 |
| * | 指针变量。 | *a; 是一个指针变量 |
举例说明一下:
package main
import "fmt"
//个人博客 http://www.wulaoer.org
//其他运算符
func main() {
var a int = 4
var b int32
var c float32
var ptr *int
fmt.Printf("变量a的数据类型为 = %T\n",a)
fmt.Printf("变量b的数据类型为 = %T\n",b)
fmt.Printf("变量c的数据类型为 = %T\n",c)
ptr = &a //ptr包含了a变量的内存地址
fmt.Printf("变量ptr的数据类型为 %d\n", ptr)
fmt.Printf("变量*ptr的数据类型为 %d\n", *ptr)
}
打印结果:
变量a的数据类型为 = int 变量b的数据类型为 = int32 变量c的数据类型为 = float32 变量ptr的数据类型为 824634327040 变量*ptr的数据类型为 4
运算符优先级
有些运算符拥有较高的优先级,二元运算符的运算方向均是从左至右。下表列出了所有运算符以及它们的优先级,由上至下代表优先级由高到低:
| 优先级 | 运算符 |
|---|---|
| 7 | ^ ! |
| 6 | * / % << >> & &^ |
| 5 | + - | ^ |
| 4 | == != < <= >= > |
| 3 | <- |
| 2 | && |
| 1 | || |
举例说明一下:
package main
//个人博客 http://www.wulaoer.org
import "fmt"
//运算优先级
func main() {
var a int = 20
var b int = 10
var c int = 15
var d int = 5
var e int;
e = (a + b) * c / d; // ( 30 * 15 ) / 5
fmt.Printf("(a + b) * c / d 的值为 : %d\n", e );
e = ((a + b) * c) / d; // (30 * 15 ) / 5
fmt.Printf("((a + b) * c) / d 的值为 : %d\n" , e );
e = (a + b) * (c / d); // (30) * (15/5)
fmt.Printf("(a + b) * (c / d) 的值为 : %d\n", e );
e = a + (b * c) / d; // 20 + (150/5)
fmt.Printf("a + (b * c) / d 的值为 : %d\n" , e );
}
打印结果:
(a + b) * c / d 的值为 : 90 ((a + b) * c) / d 的值为 : 90 (a + b) * (c / d) 的值为 : 90 a + (b * c) / d 的值为 : 50
这是golong的基础运算方法,可以参考一下。

您可以选择一种方式赞助本站
支付宝扫一扫赞助
微信钱包扫描赞助
赏