【C++11特性篇】盘点C++11中三种简化声明的方式【auto】【decltype】【nullptr】(3)

简介: 【C++11特性篇】盘点C++11中三种简化声明的方式【auto】【decltype】【nullptr】(3)

一.auto&范围for

  • 在C++98中auto是一个存储类型 的说明符,表明变量是局部自动存储类型 ,但是局部域中定义局部的变量默认就是自动存储类型,所以auto就没什么价值了。
  • C++11中废弃auto原来的用法,将其用于实现自动类型推断。这样要求必须进行显示初始化 ,让编译器将定义对象的类型设置为初始化值的类型。
  • 在C++中常与【范围for】搭配使用
int main()
{
  int i = 10;
  auto p = &i;
  auto pf = malloc;
  //auto x; 不能单独用
}
int main()
{
    vector<int> v1 = { 1,2,3,4,54 };
    for (auto e : v2)//范围for遍历
    {
        cout << e << " ";
    }
    cout << endl;
}

二.decltype——类型相关

【1】typeid()——只能看(打印)类型,但不能用

  • typeid 推出可以推出参数是什么类型,但是只能看不能用
  • typeid(pf).name()
int main()
{
    int i = 10;
    auto p = &i;
    auto pf = malloc;
    cout << typeid(p).name() << endl;
    cout << typeid(pf).name() << endl;
}

【2】decltype——推出对象的类型后:(1)再定义变量(2)或者作为模板实参

  • 关键字decltype将变量的类型声明为表达式指定的类型
    有以下两种主要用法:
  1. 单纯先定义一个变量出现
  2. 作为模板实参
int main()
{
    auto pf = malloc;
    auto pf1 = pf;
    // decltype推出对象的类型,再定义变量,或者作为模板实参
    // 单纯先定义一个变量出现
    decltype(pf) pf2;
    //作为模板实参
    B<decltype(pf)> bb1;
    //作为模板实参
    const int x = 1;
    double y = 2.2;
    B<decltype(x* y)> bb2;
}

三.nullptr——表示空指针

  • 由于C++中NULL被定义成字面量0,因为0既能指针常量,又能表示整形常量。 这样就可能回带来一些问题,比如下图所示
int main()
{
  int* p = NULL; // int* p = 0;             NULL被隐式类型转换成0
  func(NULL); // func(0);
  return 0;
}
  • 所以出于清晰和安全的角度考虑,C++11中新增了nullptr,用于表示空指针


相关文章
|
8月前
|
编译器 C++ 容器
【c++11】c++11新特性(上)(列表初始化、右值引用和移动语义、类的新默认成员函数、lambda表达式)
C++11为C++带来了革命性变化,引入了列表初始化、右值引用、移动语义、类的新默认成员函数和lambda表达式等特性。列表初始化统一了对象初始化方式,initializer_list简化了容器多元素初始化;右值引用和移动语义优化了资源管理,减少拷贝开销;类新增移动构造和移动赋值函数提升性能;lambda表达式提供匿名函数对象,增强代码简洁性和灵活性。这些特性共同推动了现代C++编程的发展,提升了开发效率与程序性能。
350 12
|
10月前
|
存储 机器学习/深度学习 编译器
【C++终极篇】C++11:编程新纪元的神秘力量揭秘
【C++终极篇】C++11:编程新纪元的神秘力量揭秘
|
编译器 程序员 定位技术
C++ 20新特性之Concepts
在C++ 20之前,我们在编写泛型代码时,模板参数的约束往往通过复杂的SFINAE(Substitution Failure Is Not An Error)策略或繁琐的Traits类来实现。这不仅难以阅读,也非常容易出错,导致很多程序员在提及泛型编程时,总是心有余悸、脊背发凉。 在没有引入Concepts之前,我们只能依靠经验和技巧来解读编译器给出的错误信息,很容易陷入“类型迷路”。这就好比在没有GPS导航的年代,我们依靠复杂的地图和模糊的方向指示去一个陌生的地点,很容易迷路。而Concepts的引入,就像是给C++的模板系统安装了一个GPS导航仪
362 59
|
安全 编译器 C++
【C++11】新特性
`C++11`是2011年发布的`C++`重要版本,引入了约140个新特性和600个缺陷修复。其中,列表初始化(List Initialization)提供了一种更统一、更灵活和更安全的初始化方式,支持内置类型和满足特定条件的自定义类型。此外,`C++11`还引入了`auto`关键字用于自动类型推导,简化了复杂类型的声明,提高了代码的可读性和可维护性。`decltype`则用于根据表达式推导类型,增强了编译时类型检查的能力,特别适用于模板和泛型编程。
164 2
|
存储 编译器 C++
【C++】面向对象编程的三大特性:深入解析多态机制(三)
【C++】面向对象编程的三大特性:深入解析多态机制
158 1
|
存储 编译器 C++
【C++】面向对象编程的三大特性:深入解析多态机制(二)
【C++】面向对象编程的三大特性:深入解析多态机制
158 1
|
编译器 C++
【C++】面向对象编程的三大特性:深入解析多态机制(一)
【C++】面向对象编程的三大特性:深入解析多态机制
171 1
C++ 20新特性之结构化绑定
在C++ 20出现之前,当我们需要访问一个结构体或类的多个成员时,通常使用.或->操作符。对于复杂的数据结构,这种访问方式往往会显得冗长,也难以理解。C++ 20中引入的结构化绑定允许我们直接从一个聚合类型(比如:tuple、struct、class等)中提取出多个成员,并为它们分别命名。这一特性大大简化了对复杂数据结构的访问方式,使代码更加清晰、易读。
185 0
|
存储 编译器 C++
【C++】面向对象编程的三大特性:深入解析继承机制(三)
【C++】面向对象编程的三大特性:深入解析继承机制
205 0
|
编译器 C++
【C++】面向对象编程的三大特性:深入解析继承机制(二)
【C++】面向对象编程的三大特性:深入解析继承机制
169 0