C++定义了一套包括算术类型和空类型(void)
算术类型(arithmetic type)
分类
分为两类
- 整型
- 浮点型
尺寸
- 算术类型的尺寸在不同的机器上可能不一样的。
- 尺寸不一样,意味着所能表示的数据范围也不一样
下表列出了C++标准规定的尺寸的最小值:
(1)bool类型: 取值真或者假
(2)字符类型:
char
是最基本的字符类型,一般来讲,char的大小和一个机器字节一样wchar_t
、char16_t
、char32_t
等用于扩展字符集wchar_t
用于确保可以存放机器最大扩展字符集中的任意一个字符char16_t
、char32_t
为Unicode字符集服务
(3) short
、int
、long
、long long
用于表示不同尺寸的整数。
- C++规定:size(
long long
) >= size(long
) >= size(int
) >= size(short
)
(4) float
、double
、long double
表示不同精度的小数
带符号类型、无符号类型
- 带符号类型可以表示正数、负数、0
- 无符号类型仅能表示大于等于0的值
除去bool型和扩展字符集以外,其他整形都可以分为带符号和无符号两种:
- char分为三种:char、signed char、unsigned char。
- 虽然字符型有三种,但是字符的表现形式只有两种:带符号、无符号
- 编译器会决定char表现为signed char还是unsigned char
- int、short、long、long long都是带符号的
- 通过在这些类型名前面加unsigned就可以得到无符号类型。比如unsigned long
- 其中unsigned int可以简写为unsigned
尽量不要使用无符号类型进行算术表达式,这超级容易出错(带符号数会自动转换成无符号数):
#include <iostream>
using namespace std;
int main()
{
unsigned u = 10;
int i = -42;
cout << u + i << endl; // 4294967264
cout << i + u << endl; // 4294967264
unsigned u1 = 42, u2 = 10;
cout << u1 - u2 << endl; // 32
cout << u2 - u1 << endl; // 4294967264
}
也不要用无符号写for循环(很容易死循环):
#include <iostream>
using namespace std;
int main()
{
for (unsigned int u = 10; u >= 0; --u) {
cout << u << endl;
}
}
如何选择类型
- 如果值不可能为负数,选用无符号类型
- 使用int执行整数运算,如果数值超过了int就选择long long
- 不要使用char或者bool去运算,它们仅用于储存值
- 因为char类型在一些机器上可能有符号,在另一些机器上就可能变成无符号了
- 浮点数运算请用double
- float通常精度不够,而且一些机器上,双精度可能比单精度更快
- long double精度太高,而且消耗大
类型转换
C++中有时候会自动进行类型转换:
bool b = 42; // 真
int i = b; //i = 1
i = 3.14 ; // 3
double p = i; // 3.0
unsigned char c = -1; //如果char占8bit,c = 255
signed char c1 = 256; // 如果char占8bit,c 未定义
- 非bool类型---->bool,初始值为0的结果是false,否则true
- bool —> 非bool类型,初始值为false时结果0,否则为1
- 浮点数----》正数,保留小数点之前的部分
- 整数值–》浮点数,小数部分为0。当整数空间大于浮点数的容量时,精度会损失
请避免未定义行为,不要写依赖于环境(不可移植)的行为
字面型常量
整数和浮点型字面值
整数字面值有三种形式:
- 十进制(默认int类型)
- 八进制(类型根据值不同而不同)
- 十六进制(类型根据值不同而不同)
20 // 十进制
024 // 八进制
0x14 // 十六进制
浮点数字面值表现为一个小数或者指数(默认double 类型)
3.14159
3.14159E0
0.
0e0
.001
字符型字面量值
字符和字符串字面值
'a' // 字符字面值
"hello world" // 字符串字面值
- 字符串字面值的类型实际上是由常量字符构成的数组。
- 编译器会在每个字符串的结尾处添加一个空字符
\0
。因此,字符串字面值的实际长度比它的内容多1
sizeof('A'); // 1
sizeof("A"); // 2
- 如果两个字符串字面值位置紧邻而且仅有空格、缩进、换行符分割,则实际上他们是一个整体
std::cout <<"a really, really long string literal"
"that spancs tow lines\n";
转义字符
有两类字符程序员不能直接使用
- 不可打印字符,因为它们没有可视的图符
- 在C++语言中有特殊含义的字符(单引号、双引号,问号,反斜线),这个时候需要用到转义字符。转义字符均已
\
开始。C++语言规定的转义字符包括:
注意:
sizeof(转义字符) = 1
指定字面值的类型
可以通过添加如下图前缀和后缀,可以改变整形、浮点型、字符型字面量值的默认类型
例子: