- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Go语言运算符案例讲解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
运算符 | 描述 | 实例 |
---|---|---|
+ | 相加 | A + B |
- | 相减 | A - B |
* | 相乘 | A * B |
/ | 相除 | B / A |
% | 求余 | B % A |
++ | 自增 | A++ |
– | 自减 | A– |
package mainimport "fmt"int main(){ var num1 int32 = 10 //var num2 int64 = num1 // 类型不同不能进行赋值运算 var num2 int64 = int64(num1) // 类型不同不能进行赋值运算 fmt.Println(num2) var num3 int32 = 10 var num4 int64 = 20 //var res int64 = num3 + num4 // 类型不同不能进行算数运算 var res1 int64 = int64(num3) + num4 // 类型不同不能进行算数运算 fmt.Println(res1) var num5 int32 = 10 var num6 int64 = 20 //var res2 bool = (num5 == num6) // 类型不同不能进行关系运算 var res2 bool = (num5 == int32(num6)) // 类型不同不能进行关系运算 fmt.Println(res2) // ... ... 其它以此类推}
package mainimport "fmt"func main() { num1 := 0 num1++ fmt.Println(num1) //++num1 // 编译报错, Go语言中++只能后置,不能前置 //fmt.Println(num1) //var num2 int = num1++ // 编译报错, num1++是语句不是表达式, 所以必须独占一行 //fmt.Println(num2)}
Go语言中字符串支持利用+号进行拼接 。
package mainimport "fmt"func main() { str := "abc" + "def" //fmt.Println(str)}
运算符 | 描述 | 实例 |
---|---|---|
== | 检查两个值是否相等,如果相等返回 True 否则返回 False。 | A == B |
!= | 检查两个值是否不相等,如果不相等返回 True 否则返回 False。 | A != B |
> | 检查左边值是否大于右边值,如果是返回 True 否则返回 False。 | A > B |
< | 检查左边值是否小于右边值,如果是返回 True 否则返回 False。 | A < B |
>= | 检查左边值是否大于等于右边值,如果是返回 True 否则返回 False。 | A >= B |
<= | 检查左边值是否小于等于右边值,如果是返回 True 否则返回 False。 | A <= B |
运算符 | 描述 | 实例 |
---|---|---|
&& | 如果两边的操作数都是 True,则条件 True,否则为 False。 | A && B |
\|\| | 如果两边的操作数有一个 True,则条件 True,否则为 False。 | A || B |
! | 如果条件为 True,则逻辑 NOT 条件 False,否则为 True。 | !A |
运算符描述实例&参与运算的两数各对应的二进位相与, 对应位只要都是1结果就为1A & B\|参与运算的两数各对应的二进位相或,对应位只要其中一个是1结果就为1A | B^参与运算的两数各对应的二进位相异或,对应位只要不同结果就是1A ^ B<<左移运算符,左移n位就是乘以2的n次方A << 2>>右移运算符,右移n位就是除以2的n次方B >> 2&^逻辑清零运算符, B对应位是1,A对应位清零,B对应位是0, A对应位保留原样A &^ B 。
int main(){ /* 0110 a &^1011 b 如果b位位1,那么结果为0, 否则结果为a位对应的值 ---------- 0100 */ a1 := 6 b1 := 11 res1 := a1 &^ b1 fmt.Println("res1 = ", res1) // 4 /* 1011 a &^1101 b 如果b位位1,那么结果为0, 否则结果为a位对应的值 ---------- 0010 */ a2 := 11 b2 := 13 res2 := a2 &^ b2 fmt.Println("res2 = ", res2) // 2}
运算符 | 描述 | 实例 |
---|---|---|
= | 将右边赋值给左边 | 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 |
&^= | 位逻辑清零赋值 | C &^= 2 等于 C = C &^ 2 |
运算符 | 描述 | 实例 |
---|---|---|
& | 返回变量存储地址 | &a; 将给出变量的实际地址 |
* | 访问指针指向内存 | *p; 访问指针p指向内存 |
1
2
3
4
5
6
7
8
9
10
11
12
|
package main
import "fmt"
int main(){
var num int = 666
var p *int = &num
fmt.Println(num)
fmt.Println(*p)
num = 777
fmt.Println(num)
*p = 999
fmt.Println(num)
}
|
1
2
3
4
5
6
7
8
9
10
|
#include <stdio.h>
int
main()
{
int
ages[3] = {19, 23, 22};
int
*arrayP = &ages[0];
printf
(
"ages[0] = %i\n"
, *(arrayP + 0));
// *(arrayP + 0) == *arrayP
printf
(
"ages[1] = %i\n"
, *(arrayP + 1));
printf
(
"ages[2] = %i\n"
, *(arrayP + 2));
return
0;
}
|
1
2
3
4
5
6
7
8
9
|
package main
import "fmt"
int main(){
var ages [3]int = [3]int{19, 23, 22}
var p *int = &ages[0]
//fmt.Println(&ages[0])
//fmt.Println(*p) // 19
fmt.Println(*(p + 0)) // 编译报错
}
|
到此这篇关于Go语言运算符案例讲解的文章就介绍到这了,更多相关Go语言运算符内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。
原文链接:https://blog.csdn.net/weixin_44617968/article/details/117655658https 。
最后此篇关于Go语言运算符案例讲解的文章就讲到这里了,如果你想了解更多关于Go语言运算符案例讲解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
1、流程控制语句主要有if、ii...else、elseif(有时也可以写成else if)、switch四种。 PHP中语句格式为: if(条件满足) {执行语句} if(条件满足) {执行
目录 DFS初步概念 DFS例题-迷宫游戏 题目描述 输入输出格式 输入输出样例
This question两年前被问到,但它提到的资源要么不是很有帮助(恕我直言),要么链接不再有效。 必须有一些很好的教程才能理解 Phaser .我已经阅读了 javadoc,但我的眼睛呆滞了,因
This question两年前被问到,但它提到的资源要么不是很有帮助(恕我直言),要么链接不再有效。 必须有一些很好的教程才能理解 Phaser .我已经阅读了 javadoc,但我的眼睛呆滞了,因
这个正则出自这个网站 http://www.regexlab.com/zh/regref.htm 正向预搜索:"(?=xxxxx)","(?!xxxxx)"
chr(9)、chr(10)、chr(13)、chr(32)、chr(34) 所有关于 ASCII码的表格:[url]http://www.asciitable.com/[/url] chr(13)
我是一名优秀的程序员,十分优秀!