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

一、进制

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)。

b57f820f1fb46ab7be720dd6e1bd7f8f.png

由此可见,内存空间上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

4a779e21a82bc06b4850d09526b537c9.png

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

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

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

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

056346e63792c3fd9315420f08f85673.png

c29d47f71b3645888ba4b2de162d03fc.png

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

330c4e5ef59e597efd8ddb29fc629a9d.png

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

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

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

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

513d631865d995c4d68d996c1100c64e.png

838f038d6dddd99535900d5ada2d40f9.png

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类型的数值。

b95a484d5c224b663c95b530fd4d9090.png

3.3.4 其他类型变量

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

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

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

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/467331.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用CodeSmith要注意的几点

新的项目即将开始了,项目经理老蔡说上次项目的持久层框架不太适合B/S项目,原因是反射用得太多了,并且数据层内部自己又封装了好几层,所以决定从新设计一个执行效率更高的框架。 老蔡设计了下他构思好的持久层和数据层的接口&am…

Alsa里面恶心的DAPM

相关文章音频系统,Alsa 里面的buff 是怎么计算的?为什么需要超过48k的采样音频?我在MTK平台下调试音频ALSA音频几个重要的参数openwrt 音频开发(干货)Ai音箱和Linux音频驱动小谈Android 音频数据流分析之程序员干架产品经理正文做音频的很多初…

android 屏幕关闭 eofexception,android EOFException异常解决办法 (SharedPreferences保存对象)...

SharePreferences可以保存String 但是不能保存对象这不符合面向对象。为此可以通过序列化和反序列化将Serializable对象和字符串相互转化所以可以将Serizlizable对象转化为字符串保存到SharedPreferences中SharedPreferences.Editor localEditor settings.edit();localEditor.…

软件开发能力成熟度模型CMM介绍

软件开发能力的成熟度模型(Capability Manurity Model for Software,CMM)是软件工程协会SEI(Software Engineering Institution)在卡内基.梅隆大学开发完成的对一个组织软件开发能力进行评价的标准,它侧重于对软件开发过程和开发方法论的考察。CMM包括五…

POJ 3461Oulipo KMP模板

KMP之所以线性,因为匹配的时候i是不往回走的 我们只用调整j的位置 假设在s中找t 用二元组(i,j)表示s串的[i-j1,i] 与t串的[1,j]匹配 假设s[i1]和t[j]匹配上了,就j 如果不匹配的话,我们就想办法调整j, 直到找到一个满足二元组条件的j并且t[j1]s[i] 快速调整j就是利用nxt数组的过…

从Linus Torvalds一封发飙的电邮开始谈设备树究竟是棵什么树?

[导读] 新版的U-Boot以及内核都引入了设备树,那么这究竟是棵什么样的树呢?长啥样?有啥用?为啥弄个这样的树?本文基于对设备树标准的理解,来学习整理一下相关的要点,供大家参考。Linux为啥要设备…

html两个div间有白线,html-在特定浏览器宽度下,白线出现在渐变填充div的末尾

我有一个ID为#gradient_div的div,其背景图像设置为线性渐变.仅在某些浏览器窗口宽度下,线性渐变的末尾与div #gradient_div的末尾之间才出现缝隙.当我拉伸和收缩浏览器窗口时,这条白线消失并重新出现.似乎与边距有关:>当我将边距设置为margin:0 1&…

递归多线程实现前缀和

http://blog.csdn.net/qq_21361539/article/details/51577263转载于:https://www.cnblogs.com/NEU-2015/p/7857668.html

[Classic] 日文版《出师表》

臣亮言す.先帝业を创めて未だ半ばならずして,中道にして崩祖せり.今天下三分すれども, 益州は疲弊す.此れ诚に危急存亡の秋なり.然れども侍卫の臣,内に懈らず,忠志の士,身を 外に忘るるは,盖し先帝の殊遇を追いて,之を陛下に报いんと欲すればなり.诚に宜しく圣聴 を开张して…

为什么读书了,还不如那些初中毕业的同学

今天群里特别热闹,大家聊了很多,我在旁边看着,很舒服,可能也有人跟我一样,看着这些B神吹牛。像读书时候的卧谈会,大家都聊的很嗨,听的人更嗨,我就是那个喜欢听大家吹牛的人&#xff…

html判断整数小数点后两位小数点,js控制input框只能输入数字和一位小数点且小数点后面只有两位小数...

js控制input框只能输入数字和一位小数点且小数点后面只有两位小数js控制input框只能输入数字和一位小数点且小数点后面只有两位小数212或 0.66; 过滤 00000,1.10,0.00function clearNoNum(obj){obj.value obj.value.replace(/[^\d.]/g,""); //清除“数字”和“.”以…

为什么说卷积神经网络,是深度学习算法应用最成功的领域之一?

目前,作为深度学习的代表算法之一,卷积神经网络(Convolutional Neural Networks,CNN)在计算机视觉、分类等领域上,都取得了当前最好的效果。后来,基于深度神经网络和搜索树的智能机器人“AlphaG…

C语言博客作业--函数

C语言博客作业--函数 一&#xff0c;PTA实验作业 6-2 简单实现x的n次方 1.本题PTA提交列表 2.设计思路 double mypow( double x, int n )函数&#xff08;1&#xff09;定义y1&#xff0c;i用于循环变量&#xff08;2&#xff09;for(i1;i<n;i){ yy*x}用循环实现x的n次方&am…

linux下软件的基本安装和卸载

Linux软件的安装和卸载一直是困扰许多新用户的难题。在Windows中&#xff0c;我们可以使用软件自带的安装卸载程序或在控制面板中的“添加/删除程序”来实现。与其相类似&#xff0c;在Linux下有一个功能强大的软件安装卸载工具&#xff0c;名为RPM。它可以用来建立、安装、查询…

计算机应用基础课程编制标准,计算机应用基础课程标准.doc

计算机应用基础课程标准《计算机应用基础》课程标准一、前言《计算机应用基础》课程是高职院校必修的一门基础课&#xff0c;具有很强的实用性和实践性&#xff0c;是各行各业从事现代化办公&#xff0c;计算机设计及应用领域人才所必须具备的理论知识和时间技能&#xff0c;通…

Linux系统编程 / triggerhappy 源码分析(3.select 的应用)

哈喽&#xff0c;我是老吴&#xff0c;继续记录我的学习心得。一、进步的滞后性我们期望进步是线性&#xff1a;每一个人付出一些努力后&#xff0c;都希望它有立竿见影的效果。现实是&#xff1a;做出努力后&#xff0c;结果的显现往往滞后。只有在几个月或几年后&#xff0c;…

node中定时器, process.nextTick(), setImediate()的区别与联系

1.定时器 setTimeout()和setInterval()与浏览器中的API是一致的&#xff0c;定时器的问题在于&#xff0c;他并非精确的&#xff08;在容忍范围内&#xff09;。尽管事件循环十分快&#xff0c;但是如果某一次循环占用的时间较多&#xff0c;那么下次循环时&#xff0c;他也许已…

[转载]关于NETBIOS理清楚概念的文章

有关网上邻居的问题&#xff0c;问的人一直比较多&#xff0c;在理解上存在的误区也普遍较为严重。鉴于Microsoft的NETBIOS文档不是很细致&#xff0c;我四处收集了一些相关资料加上自己的实践经验写了这个系列&#xff0c;希望能对大家有所帮助&#xff0e; 本来想为了增加可读…

form.html,HTML表单form

前面我们讲了HTML的各种数据输入方式&#xff0c;数据输入之后&#xff0c;一般来说应该提交给后台处理&#xff0c;HTML通过表单form来提交数据。form包含1个或多个数据输入&#xff0c;如input&#xff0c;单选&#xff0c;复选&#xff0c;文件等等form将其包含的输入项&…

今天,给我妈打电话聊了我爸

晚上&#xff0c;给我妈打电话&#xff0c;我爸前两天病了&#xff0c;前几年的大病虽然慢慢康复&#xff0c;但是因为年纪大了&#xff0c;身体机能也慢慢变弱&#xff0c;总是有一些大大小小的问题。前两天我发消息给我爸&#xff0c;我说我们要进新房子了&#xff0c;虽然房…