C/C++编程:基本内置类型

1060 篇文章 297 订阅

C++定义了一套包括算术类型和空类型(void)

算术类型(arithmetic type)

分类

分为两类

  • 整型
  • 浮点型

尺寸

  • 算术类型的尺寸在不同的机器上可能不一样的。
  • 尺寸不一样,意味着所能表示的数据范围也不一样

下表列出了C++标准规定的尺寸的最小值:

在这里插入图片描述

(1)bool类型: 取值真或者假
(2)字符类型:

  • char是最基本的字符类型,一般来讲,char的大小和一个机器字节一样
  • wchar_tchar16_tchar32_t等用于扩展字符集
    • wchar_t用于确保可以存放机器最大扩展字符集中的任意一个字符
    • char16_tchar32_t为Unicode字符集服务

(3) shortintlonglong long用于表示不同尺寸的整数。

  • C++规定:size(long long) >= size(long) >= size(int) >= size(short)

(4) floatdoublelong 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

指定字面值的类型

可以通过添加如下图前缀和后缀,可以改变整形、浮点型、字符型字面量值的默认类型
在这里插入图片描述
例子:

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值