百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 文章教程 > 正文

golang2021运算符与进制(10)位运算

xsobi 2024-11-23 10:51 24 浏览

Go语言位运算符

位运算符是对整数在内存中的二进制位进行操作。

?

位运算符比一般的算术运算符速度要快,而且可以实现一些算术运算符不能实现的功能。如果要开发高效率程序,位运算符是必不可少的。位运算符用来对二进制位进行操作,包括:按位与(&)、按位或(|)、按位异或(^)、按位左移(<<)、按位右移(>>)。

?

假定 A = 60,B = 13,其二进制数转换如下。

A = 0011 1100

B = 0000 1101

?

A&b = 0000 1100

A|B = 0011 1101

A^B = 0011 0001

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

表:位运算符

1、按位与

按位与(&):对两个数进行操作,然后返回一个新的数,这个数的每一位都需要两个输入数的同一位都为 1 时才为1。简单说就是,同一位同时为 1 则为 1,如下所示。

?

?

252&63









252

1

1

1

1

1

1

0

0

63

0

0

1

1

1

1

1

1

60

0

0

1

1

1

1

0

0

表:按位与

252 的二进制可以表示为 11111100,63 的二进制可以表示为 00111111,将每一位都进行与运算后结果为00111100,转换为十进制的结果为 60。

2、按位或

按位或(|):对两个数进行操作,然后返回一个新的数,这个数的每一位只要任意一个输入数的同一位为 1 则为1。简单说就是:同一位其中一个为 1 则为 1,如下所示。

?

?

178|94









178

1

0

1

1

0

0

1

0

94

0

1

0

1

1

1

1

0

254

1

1

1

1

1

1

1

0

表:按位或

178 的二进制可以表示为 10110010,94 的二进制可以表示为 01011110,将每一位都进行或运算后结果为11111110,转换为十进制的结果为 254。

3、按位异或

按位异或(^):对两个数进行操作,然后返回一个新的数,这个数的每一位只要两个输入数的同一位不同则为 1,如果相同就为0。简单说就是:同一位不相同则为 1,如下所示。

?

?

20^5









20

0

0

0

1

0

1

0

0

5

0

0

0

0

0

1

0

1

17

0

0

0

1

0

0

0

1

表:按位异或

20 的二进制可以表示为 00010100,5 的二进制可以表示为 00000101,将每一位都进行异或运算后结果为00010001,转换为十进制的结果为 17。

4、左移运算符

按二进制形式把所有的数字向左移动对应的位数,高位移出(舍弃),低位的空位补 0。

1) 语法格式

需要移位的数字 << 移位的次数

例如,3 << 4,则是将数字 3 左移 4 位。

2) 计算过程

3 << 4

首先把 3 转换为二进制数字 0000 0000 0000 0000 0000 0000 00000011,然后把该数字高位(左侧)的 4 个 0 移出,其他的数字都朝左平移 4 位,最后在低位(右侧)的 4 个空位补 0。则得到的最终结果是 00000000 0000 0000 0000 0000 0011 0000,转换为十进制是 48。

3) 数学意义

在数字没有溢出的前提下,对于正数和负数,左移 1 位都相当于乘以 2 的 1 次方,左移 n 位就相当于乘以 2 的 n次方,如下所示。

?

?

3<<4









3

0

0

0

0

0

0

1

1

3<<4

0

0

1

1

0

0

0

0

48

3x2?








表:左移运算

3 的二进制可以表示为 00000011,将每一位向左移动 4 位,高位移出(舍弃),低位的空位补 0,运算结果为00110000,转换为十进制的结果为 48。

5、右移运算符

按二进制形式把所有的数字向右移动对应的位数,低位移出(舍弃),高位的空位补符号位,即正数补 0,负数补 1。

1) 语法格式

需要移位的数字 >> 移位的次数

例如,11 >> 2,则是将数字 11 右移 2 位。

2) 计算过程

11 的二进制形式为:0000 0000 0000 0000 0000 0000 0000 1011,然后把低位的最后 2个数字移出,因为该数字是正数,所以在高位补 0。则得到的最终结果是 0000 0000 0000 0000 0000 0000 00000010。转换为十进制是 2。

3) 数学意义

右移 1 位相当于除以 2,右移 n 位相当于除以 2 的 n 次方,如下所示。

?

?

11>>2









11

0

0

0

0

1

0

1

1

11>>2

0

0

0

0

0

0

1

0

2

11÷22








表:右移运算

11 的二进制可以表示为 00001011,每一位向右移动 2 位,低位移出(舍弃),高位正数补 0,运算结果为00000010,转换为十进制的结果为 2。

?

位运算符的用法,如下所示。

?

  1. package ? ? main

  2. import "fmt"

  3. func main() {

  4. var a uint = 60

  5. var b uint = 13

  6. var c uint = 0

  7. c = a & b

  8. fmt.Printf("第一行 - c 的值为 ? ? %d \n", c)

  9. c = a | b

  10. fmt.Printf("第二行 - c 的值为 ? ? %d \n", c)

  11. c = a ^ b

  12. fmt.Printf("第三行 - c 的值为 ? ? %d \n", c)

  13. c = a << 2

  14. fmt.Printf("第四行 - c 的值为 ? ? %d \n", c)

  15. c = a >> 2

  16. fmt.Printf("第五行 - c 的值为 ? ? %d \n", c)

  17. }

运行结果如下:

第一行 - c 的值为 12

第二行 - c 的值为 61

第三行 - c 的值为 49

第四行 - c 的值为 240

第五行 - c 的值为 15



相关推荐

建站 | 从零开始打造自己的网站--以创意众筹网项目为例

文/跨界哥经过前几期的思考探索,跨界哥的创意众筹网项目的大概框架已经有了雏形,今天真正开始着手网站的建设。从零开始打造属于自己的网站,自己终于做了站长,想想还是有点小激动。简单描述下创意众筹网的核心业...

MyEclipse应用服务器教程:应用程序服务器入门指南(上)

1.定义一个新的服务器定义一个新的服务器允许您选择需要使用的服务器连接,并提供配置信息,然后选择项目部署到服务器上。(1)在服务器视图工具栏上点击new_server_icon。或者右键单击服务器视...

ABP异常为什么是403呢?

前言在ABP中使用UserFriendlyException抛出异常,HTTP状态码为什么是403?下面用这一段测试代码:[HttpPost]publicasyncTask<PeopleD...

Web自动化测试:模拟鼠标操作(ActionChains)

在日常的测试中,经常会遇到需要鼠标去操作的一些事情,比如说悬浮菜单、拖动验证码等,这一节我们来学习如何使用webdriver模拟鼠标的操作首页模拟鼠标的操作要首先引入ActionChains的包fro...

webapi 全流程

C#中的WebAPIMinimalApi没有控制器,普通api有控制器,MinimalApi是直达型,精简了很多中间代码,广泛适用于微服务架构MinimalApi一切都在组控制台应用程序类【Progr...

SpringBoot日志处理之Logback

日志处理是一个正式项目必备的功能,日志要能够根据时间、类型等要素,根据指定格式来保存指定的日志,方便我们观察程序运行情况、定位程序bug。SpringBoot中推荐使用Logback日志框架。slf4...

ASP.NET Core Web API 接口限流

一.前言ASP.NETCoreWebAPI接口限流、限制接口并发数量,我也不知道自己写的有没有问题,抛砖引玉、欢迎来喷!二.需求写了一个接口,参数可以传多个人员,也可以传单个人员,时间范围...

高德打车通用可编排订单状态机引擎设计

一背景订单状态流转是交易系统的最为核心的工作,订单系统往往都会存在状态多、链路长、逻辑复杂的特点,还存在多场景、多类型、多业务维度等业务特性。在保证订单状态流转稳定性的前提下、可扩展性和可维护性是我...

.Net6基础功能封装分享12(统一参数校验)

开发后台webapi接口,需要对接口传入的参数进行校验,如果传入的参数不符合验证规则,就直接返回参数错误,就需要封装统一参数校验过滤器;在.net6中,内置了DataAnnotations实现通过数据...

Path to prosperity for US and the world lies in cooperation, not confrontation

ThisisaneditorialfromChinaDaily.Turningadeafeartothe"handsoff"criesofprotestersnot...

C++ strategy策略模式

策略模式策略模式是一种行为设计模式,它定义了一组算法,他们可以以相同的接口共享。这种模式使用场景最多的就是在根据不同的条件选择不同的行为时,可以使用此模式进行解耦,使得你的代码更加易于维护和扩展,当然...

万字图文详解24种设计模式

一直想写一篇介绍设计模式的文章,让读者可以很快看完,而且一看就懂,看懂就会用,同时不会将各个模式搞混。自认为本文还是写得不错,花了不少心思来写这文章和做图,力求让读者真的能看着简单同时有所收获。设计模...

25000 字详解 23 种设计模式(多图 + 代码)

文章来源:https://javadoop.com/post/design-pattern目录创建型模式结构型模式行为型模式总结前言一直想写一篇介绍设计模式的文章,让读者可以很快看完,而且一看就懂,看...

C# 设计模式之-状态模式

问题引入仓库管理系统中,堆垛机任务的状态的变更,一般会引起一系列相关的的变更,如入库完成,就需要修改库位状态为:工作中;出库完成,则需要将任务对应的库位状态修改为:空闲;此时可以使用状态模式来将堆垛机...

seata-golang 接入指南

作者|刘晓敏来源|阿里巴巴云原生公众号seata-golang是一个分布式事务框架,实现了AT模式和TCC模式,AT模式相较TCC模式对代码的入侵性更小、需要开发的接口更少;但A...