C++排雷:15.auto和decltype的区别

auto和decltype都是类型推断的方式,但又有一定的区别:

1.编译器的作用

  • auto类型说明符 通过 编译器计算变量的初始值 来推断其类型
  • 而decltype是让编译器分析其表达式推断其类型,并不是计算表达式的值。

2.编译器推断出来的auto类型与初始值类型可能有出入,编译器会适当地改变其结果使auto更符合初始化规则。

  • auto会忽略顶层const而把底层留下来。
#include<iostream>
#include<string>
using namespace std;
int main()
{
	const string str01 = "asdad";
	for (auto  a :str01)//a为char类型
	{
		a = '1';//成功赋值
	}
	return 0;
}
  • 而decltype会保留变量的顶层const。
#include<iostream>
#include<string>
using namespace std;
int main()
{
	const string str01 = "asdad";
	for (decltype(str01)  a :str01)//a为const char 类型,本迭代无法进行
	{
		a = '1';//const无法赋值
	}
	return 0;
}

3.与auto不同,decltype的结果类型与表达式的形式密切相关

  • 如果变量名不加括号,结果就是该变量的类型

  • 如果加上了一层或多层括号,则编译器会推断得到引用类型。

一个实例:

#include<iostream>
#include<typeinfo>

int main()
{
	int a = 3;
	auto c1 = a;
	decltype(a) c2 = a;
	decltype((a)) c3 = a;

	const int d = 5;
	auto f1 = d;
	decltype(d)f2 = d;


	std::cout << typeid(c1).name() << std::endl;
	std::cout << typeid(c2).name() << std::endl;
	std::cout << typeid(c3).name() << std::endl;
	std::cout << typeid(f1).name() << std::endl;
	std::cout << typeid(f2).name() << std::endl;

	c1++;
	c2++;
	c3++;
	f1++;
	f2++;

	std::cout << a << " " 
	<< c1 << " " 
	<< c2 << " " 
	<< c3 << " " 
	<< f1 << " " 
	<< f2 << std::endl;

	return 0;
}

VS2019自动提示:
在这里插入图片描述
因为decltype(d)f2 = d;保留了const int d的顶层,所以f2为const int型,无法自加;

而auto f1 = d;忽略了const int d的顶层,所以f1为 int型,可以自加;

注释掉f2++;后的运行结果如下:

int
int
int
int
int
4 4 4 4 6 5

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值