1 引言
在计算机的世界里,数据类型是被人类定义出来的,方便人去更好地理解、辨别数据。计算机只能识别二进制数,不可能要求写代码时,只是输入一些0/1的东西。通过定义数据类型,可以让人和计算机更好地“沟通”,计算机对不同数据类型编译的方式是不一样的。
同时,不同的数据类型在计算机中占有的存储空间大小又是不一样的,即有的占用空间大,有的占用空间小,这样一来,计算机存储就更加灵活,空间利用率也会更高。数据在计算机中存储的空间用字节(Byte)来计量,一个字节存储8位无符号数,储存的数值范围为0-255。
常用的数据类型有:整型、浮点型、字符型、布尔型。要完全弄清楚一个数据类型,笔者觉得应该从这几个维度进行总结归纳:① 作用;② 分类;② 表示方法;③ 内存和范围;⑤ 特殊知识点。
2 不同数据类型介绍
2.1 整型
① 作用:用来表示整数;
② 分类:短整型(short)、整型(int)、长整型(long)、长长整型(long long)。
③ 表示方法:数据类型 变量名 = 变量初始值
例如:
short a = 1; //短整型变量a
int b = 2; //整型变量b
long c = 3; //长整型变量c
long long d = 4; //长长整型变量d
④ 内存和范围
⑤ 特殊知识点
- 在其它地方经常看到int8/int16/int32样式的表示方法:int8等同于Byte,占一个字节;int16等同于short占两个字节;int32等同于int,占四个字节;int64等同于long long,占8个字节。
- 超过所能表示的最大值时,会用该数据类型的下限表示(也就是出错了)。
2.2 浮点型
① 作用:用来表示小数
② 分类:单精度(float)、双精度(double)
③ 表示方法:数据类型 变量名 = 变量初始值
举例:
float a = 1.1f; //定义一个单精度变量
double = 1.2; //定义一个双精度变量
④ 内存和范围
⑤ 特殊知识点
- float在定义时,后面最好加一个f,float a = 3.14f;如果定义是float a = 3.14;会默认a是双精度,在程序运行时,需要转一下。
- 在C++中,无论是float还是double,小数输出时,默认显示6位有效数字。
- 科学计数法的表示方法:1) float a = 3e^2;//表示3*10^2 2)float b=3e^-2;//表示0.03
2.3 字符型
① 作用:用来表示文本信息
② 分类:字符、转义字符、字符串
③ 表示方法
字符:char 变量名 = ‘字符’; //用单引号
转义字符:一些字母前加"\"来表示常见的那些不能显示的ASCII字符,如\0,\t,\n等,就称为转义字符。常用的转义字符有1)\n 换行;2)\\反斜杠;3)\t加8个空格。
字符串:两种风格
1)C风格:char 变量名[] = "字符串"; //双引号
2)C++风格:string 变量名 = "字符串"; //需要包含头文件#include<string>
④ 内存和范围
一个字符占一个字节
⑤ 特殊知识点
- 字符是将对应的ASIC码放入到存储单元中,计算机内存的是对应的二进制数;
- 使用string时,需要包含头文件#include<string>。
2.4 布尔类型
① 作用:表示真或假
② 分类:bool
③ 表示方法:bool 变量名 = ‘true’ or 'false'
④ 内存和范围:只占一个字节,0或者1
3 常用相关的函数
3.1 sizeof函数
作用:可以用来统计数据所占内存;
语法:sizeof(变量)或者sizeof(变量类型)
int a;
int a_length_1 = sizeof(a);
int a_length_2 = sizeof(int);
int b[5]={1,2,3,4,5};
int b_length=sizeof(b)/sizeof(int);//求数组长度
3.2 数据输入
关键字:cin
语法:cin<<变量;
3.3 数据输出
关键字:cout
语法:cout<<变量<<endl; //endl表示换行