一、进制介绍
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. QT 模拟Visio软件通过拖动搭建流程图

    探索中.. 1 https://bbs.csdn.net/topics/390848708 https://www.cnblogs.com/chinese-zmm/archive/2010/10/10 ...

  2. python 之 Django框架(路由系统、include、命名URL和URL反向解析、命名空间模式)

    12.36 Django的路由系统 基本格式: from django.conf.urls import url urlpatterns = [ url(正则表达式, views视图函数,参数,别名) ...

  3. Verilog转电路图

    “你写的不是程序,是电路!”这句话听了很多,大多数人还是搞不太懂.程序怎么能是电路呢?这里将一些典型的Verilog转电路图贴出来,也许可以稍稍理解电路思想了. 1. 2. 3. 4. 5. 6. 7 ...

  4. appium 环境准备

      一.环境准备 1.相关依赖环境 当前的环境是Windows 10版本 64位系统(32位的自己想办法吧)          1.jdk1.6.0 (64位)  --最好1.6以上版本      2 ...

  5. Luogu4069 SDOI2016 游戏 树链剖分、李超线段树

    传送门 每一次加的是一个一次函数,一些呈一次函数的线段求最小值,显然用到李超线段树. 然后把维护序列的李超线段树强行上树,就直接套上树剖就可以了. 至于李超树如何区间查询,因为一次函数线段的最小值一定 ...

  6. java之hibernate之配置讲解

    1.映射文件:User.hbm.xml <!-- package 指向class中所有类的包名,可以直接在指定类名时同时指定包名 --> <hibernate-mapping pac ...

  7. Unity - Profiler参数详解

    CPU Usage ​       ● GC Alloc - 记录了游戏运行时代码产生的堆内存分配.这会导致ManagedHeap增大,加速GC的到来.我们要尽可能避免不必要的堆内存分配,同时注意:1 ...

  8. 【SP1716】GSS3 - Can you answer these queries III(动态DP)

    题目链接 之前用线段树写了一遍,现在用\(ddp\)再写一遍. #include <cstdio> #define lc (now << 1) #define rc (now ...

  9. 图解Apache Mina

    Apache MINA 是一个用于简化开发构建高性能.高可扩展的网络应用框架.通过JAVA NIO在各种传输协议(如:TCP/IP.UDP/IP)上提供抽象的事件驱动异步API Apache MINA ...

  10. VS2017 配置 boost_1_70

    1. 下载与安装 1.1 安装方法1 (1) 下载 https://www.boost.org/ 或者使用 https://sourceforge.net/projects/boost/files/b ...