一、进制介绍
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语言-二进制与位运算的更多相关文章

  1. 深入理解计算机系统(2.2)---布尔代数以及C语言上的位运算

    布尔代数上的位运算 布尔代数是一个数学知识体系,它在0和1的二进制值上演化而来的. 我们不需要去彻底的了解这个知识体系,但是里面定义了几种二进制的运算,却是我们在平时的编程过程当中也会遇到的.这四种运 ...

  2. C/C++语言中的位运算

    在计算机程序中,数据的位是可以操作的最小数据单位,理论上可以用“位运算”来完成所有的运算和操作. 一般的位操作是用来控制硬件的,或者做数据变换使用,但是,灵活的位操作可以有效地提高程序运行的效率.C语 ...

  3. C语言中的位运算和逻辑运算

    这篇文章来自:http://blog.csdn.net/qp120291570/article/details/8708286 位运算 C语言中的位运算包括与(&),或(|),亦或(^),非( ...

  4. C语言中的位运算的技巧

    一.位运算实例 1.用一个表达式,判断一个数X是否是2的N次方(2,4,8,16.....),不可用循环语句. X:2,4,8,16转化成二进制是10,100,1000,10000.如果减1则变成01 ...

  5. Java二进制和位运算,这一万字准能喂饱你

    基础不牢,地动山摇.本文已被 https://www.yourbatman.cn 收录,里面一并有Spring技术栈.MyBatis.JVM.中间件等小而美的专栏供以免费学习.关注公众号[BAT的乌托 ...

  6. POJ 2436 二进制枚举+位运算

    题意:给出n头牛的得病的种类情况,一共有m种病,要求找出最多有K种病的牛的数目: 思路:二进制枚举(得病处为1,否则为0,比如得了2 1两种病,代号就是011(十进制就是3)),首先枚举出1的个数等于 ...

  7. #C语言初学记录(位运算)

    位运算 Problem Description7-1 数组元素循环右移问题 一个数组A中存有N(>0)个整数,在不允许使用另外数组的前提下,将每个整数循环向右移M(≥0)个位置,即将A中的数据由 ...

  8. C语言基础知识--位运算

    1.原码,反码,补码: (1)在n位的机器数中,最高位为符号位,该位为零表示为正,为一表示为负:其余n-1位为数值位,各位的值可为零或一.当真值为正时,原码.反码.补码数值位 完全相同:当真值为负时, ...

  9. POJ2570 二进制,位运算,Floyd

    题意:       给你一个有向图,两点之间有多种连接方式,然后每次询问都问你点A,B之间有哪些方式可以到达,每个小字母是一个方式. 思路:       很巧妙的位运算和Floyd应用,借助Floyd ...

随机推荐

  1. 史上最详细bitbucket入门手册,手把手操作指南

    老大要我去调研一下有什么好用的免费软件版本管理工具,有利于小团队开发的.我第一个想到的就是git,经常在git下东西,听说它的代码仓库好用,于是就注册了一个github的账号,创建仓库的时候才发现只能 ...

  2. java笔记4—继承

    继承: 作用: 提高了代码的复用性. 让类与类之间产生了关系,为多态提供了前提 继承中成员变量的特点: 继承中成员函数的特点: 方法重写: 注意:重写方法必须和被重写的方法具有相同的方法名,参数列表和 ...

  3. Django之拾遗

    一.设计模式 1.1 MVC 模型(M)是数据的表述,非真正数据,而是数据接口. 视图(V)是你看到的界面,是模型的表现层,此外还提供了收集用户输入的接口. 控制器(C)控制模型和视图之间的信息流动. ...

  4. day27——面向对象的总结、异常处理

    day27 面向对象的总结 异常处理 错误的分类 语法错误 if if 2>1 print(222) dic = {"name"; "alex"} 逻辑错 ...

  5. MySQL运维中的Tips--持续更新

    1.into outfile 生成sql:一般都是生成文本或者其他形式的文件,现在需要生成sql形式的文件.配置文件加secure_file_priv=''select concat('insert ...

  6. 记录一次mysql宕机的解决办法

    首先先粘贴出来我的错误信息,如下: 2019-07-16T00:53:18.285919Z 0 [System] [MY-010116] [Server] /usr/sbin/mysqld (mysq ...

  7. java 获取手机归属地,引起net.UnknownHostException错误

    这个问题是请求,重定向了,跟入源码.修改了地址,变成302 Connection connect = Jsoup.connect(url); connect.header("Host&quo ...

  8. 二叉树、B树、B+树、B*树、VAL树、红黑树

    二叉搜索树 每个节点只存储一个关键字, 每个节点最多有两个子节点, 左子节点存储的关键字小于本节点存储的关键字 右子节点存储的关键字大于本节点存储的关键字 搜索时,从根节点开始搜索,小于走左结点,大于 ...

  9. jQuery动画(带参数)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  10. JS中的函数与对象

    创建函数的三种方式 1.函数声明 function calSum1(num1, num2) { return num1 + num2; } console.log(calSum1(10, 10)); ...