go语言-二进制与位运算
一、进制介绍
1、二进制:0,1 -->不能直接用二进制来表示一个整数,用%b输出二进制
package main
import "fmt"
func main() {
var i int =5
fmt.Printf("%b",i) //--->>显示5的二进制数
2、十进制:0-9 3、八进制:0-7 -->>以数字0开头表示
package main
import "fmt"
func main() {
var a int = 011
fmt.Println("a=",a)
4、十六进制:0-9 A-F(字母不区分大小写),以0x开头表示,字母不区分大小写
package main
import "fmt"
func main() {
var j =0x11
fmt.Println("j=",j)
二、进制转换-其他进制转十进制(初始进制数*初始进制数的次方)
1、二进制转十进制:1011=11,1*2的3次方+0*2的2次方+1*2的1+1*2的0次方
2、八进制转十进制:0123=83,1*8的2次方+2*8的1次方+3*8的0次方
3、十六进制转十进制:0x34A=842,3*16的2次方+4*16的1次方+10(A)*16的0次方 三、进制转换-十进制转其他进制--->>>都是除以要转的进制数,取余数
1、十进制转二进制转,该数除以2,将余数倒过来,就是二进制 10=1010
2、十进制转八进制,该数除以8,将余数倒过来,就是八进制 156=0234
3、十进制转十六进制,该数除以16,将余数倒过来,就是十六进制 356=0X164 四、进制转换-二进制转其他进制(八进制时三位为一组,十六进制时四位为一组)
1、二进制转八进制:将二进制分三位为一组,再将每个数*2的次方,1101011=0325
2、二进制转十六进制:将二进制分四位为一组,再将每个数*2的次方,11010101=0xD5 五、进制转换-其他进制转二进制--->>>都是除以要转的进制数,取余数
1、八进制转二进制:将每一位八进制数转成三位的二进制,0237=10011111
2、十六进制转二进制:将每一位十六进制数转成四位的二进制,0x237=1000110111 六、位运算:&、|、^、<<、>>,运算需将转成补码运算,若是负数,需将结果从补码转成反码,再转成源码
1、原码、反码、补码介绍
2、二进制最高位是符号位,0表示正数,1表示负数 --->>1=0000 00001 -1=1000 0001
3、正数的原码,反码,补码都是一样
4、负数的反码=原码符号位数不变,其它取反,补码=反码+1
1-->>原码:0000 0001-->反码:0000 0001-->补码:0000 0001
-1-->>原码:1000 0001-->反码:1111 1110-->补码:1111 1111
5、0的反码,补码都是0
6、在计算机运算的时候都是采用补码的方式运算
7、负数:补码转反码是-1,反码转源码是取反 8、& 按位与:全1为1,否则为0
-->>2&3=2 2=0000 0010 3=0000 0011,将2和3的二进制补码进行&运算
9、| 按位或:有1出1,否则为0 -->>2|3=3 2=0000 0010 3=0000 0011,将2和3的二进制补码进行|运算
10、^ 按位异或:一个为1,一个为0,结果为1,否则为0
-->>2^3=1 2=0000 0010 3=0000 0011,将2和3的二进制补码进行^运算
-->>-2^2=-4 2=(原码:1000 0010-->>反码:1111 1101-->>补码:1111 1110 2=0000 0011,将-2和2的二进制补码进行^运算
-->>运算结果是补码:1111 1100-->>转反码:1111 1011-->>转源码:1000 0100=-4 11、右位移运算:低位溢出,符号位不变,并用符号位补溢出的高位
12、左位移运算:符号位数不变,低位补0
go语言-二进制与位运算的更多相关文章
- 深入理解计算机系统(2.2)---布尔代数以及C语言上的位运算
布尔代数上的位运算 布尔代数是一个数学知识体系,它在0和1的二进制值上演化而来的. 我们不需要去彻底的了解这个知识体系,但是里面定义了几种二进制的运算,却是我们在平时的编程过程当中也会遇到的.这四种运 ...
- C/C++语言中的位运算
在计算机程序中,数据的位是可以操作的最小数据单位,理论上可以用“位运算”来完成所有的运算和操作. 一般的位操作是用来控制硬件的,或者做数据变换使用,但是,灵活的位操作可以有效地提高程序运行的效率.C语 ...
- C语言中的位运算和逻辑运算
这篇文章来自:http://blog.csdn.net/qp120291570/article/details/8708286 位运算 C语言中的位运算包括与(&),或(|),亦或(^),非( ...
- C语言中的位运算的技巧
一.位运算实例 1.用一个表达式,判断一个数X是否是2的N次方(2,4,8,16.....),不可用循环语句. X:2,4,8,16转化成二进制是10,100,1000,10000.如果减1则变成01 ...
- Java二进制和位运算,这一万字准能喂饱你
基础不牢,地动山摇.本文已被 https://www.yourbatman.cn 收录,里面一并有Spring技术栈.MyBatis.JVM.中间件等小而美的专栏供以免费学习.关注公众号[BAT的乌托 ...
- POJ 2436 二进制枚举+位运算
题意:给出n头牛的得病的种类情况,一共有m种病,要求找出最多有K种病的牛的数目: 思路:二进制枚举(得病处为1,否则为0,比如得了2 1两种病,代号就是011(十进制就是3)),首先枚举出1的个数等于 ...
- #C语言初学记录(位运算)
位运算 Problem Description7-1 数组元素循环右移问题 一个数组A中存有N(>0)个整数,在不允许使用另外数组的前提下,将每个整数循环向右移M(≥0)个位置,即将A中的数据由 ...
- C语言基础知识--位运算
1.原码,反码,补码: (1)在n位的机器数中,最高位为符号位,该位为零表示为正,为一表示为负:其余n-1位为数值位,各位的值可为零或一.当真值为正时,原码.反码.补码数值位 完全相同:当真值为负时, ...
- POJ2570 二进制,位运算,Floyd
题意: 给你一个有向图,两点之间有多种连接方式,然后每次询问都问你点A,B之间有哪些方式可以到达,每个小字母是一个方式. 思路: 很巧妙的位运算和Floyd应用,借助Floyd ...
随机推荐
- Python之让 字符串内的转义字符 不做任何处理
一.在字符串前面加上 'r' 就可以了 print("\ntext_1") print(r"\ntest_2") 二.在转义字符的 '\' 前面再加一个 '\' ...
- CF991E Bus Number
题意翻译 给你一个数字序列A(长度不超过18位),问有多少个序列B满足①A中所有数字都一定要在B中出现过:②B中所有数字也一定要在A中出现过:③序列B不能以0开头 输入 #1 97 输出 #1 2 解 ...
- python 安装pytorch 及 安装失败解决办法
python 安装pytorch 及 安装失败解决办法 [转] pytorch安装失败解决办法 [转] 一分钟在win10终端成功安装pytorch pytorch 的安装方法有2种,一种是pip安装 ...
- 19 IO流(十六)——Commons工具包,FileUtils(一)
Commons包的API:自己查吧懒得传云 Commons包的导入方法 Commons是一个java的IO开源工具,导入方法: 从apache.org下载commons包 解压 copy其中的comm ...
- 有关kali更新源时出现的GPG数字证书无效提示的解决方法
下载并导入key文件 wget -O - https://archive.kali.org/archive-key.asc |apt-key add 显示ok表示成功导入key,然后再进行之后的其他步 ...
- Django模型层之更多操作
Django模型层之更多操作 一 .ORM字段 1.1 常用字段 AutoField int自增列,必须填入参数 primary_key=True.当model中如果没有自增列,则自动会创建一个列名为 ...
- InnoDB的MVCC实现原理
InnoDB的MVCC,是通过在每行记录后面保存两个隐藏的列来实现的. 这两个列,一个保存了行的创建时间,一个保存了行的过期时间(删除时间).当然存储的并不是实际时间,而是系统版本号(sytem ve ...
- -Dmaven.test.skip=true 和 -DskipTests
-DskipTests,不执行测试用例,但编译测试用例类生成相应的class文件至target/test-classes下. -Dmaven.test.skip=true,不执行测试用例,也不编译测试 ...
- Ubuntu 18.04下安装Steam顶级在线游戏平台
Ubuntu 18.04下安装Steam顶级在线游戏平台 原创: 聆听世界的鱼 Linux公社 今天 Steam是由Valve公司开发的顶级在线游戏平台,是目前全球最大的综合性数字发行平台之一.它让你 ...
- Python2与Python3兼容
Python2与Python3兼容 python3写的代码如何也能在pyhon2上跑?请无论如何加上这一句,python3没有啥影响 from __future__ import absolute_i ...