C++查漏补缺与新标准(C++20,C++17,C++11)01 C++快速回顾(一)

本内容参考C++20高级编程

模块导入

C++ 20提供了对于模块的支持,用来代替之前的头文件机制

复制代码
//Helloworld.cpp
import <iostream>

int main(){
    std::cout<<"Hello World!"<<std::end;
    return 0;
}

如果在你的编译器中尚未支持模块,只需要将import声明替换为#include预处理指令

避免重复包含

使用预处理指令避免重复执行

复制代码
#ifndef MYHEADER_H
#define MYHEADER_H
// ... the contents of thhis header file
#endif

在现代编译器(大多数)中也支持使用 #pragma once 指令重写上述代码。

输入输出流

命名空间

命名空间中函数的调用

复制代码
//1
using namespace std;
int main(){    
    cout << "Hello World!";
}
//2
std::cout << "Hello World!";
//3
using std::cout;
int main(){    
    cout << "Hello World!";
}

命名空间的嵌套

嵌套的命名空间,即将一个名称空间放在另一个名称空间中

C++17前的写法:

复制代码
namespace MyLibraries{
    namespace Networking{
        namespace FTP{
            /*content*/
        }
    }
}

C++17后的写法

复制代码
namespace MyLibraries::Networking::FTP{/*content*/}

命名空间别名

可以为命名空间别名,换一个更简单的新名称

复制代码
namespace MyFTP = MyLibraries::Networking::FTP;

变量

数值极限

C++ 提供了定义在的类模板 std::numeric_limitsewq

复制代码
cout << "int:\n";
cout<< format(" Max int value:{}\n", numeric_limits< int>:: max( ));
cout<< format(" Min int value:{}\n", numeric_limits< int>:: min( ));
cout<< format(" Lowest int value:{}\n", numeric_limits< int>:: lowest( ));
cout <<"\ndouble:\n";
cout<< format(" Max double value:{}\n", numeric_limits< double>:: max( ));
cout<< format(" Min double value:{}\n", numeric_limits< double>:: min( ));
cout<< format(" Lowest double value:{}\n", numeric_limits< double>:: lowest( ));
上面的代码段在我的系统上的输出如下:
int:
Max int value:2147483647
Min int value:-2147483648
Lowest int value:-2147483648
double:
Max double value:1.79769e+308
Min double value:2.22507e-308
Lowest double value:-1,79769e+308
注意min()和lowest()之间的区别。对于一个整数,最小值等于最低值。然而对于浮点类型来说,最小值表

类型转换

类型转换有如下三种

复制代码
float MyFloat {3,14f};
    int i1 { (int)MyFloat };
    int i2 { int(MyFloat) };
    int i3 { static_cast<int>(MyFloat)};

第一种数值转换的方法来源于C

第二种数值转换的方法很少使用

第三种数值转换的方法是最推荐的方法

枚举类型

复制代码
enum class PieceType{
    King = 1,
    Queen,
    Rook = 10,
    Pawn
};

如果没有为当前的枚举成员赋值,编辑器会末尾将上个枚举成员的值递增1,再赋予当前的枚举成员。

枚举对象不会自动超出封闭的作用域,意味着不同的强枚举类型可以有同名的枚举值。

复制代码
enum class State{Unknow,Stateed,Finished};
enum class Error{None,BadInput,DiskFull,Unknow};

这样就意味着必须使用必须使用枚举值的全名。

C++ 20: 从C++20开始,可以使用using enum声明来避免使用枚举值的全名,这是一个例子

复制代码
using enum PieceType;
PieceType piece{King};

另外可以用using声明避免某个特定枚举值的全名,但是使用其他枚举值仍然需要使用全名

复制代码
using enum PieceType::king;
PieceType piece{King};
piece = PieceType::Queen;

C++表达式

C++表达式求值逻辑

C++对表达式求值采用短路逻辑,这意味着一旦最终结果可确定,就不对表达式的剩余部分求值

复制代码
bool result{bool1 || bool2 || (i>7) || (27/13%i+1)<2 }

三向比较运算符<=>(C++20)

三向比较运算符用于确定两个值的大小顺序,返回类枚举类型,定义在和std名称空间中。 如果操作数是整数类型,返回强排序。

如果操作数是浮点类型,返回偏序。

函数

函数返回类型的推断

复制代码
auto addNumbers(int number1,int number2){
    return number1+number2;
}

要求:

复制代码
1.函数体内可以有多个return语句,但是他们必须被解释为同一类型
2.函数可以进行递归调用,但是该函数的第一条return语句必须是非递归调用

当前函数的名称(预定义的局部变量func

每个函数都有一个预定义的局部变量func ,其中包含函数的名称

Image

Image

相关推荐
chenyuhao20243 分钟前
MySQL索引特性
开发语言·数据库·c++·后端·mysql
雨中飘荡的记忆21 分钟前
财务对账系统设计与实现
java
0***h94221 分钟前
使用 java -jar 命令启动 Spring Boot 应用时,指定特定的配置文件的几种实现方式
java·spring boot·jar
雨中飘荡的记忆24 分钟前
布式事务详解:从理论到实践(RocketMQ + Seata)
java·rocketmq
小龙报31 分钟前
【算法通关指南:数据结构和算法篇 】队列相关算法题:3.海港
数据结构·c++·算法·贪心算法·创业创新·学习方法·visual studio
i***486136 分钟前
微服务生态组件之Spring Cloud LoadBalancer详解和源码分析
java·spring cloud·微服务
zzlyx9937 分钟前
用C#采用Avalonia+Mapsui在离线地图上插入图片画信号扩散图
java·开发语言·c#
Aevget40 分钟前
MyEclipse全新发布v2025.2——AI + Java 24 +更快的调试
java·ide·人工智能·eclipse·myeclipse
辞旧 lekkk1 小时前
【c++】封装红黑树实现mymap和myset
c++·学习·算法·萌新
一 乐1 小时前
购物|明星周边商城|基于springboot的明星周边商城系统设计与实现(源码+数据库+文档)
java·数据库·spring boot·后端·spring