一、进制

1.1 二进制

1.1 简介

二进制数据是用0和1两个数码来表示的数。它的基数是2,进位规则是“逢二进1”,借位规则是“借一当二”。当前的计算机系统使用的基本上是二进制系统。

1.2 二进制数据表示法

二进制没有2只有0和1,逢2进1,其权的大小顺序为22、21、2o。例如:

二进制数据0001代表十进制的1,二进制数据0010代表十进制的2,

二进制数据0011代表十进制的3,二进制数据0100代表十进制的4,

二进制数据0101代表十进制的5,二进制数据0110代表十进制的6,

二进制数据1000代表十进制的8,二进制数据1001代表十进制的9,

二进制数据1010代表十进制的10,二进制数据1011代表十进制的11,

二进制数据1101代表十进制的13,二进制数据1111代表十进制的15。

1.3 二进制数据的特点

在一个二进制数字的尾部每次多加一个0代表这个数字乘以2,就如同十进制的尾部每次多加一个0代表乘以10。例如:

二进制数据0001代表十进制的1,二进制数据0010代表十进制的2,

二进制数据0100代表十进制的4,二进制数据1000代表十进制的8,

2的常见倍数:1 2 4 8 16 32 64 128 256 512 1024 2048 4096

1.2 十六进制

英文名称:hexadecimal ,是计算机中数据的一种表示方法。同我们日常中的十进制表示法不一样。它由0-9,A-F组成,字母不区分大小写。

与10进制的对应关系是:0-9对应0-9;A-F对应10-15;N进制的数可以用0---(N-1)的数表示超过9的用字母A-F。二进制只有0和1没有2,十进制只有0-9的数字没有10,十六进制只有0-F,也就是0到15的数字没有16。

在一个十六进制数字的尾部每次多加一个0代表这个数字乘以16,就如同十进制的尾部每次多加一个0代表乘以10。例如:

十进制的32表示成十六进制就是:20

十六进制的20代表十进制的:2×161+0×16o=32

十六进制的A5代表十进制的:10×161+5=165

十六进制的100代表十进制的:16×16=256

十六进制的23F代表十进制的:2×16×16+3×16+15=575

1.3 进制的转换

10进制转2进制:让个位对2取余数得出是1还是0,对其他位除以对应的2的倍数

二、常量

C语言的常量包括:整数常量、浮点数常量、字符常量和字符串常量。

2.1 整数常量的表示方法

十进制表达式,和普通数字的表达方法一致。例如:13,28,-52,-1000等等

十六进制表达式,以0x开头。例如:0xA1,0xC8,-0x20,-0x500等等

八进制表达式,以0开头。例如:032,-011

注意:0开头的常量看上去好像是十进制,其实不是了,已经是八进制了,八进制中只有0-7之间的数字,8和9都错误代码。

注意:C语言并没有提供二进制常量表达式。

2.2 浮点数常量

浮点数常量,通俗地说就是带小数点的数字,表达式的中必须含有小数点,即使小数部分是0也要缺省带小数点。

主要有两种表达式:

单精度浮点数:尾部带f的浮点数代表是单精度浮点数。例如:0.5f,88.2f,-55.0f等等。

双精度浮点数:尾部不带f的浮点数代表是双精度浮点数。例如:0.88,99.5,-111.356等等。

一般认为双精度浮点数比单精度浮点数表达的范围要大很多,包括整数部分和小数部分,双精度表达的数字长度要大很多。

2.3 字符常量

字符常量是用单引号将一个字符括起来的构成,每种被括起来不同的字符代表一个不同的数字(就如同每个学生有不同的名字,而且还有个不同的学号一样)。

所有字符与数值的对照表就是ASCII编码表,作为字符常量使用的ASCII编码主要是使用0-127范围内的数字。其中0~31及127(共33个)是控制字符或通信专用字符,其余为可显示字符。

例如:char c = ‘A’;

‘A’代表的是一个数字65,因为在ASCII编码表中A的数值是65,依此类推:

‘ B’代表66,‘a’代表97,

‘X’代表88,‘5’代表53,

‘=’代表61,‘|’代表124,

’ ’空格代表32等等。

因此,字符常量实际上也是一种整数常量,只不过字符常量所表达的范围比较小而已。

所有的ASCII码都可以用“\”加数字(2位的16进制数字或3位的8进制数字)来表示。

在C语言中常用些字母前加“\”,来表示常见的那些不能显示的ASCII字符,这样的字符就叫做转义字符。例如:char c = ‘\n’;其中‘\n’代表10,被打印输出时代表换行“new line”。依此类推:‘t’代表9,被打印输出时代表间隔一个TAB距离“Table”。

‘\0’代表0,打印输出时代表字符串结尾。

‘\\’代表92,打印输出时是一条反斜杠。

注意在C语言中要打印一条反斜杠,在字符常量中必须使用‘\\’来表示。

‘\”’代表34,打印输出时代表是一个双引号。

char c=‘\x25’; 代表37打印输出的是% ,Char c=‘\053’; 代表43打印输出的是+。

2.4 字符串常量

字符串常量是一对双引号括起来的字符集合。

例如,下面的是合法的字符串常量:"how do you do.","CHINA","a","$123.45",

存储:字符串中的字符依次存储在内存中一块连续的区域内,并且把空字符‘ \0’自动附加到字符串的尾部作为字符串的结束标志。故字符个数为n的字符串在内存中应占(n+1)个字节。

使用printf可以输出字符串,例如:printf("how do you do.");

与字符常量的比较:

字符常量是由一对单引号括起来的单个字符;而字符串常量是一对双引号括起来的字符集合。

字符常量本质上是一个数字,这个数字对应了一个字符;而字符串常量本质上是一个字符集合的内存地址,打印时从头部遍历直到结尾符结束。

不能将字符串与字符常量混淆。字符常量可以赋值给字符变量,但不能把一个字符串常量赋给一个字符变量,同时也不能对字符串常量赋值!例如:char b=‘a’;(正确) char b= “a”;(错误)

三、变量

3.1 字节的概念

计算机中将字节(Byte)作为计量存储容量和传输容量的一种计量单位,一个字节等于8位二进制数。在内存中个位的空间可以存储的数值只有0和1两种,两个位可以存储的数值可能是00、01、10和11。这四个数值分别代表的就是0、1、2、3。依此类推,如果有4个位的空间可以存储的数字就是:0-15(0x0到0xF)。

由此可见,内存空间上N个位可以存储的数值就是2的N次方个。

一个字节代表8个位的内存空间,可以存储的数值就是2的8次方个,即0到255之间的数值,十六进制表达是0x00到0xFF之间的数值

3.2 变量的分类

C语言变量,是指一段用于存取数据的内存空间。

根据当个变量的空间长短可分为:

字符型变量(1个字节):char类型、unsigned char类型;

短型变量(2个字节):short类型、unsigned short类型;

长型变量(4个字节):int、unsigned int(或long、unsigned long)或float类型以及指针变量等。

超长型变量( 8个字节):double类型、__int64等。

根据类型可以分为:

整数型变量:包括char、 unsigned char、short、 unsigned short、int、 unsigned int(或long、unsigned long )以及 __int64等。

浮点数型变量:float类型(单精度)、double类型(双精度);

其他变量类型还有:指针变量:数组变量以及结构体对象等;

3.3 变量的存储范围

从上表看出4个位表达的刚好是十六进制数字的个位数,如果再加4个位8位刚好表达的就是十六进制的两位数。因此计算机以8个位代表一个字节,表达的数字是(0-255)0x00到0xFF之间的数字总共256个,就像十进制中的两位数是0到99总共100个那样。

3.3.1 单字节变量(8位)

单字节变量(8位): unsigned char和char

unsigned char:无符号单字节变量,存储范围是0-255(0xFF)。

char:有符号单字节变量,存储范围是-128到0到127之间的数。

为了让char类型存储的256种数字中,一半是正数一半是负数,计算机将char类型变量中的最高位作为符号位。最高位为0的是正数,最高位为1是负数。

在负数区间,将unsigned char的数值减去256就是char类型。

3.3.2 双字节变量(16位)unsigned short和short

unsigned short:无符号双字节变量,存储的范围是0-65535(0xFFFF) 总共65536个,就像十进制中的4位数是0到9999总共10000个那样

short :有符号双字节变量,存储范围是-32768到0到32767。

为了让short类型存储的65536种数字中,一半是正数一半是负数,计算机将short类型变量中的最高位作为符号位。最高位为0的代表正数,最高位为1代表负数。

在负数区间,将unsigned short的数值减去65536就是short类型的数值。

3.3.3 四字节变量(32位): unsigned int和int(或unsigned long和long)

unsigned int:无符号四字节变量,存储的范围是0-4294967295(0xFFFFFFFF) 总共4294967296个,就像十进制中的8位数是0到99999999总共100000000个那样

int:有符号四字节变量,存储范围是-2147483648到0到2147483647。

在计算机中:1K=1024,1M=1024K,1G=1024M。

65536刚好被1024整除等于64,因此65536也称为64K,32768称为32K; 4294967296刚好被3个1024整除,因此也称为4G,2147483648称为2G。

为了让int类型存储的4G种数字中,一半是正数一半是负数,计算机将int类型变量中的最高位作为符号位。最高位为0的代表正数,最高位为1代表负数。

在负数区间,将unsigned int的数值减去4G就是int类型的数值。

3.3.4 其他类型变量

指针变量:在32位操作系统中也是32位的,存储范围是0-0xFFFFFFFF之间。

浮点数类型:浮点数变量的存储结构与整型变量的存储结构完全不同。

float类型小数部分最多可以精确到6到7位,整数位数增长会占用小数部分。

double 类型的小数部分至少要能精确到小数点后 10 位以上,整数位数增长会影响到小数部分的精确度。

c语言变量加常量,C语言(二)---常量与变量(示例代码)相关推荐

  1. R语言广义加性模型GAMs:可视化每个变量的样条函数、样条函数与变量与目标变量之间的平滑曲线比较、并进行多变量的归一化比较、测试广义线性加性模型GAMs在测试集上的表现(防止过拟合)

    R语言广义加性模型GAMs:可视化每个变量的样条函数.样条函数与变量与目标变量之间的平滑曲线比较.并进行多变量的归一化比较.测试广义线性加性模型GAMs在测试集上的表现(防止过拟合) 目录

  2. python制作微信二维码_Python提取支付宝和微信支付二维码的示例代码

    支付宝或者微信支付导出的收款二维码,除了二维码部分,还有很大一块背景图案,例如下面就是微信支付的收款二维码: 有时候我们仅仅只想要图片中间的方形二维码部分,为了提取出中间部分,我们可以使用图片处理软件 ...

  3. c语言字符串加减_C语言中指针的介绍

    C语言中指针的介绍 指针是C语言中广泛使用的一种数据类型. 运用指针编程是C语言最主要的风格之一.利用指针变量可以表示各种数据结构:能很方便地使用数组和字符串: 并能象汇编语言一样处理内存地址,从而编 ...

  4. C语言如何加缓冲,C语言学习笔记之输出缓冲

    在c语言中经常用到输出函数printf,当我们像往常一样在输出函数中输入我们的想要的输出的东西后加\n换行 验证结果如我们输出的一样 如果我们在后面加入死循环会不会出现这些语句呢 结果卡死了,可还是输 ...

  5. R语言 lightgbm 算法优化:不平衡二分类问题(附代码)

    来源:大数据文摘本文约10000字,建议阅读10分钟本文以kaggle比赛的数据为例,为你讲解不平衡二分类问题的解决方法. 本案例使用的数据为kaggle中"Santander Custom ...

  6. r语言 柱状图加星号_R语言绘制带有显著性字母标记的柱状图

    Tao Wen 引子 方程分析的包目前正在重构,大家耐心等待,这是一年前我开始做这个包的时候的细节,从这里大家就可以学会如何做差异分析和可视化. library(tidyverse) library( ...

  7. 二维离散变换由c语言编写,C++实现离散余弦变换(参数为二维指针)(示例代码)...

    http://www.cnblogs.com/scut-linmaojiang/p/5013590.html 写在前面 到目前为止已经阅读了相当一部分的网格水印等方面的论文了,但是论文的实现进度还没有 ...

  8. r语言 柱状图加星号_R语言-柱状图

    ​​适合用于描述主数据(y轴数据)在不同分类(x轴是因子类型的分类数据,或者是时间数据)下的展示情况.同时,柱状图还可以清晰地绘制不同情况下的多组数据,以便于横向对比.barplot函数是柱状图的核心 ...

  9. c语言指针加括号,C语言数组,指针和方括号赋值和输出产生不同结果?

    背景: 下述函数的作用,是将字符数组倒叙转化为整型数组,但是运行过程中,*b这种形式,就能正常赋值,输出:b[test_count]这种形式就不能正常赋值,输出 编译工具:Visual studio ...

  10. C语言丨运算符号的三种用法(有示例代码)

    &: 在C语言中有两种意思,一种是取地址符,是单目运算符:另一种是位运算符,表示"按位与",是双目运算符. 1.用于指针赋值 #include<stdio.h> ...

最新文章

  1. 海思3536:PC客户端编译过程报错及解决方法
  2. 三招看穿ERP软件是否可行
  3. jvm调优:GC日志格式
  4. mysql进阶(十五) mysql批量删除大量数据
  5. 奇怪吸引子---一个奇妙的四维混沌吸引子
  6. 纪中B组模拟赛总结(2020.2.22)
  7. POJ1040 HDU1456 UVA301 UVALive5516 Transportation题解
  8. Fedora9 问题集锦
  9. spyder替换_Spyder快捷键
  10. 前路钉板系统在重建胸腰段稳定性中应用 [已发表]
  11. wtg linux双系统,Windows和Linux同时装入移动硬盘,实现可移动专属双系统
  12. 数据分析师之路-数据埋点
  13. 汽车车牌自动识别技术
  14. 陶哲轩实分析 5.5 节习题试解
  15. 各行业的英语术语(绝对精华3)
  16. Androi Error:Execution failed for task ':app:transformDexArchiveWithExternalLibsDexMergerForDebug'
  17. ASM Disk Discovery 最佳实践
  18. Win7下硬盘安装Linux双系统
  19. 基于stm32单片机有害气体监测检测Proteus仿真
  20. 01背包问题 动态规划

热门文章

  1. hdu 1161 Eddy's mistakes
  2. 利用open***建立桥接***[zt]
  3. 2021-08-12 画蜡烛线
  4. Android应用开发—RecyclerView绘制蒙层
  5. golang学习之旅(2)- go的数据基本数据类型及变量定义方式
  6. eclipse怎样改编码格式_Eclipse中各种编码格式及设置
  7. 解决:build_attrs() takes at most 2 arguments (3 given)
  8. Halcon中OCR的实现及关键函数解析
  9. C++中模板使用详解
  10. grpc php 返回值过大,使用grpc实现php、java、go三方互调