【C语言疯狂讲义】(七)C语言进制转换
1、计算机中的进制
2进制:逢二进1 0 1
8进制:逢八进1 0 1 2 3 4 5 6 7
10进制:逢十进1
默认的进制 0 - 9
16进制:逢十六进1 0 - 9 A B C D E F (内存的地址格式)
2、进制的转换问题
三个要素:
数位(0-7)、
基数(每一位能取值的个数)、
位权(数码*基数^数位)、 101 = 1*2^0+0*2^1+1*2^2
数码(每一位设置)
转换:有得时候转换为人能识别的数制,要操作计算机写计算机可以识别的语言(二进制)
10 -> 2 : 除2取余法,把10进制数除以2,然后取得余数的序列。再倒序
2 -> 10 : 全部位的位权相加 101 = 1*2^0+0*2^1+1*2^2
2 --> 16 : 4合1法。
整数部分从右向左 4位结合成一位。小数部分从左向右4位结合1位,不足部分补0
16 -->2 : 1拆4法。 16进制的1位拆成二进制的4位
2 --> 8 : 3合1
8 --> 2 : 1拆3
8 --> 10 : 8--> 2 --> 10
16 --> 10: 16 -->2 -->10
3、原码、反码和补码
1)机器码、真值
一个数的二进制的表示
机器码
把一个数的二进制转换为10进值得值
真值
2)计算数据的存储
存储的时数的补码
数是有正负性
正数:最高位
用0表示符号位
负数:最高位
用1表示符号位
3)原码、反码、补码:
正数:就是其二进制表示 +1 00000001
负数:二进制的最高位是1 -1 10000001
反码:
正数:就是其二进制表示 +1 00000001
负数:符号位不变,其它位逐位取反 -1 11111110
补码:
正数:就是其二进制表示 +1 00000001
负数:反码+1 -1 11111111
注意:补码的真值不等于原码的真值的
4、为什么要使用补码?
主要是位了优化计算机中的减法
5、补码的深入解说
1-1 = 1+(-1)
6、位运算符
二进制数码之间的运算
6个符号
& 按位与:逐位运算,有0则为0,同1则为1
| 按位或:有1为1
^ 按位异或:同样为0。不同为1
~ 按位的取反:0变1。1变0
>> 按位右移:把一个数的所有的二进制位所有向右移动指定位数 10>>2;
注意:移出的位舍弃,高位补符号位,可能让一个数为0
<< 按位左移
把一个数的所有的二进制位所有向左移动指定位数
注意:移出的位舍弃。低位补0。可能会改变一个数的正负性
11&2
1011
& 0010
--------------
0010
技巧:
不论什么数和1按位&操作。得到这个数的最低位
偶数的最低位 0
奇数的最低位 1
7、变量在内存中存储的细节
内存分配给变量的存储空间是从高到低
一个变量低位低地址
高位存放高地址
8、char类型
char
char常量 'a','b',
以int型进行存储,占4个字节
char变量
【C语言疯狂讲义】(七)C语言进制转换的更多相关文章
- 一起talk C栗子吧(第七回:C语言实例--进制转换)
各位看官们.大家好,从今天開始.我们讲大型章回体科技小说 :C栗子,也就是C语言实例. 闲话休提, 言归正转.让我们一起talk C栗子吧! 看官们.上一回中咱们说的是生成随机数的样例.这一回咱们说的 ...
- C语言关于进制转换,补码, 整数的位操作
菜单导航: 1.二进制.八进制.十进制.十六进制的相互转换 2.原码.反码.补码 3.举例证明整数在计算机内是以补码的形式存在(以负数为例) 4.整数的位操作:按位且&.或|.异或^.取反~ ...
- C语言实现进制转换——超图面试题
递归:递归的原理,就是自己调用自己本身.存在一个顺序的问题,如果在递归前的是顺序执行,递归后的是逆序执行,如下: void gogogo() { //递归之前 gogogo(); //递归之后 } 递 ...
- C语言拼接字符串以及进制转换
#include<stdio.h> #include<stdlib.h> #include<string.h> char *join1(char *, char*) ...
- C语言 进制转换
这个程序仅仅是由十进制转换为其他进制的过程,其转换的规则如下图所示. 我使用的思路:首先在除基的过程中用一个数组保存余数,然后在输出进制转换结果的时候倒序输出,并且在输出前判断余数是否大于10,如果大 ...
- C语言基础——进制转换 / 数据表示
第一部分:进制转换 二进制:由0~1构成,逢2进1 八进制:由0~7构成,逢8进1 十六进制:由0~9.A~F构成,逢16进1 两个基本概念 基数:n进制基数为n 123.4 = 1*10^2 + 2 ...
- JAVA之旅(一)——基本常识,JAVA概念,开发工具,关键字/标识符,变量/常量,进制/进制转换,运算符,三元运算
JAVA之旅(一)--基本常识,JAVA概念,开发工具,关键字/标识符,变量/常量,进制/进制转换,运算符,三元运算 Android老鸟重新学一遍JAVA是什么感觉?枯燥啊,乏味啊,而且归纳写博客,都 ...
- Java基础(进制转换-)
进制概述: 进制也就是进位计数制,是人为定义的带进位的计数方法(有不带进位的计数方法,比如原始的结绳计数法,唱票时常用的“正”字计数法,以及类似的tally mark计数). 对于任何一种进制---X ...
- java se系列(二) 关键字、注释、常量、进制转换、变量、数据类型转换、运算符
1 关键字 1.1 关键字的概述 Java的关键字对java的编译器有特殊的意义,他们用来表示一种数据类型,或者表示程序的结构等,关键字不能用作变量名.方法名.类名.包名. 1.2 常见的关键字 备注 ...
- Knowledge Point 20180305 机器数转换与进制转换
机器数(这里的机器数说的就是数值在计算机中的存储形式,相关可以了解数据在计算机中的表示)之间的转换往往是通过原码来实现的,下面我们结合进制来来一下: 进制也就是进位制,是人们规定的一种进位方法. 对于 ...
随机推荐
- linux下命令源码
一般来说,不同的命令可能隶属于不同的软件包,这样就没有一个地方会有所有命令的源代码.(命令的个数也会与你所安装的软件包有关)但是,一些常用的命令,例如basename cat chgrp chmod ...
- Bean利用Resource接口获取资源的几种方式
Resources的类型 获取resource的方式(xml配置正常进行):
- HashMap扩容函数解读
void resize(int newCapacity) { Entry[] oldTable = table; int oldCapacity = oldTable.length; if (oldC ...
- C++实现高斯滤波器
在matlab中,我们经常用到高斯滤波器,生成滤波器一般都是这样的函数psf = fspecial('gauss', GaussSize, sigma),但是在vs2010中用到的高斯滤波器不能自 ...
- iOS设计模式 —— KV0
刨根问底KVO KVO 全称 Key-Value Observing.中文叫键值观察.KVO其实是一种观察者模式,观察者在键值改变时会得到通知,利用它可以很容易实现视图组件和数据模型的分离,当数据模型 ...
- Selenium2+python自动化35-获取元素属性【转载】
前言 通常在做断言之前,都要先获取界面上元素的属性,然后与期望结果对比.本篇介绍几种常见的获取元素属性方法. 一.获取页面title 1.有很多小伙伴都不知道title长在哪里,看下图左上角. 2.获 ...
- 【UOJ UNR #1】火车管理 可持久化线段树
用可持久化线段树维护每个站的第一辆车和每个站的前一次更新的位置即可. #include<iostream> #include<cstring> #include<cstd ...
- 使用vscode开发调试.net core应用程序并部署到Linux跨平台
使用VS Code开发 调试.NET Core RC2应用程序,由于.NET Core 目前还处于预览版. 本文使用微软提供的示例进行开发及调试. https://github.com/aspnet/ ...
- centos6 部署strongloop
1.安装node 1)下载官方二进制包 cd /opt wget https://nodejs.org/dist/latest-v7.x/node-v7.10.0-linux-x64.tar.gz 2 ...
- POJ 3264 Balanced Lineup 【线段树/区间最值差】
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 62103 Accepted: 29005 Cas ...