C++在C语言基础上的优化

目录

一、命名空间

1、命名空间的定义

2、命名空间的使用

二、输入&输出

三、缺省参数

1、缺省参数的概念

2、缺省参数的分类

四、函数重载

五、引用

1.引用的概念

2.引用的特性

3、引用和指针的区别

六、内联函数

七、基于范围的for循环


一、命名空间

        命名空间用来对标识符本地化,避免命名冲突。

1、命名空间的定义

        定义命名空间需要使用namespace关键字,后面跟命名空间的名字,然后接一对{}即可,{}里边为命名空间的成员。

        (1)、命名空间可以定义变量/函数/类型

//命名空间
namespace lbj
{//定义变量int rand = 10;//定义函数int Add(int left, int right){return left + right;}//定义类型struct Node{struct Node* next;int val;};
}

        (2)、命名空间可以嵌套定义

//2.命名空间的嵌套
namespace lbj
{int a;int b;int Add(int left, int right){return left + right;}namespace lbj_1{int c;int d;int Sub(int left, int right){return left - right;}}
}

        (3)、同一个工程中允许存在多个相同名称的命名空间,编译器会自动将所有同名命名空间合并成一个命名空间。一个命名空间就定义了一个新的作用域,命名空间中的所有内容都局限于该命名空间中。

2、命名空间的使用

        命名空间有三种使用方式:

        (1)、加命名空间名称及作用于限定符

lbj::a

        (2)、使用using将命名空间中的某个成员引入

using lbj::a;

        (3)、使用using namespace +命名空间名称引入

using namespace lbj;

二、输入&输出

        C++的输入和输出分别是:cin和cout,cin是标准输入对象,cout 是标准输出对象,使用时必须包含头文件<iostream>以及按命名空间使用方法使用std。

        cin和cout可以自动识别变量类型,不需要手动控制格式。

#include<iostream>
using namespace std;
int main()
{int a;double b;char c;//可以自动识别变量类型cin >> a;cin >> b >> c;cout << a << endl;//endl表示换行输出cout << b << " " << c << endl;return 0;
}

三、缺省参数

1、缺省参数的概念

        缺省参数是声明或定义函数时为函数的参数指定一个缺省值(即默认值)。在调用该函数时,如果没有指定实参则采用该形参的缺省值,否则使用指定的实参。

#include<iostream>
using namespace std;
void Func(int a = 0)
{cout << a << endl;
}
int main()
{Func();		//没有传参,使用参数的默认值(缺省值)Func(10);	//传参,使用指定的实参return 0;
}

2、缺省参数的分类

        (1)、全缺省参数:所有参数全部设定了缺省值

//全缺省参数
void Func(int a=1,int b=4,int c=7)

        (2)、半缺省参数:部分参数设定了缺省值

//半缺省参数
void Func(int a, int b, int c = 7)

        注意:半缺省参数必须从右往左依次给出,不能有间隔;缺省参数不能在函数的声明和函数定义中同时出现,一般采用设定在函数声明中,不设定在函数定义中;缺省值必须是常量或全局变量

四、函数重载

        C++允许在同一作用域中声明多个功能类似的同名函数,这些同名函数的形参列表(参数个数或参数类型或参数类型的顺序)不同,常用来实现功能类似数据类型不同的问题。函数重载即函数名相同,参数不同。

        参数类型不同:

//1.参数类型不同
int Add(int left, int right)
{return left + right;
}
double Add(double left, double right)
{return left + right;
}

        参数个数不同:

//2.参数个数不同
void f()
{cout << "f()" << endl;
}
void f(int a)
{cout << "f(int a)" << endl;
}

        参数类型的顺序不同:

//3.参数类型的顺序不同
void f(int a, char b)
{cout << "f(int a, char b)" << endl;
}
void f(char a, int b)
{cout << "f(char a, int b)" << endl;
}

        C++支持函数重载,而C语言不支持函数重载是因为C++是通过函数修饰规则来区分同名函数的,只要函数的参数不同,修试出来的名字也就不同,所以支持重载,而C语言没法识别同名函数,所以不支持函数重载。如果两个同名函数的参数是一样的,只有返回值不同是不能够成重载的。切记函数重载的关键是函数参数,不是返回值。

五、引用

1.引用的概念

        引用是给已经存在的变量取别名。引用变量和它所引用的实体变量共用一块内存空间,编译器不需要为引用变量开辟新的内存空间。

        类型+&+引用变量名=引用实体

void test()
{int a=10;int& ra=a;//引用变量ra是a的别名
}

2.引用的特性

        (1)引用在定义时必须初始化;

        (2)一个变量可以有多个引用;

        (3)引用一旦引用一个实体,就不能再引用其他实体;

        (4)引用的权限可以平移、可以缩小,但不能放大;

        (5)引用做函数参数,改变形参也会改变实参。引用在语法概念上是一个别名,和其引用实体共用同一快内存空间,但是在底层实现上,引用时按照指针的方式来实现的;

        (6)引用做返回值,如果函数返回,除了函数的作用域,返回对象还在(函数只运行了一次),则可以使用引用返回,如果返回对象已经还给系统(函数运行了不止一次),则必须使用传值返回,不能再使用引用返回。

3、引用和指针的区别

        (1)引用时一个变量的别名,指针存储变量的地址。

        (2)引用在定义时必须初始化,指针不用。

        (3)引用在引用一个实体之后就不能再引用其他实体,指针可以在任何时候指向任何一个同类型实体。

        (4)没有空引用,有空指针。

        (5)引用自加即引用的实体加1,指针自加即指针向后偏移一个类型的大小。

        (6)引用比指针使用起来相对更安全。

六、内联函数

        以inline修饰的函数叫做内联函数,编译时C++会在调用内联函数的地方展开函数体,没有函数调用建立栈帧的开销,内联函数可以提升程序的运行效率。

        inline是一种以空间换时间的做法,在编译阶段会用函数体替换函数调用,少了调用开销,提高程序运行效率,但是可能造成目标文件变大。

        inline对于编译器而言只是一个建议、一个请求,编译器可以选择忽略这个请求。一般函数规模较小、不是递归、频繁调用的函数使用内联。

        inline不建议函数声明和定义分离(指的是不同文件),会导致连接错误。

七、基于范围的for循环

        C++11中引入了基于范围的for循环。for循环后的括号有冒号‘:’分为两部分,第一部分是范围内用于迭代的变量,第二部分是被迭代的范围。   

//基于范围的for循环
#include<iostream>
using namespace std;
void test_for()
{int arr[] = { 1,3,5,7,9 };for (auto& e : arr){e *= 2;}for (auto e : arr){cout << e << " ";}cout << endl;
}
int main()
{test_for();return 0;
}

         注意:基于范围的for循环中的continue和break和普通循环类似用法

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/129691.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

穷举深搜暴搜回溯剪枝(4)

一)单词搜索: 直接在矩阵中依次找到特定字符串 79. 单词搜索 - 力扣&#xff08;LeetCode&#xff09; 画出决策树&#xff0c;只需要做一个深度优先遍历: 1)设计dfs函数:只需要关心每一层在做什么即可&#xff0c;从这个节点开始&#xff0c;开始去尝试匹配字符串的下一个字符…

使用Xshell远程访问工具连接到Linux

首先需要查看Linux地址&#xff0c;在Linux主界面中右键选择“Open in Terminal” 输入“ifconfig”指令查看IP地址 打开Xshell&#xff0c;输入相关信息&#xff0c;建立连接 点击连接&#xff0c;按照提示输入用户名 root和你自己安装centos7时设置的密码&#xff0c;用…

OpenCV_CUDA_VS编译安装

一、OpenCV 我这里是下载的OpenCV4.5.4&#xff0c;但是不知道到在vs里面build时一直报错&#xff0c;后面换了4.7.0的版本测试&#xff0c;安装成功。 Release OpenCV 4.5.4 opencv/opencv GitHub 这个里面有官方预编译好的OpenCV库&#xff0c;可以直接食用。 扩展包&am…

React 展开运算符

0x00 前言 CTF 加解密合集CTF Web合集网络安全知识库溯源相关 文中工具皆可关注 皓月当空w 公众号 发送关键字 工具 获取 0x01 展开运算符 1. 展开数组 <script type"text/javascript">let arr1 [1,3,5,7,9]let arr2 [2,4,6,8,10]console.log(...arr1)&l…

TCP IP网络编程(四) 基于TCP的服务器端、客户端

文章目录 理解TCP、UDPTCP/IP协议栈链路层IP层TCP/UDP层应用层 实现基于TCP的服务器端、客户端TCP服务器端的默认函数调用顺序进入等待连接请求状态受理客户端连接请求TCP客户端的默认函数调用顺序基于TCP的服务器端、客户端函数调用关系 实现迭代服务器端、客户端实现迭代服务…

RK3399平台开发系列讲解(内核调试篇)spidev_test工具使用

🚀返回专栏总目录 文章目录 一、环境二、执行测试三、回环测试四、字节发送测试五、32位数据发送测试沉淀、分享、成长,让自己和他人都能有所收获!😄 📢 在 Linux 系统上,“spidev_test” 是一个用于测试和配置 SPI(Serial Peripheral Interface)设备的命令行工具。…

Java拓展--空间复杂度和时间复杂度

空间复杂度和时间复杂度 文章目录 空间复杂度和时间复杂度空间复杂度时间复杂度**评价排序算法****时间频度****什么是时间频度****忽略常数项****忽略低次项****忽略系数** **时间复杂度****什么是时间复杂度****计算时间复杂度的方法****常见的时间复杂度** **常见的时间复杂…

Weblogic(CVE-2017-10271)与 Struts2(s2-045) 反序列化漏洞复现

文章目录 Java 反序列化漏洞复现weblogic环境搭建漏洞复现 Struts2(s2-045)环境搭建漏洞复现**漏洞利用** Java 反序列化漏洞复现 weblogic Weblogic < 10.3.6 ‘wls-wsat’ XMLDecoder 反序列化漏洞&#xff08;CVE-2017-10271&#xff09; ​ Weblogic的WLS Security组…

【ARM CoreLink 系列 2 -- CCI-400 控制器简介】

文章目录 CCI-400 介绍DVM 机制介绍DVM 消息传输过程TOKEN 机制介绍 下篇文章&#xff1a;ARM CoreLink 系列 3 – CCI-550 控制器介绍 CCI-400 介绍 CCI&#xff08;Cache Coherent Interconnect&#xff09;是ARM 中 的Cache一致性控制器。 CCI-400 将 Interconnect 和coh…

SUMPRODUCT函数

SUMPRODUCT函数返回相应范围或数组的个数之和。 默认操作是乘法&#xff0c;但也可以执行加减除运算。 本示例使用 SUMPRODUCT 返回给定项和大小的总销售额&#xff1a; SUMPRODUCT 匹配项 Y/大小 M 的所有实例并求和&#xff0c;因此对于此示例&#xff0c;21 加 41 等于 62。…

pytorch中的词性标注_seq2seq_比较naive的示例

一、各种用法_查漏补缺&#xff1a; 1.关于numpy中的argmax的用法&#xff1a; numpy之argmax()函数 - 知乎 (zhihu.com) 具体看这篇文章够了 二、代码注释&#xff1a; 参考&#xff1a; Sequence Models and Long Short-Term Memory Networks — PyTorch Tutorials 2.0.…

【1++的数据结构】之map与set(二)

&#x1f44d;作者主页&#xff1a;进击的1 &#x1f929; 专栏链接&#xff1a;【1的数据结构】 文章目录 一&#xff0c;前言二&#xff0c;红黑树的概念及其性质三&#xff0c;红黑树的插入四&#xff0c;红黑树的验证五&#xff0c;map与set的封装红黑树迭代器的实现map重载…

qt 正则表达式

以上是正则表达式的格式说明 以下是自己写的正则表达式 22-25行 是一种设置正则表达式的方式&#xff0c; 29-34行 : 29行 new一个正则表达式的过滤器对象 30行 正则表达式 的过滤格式 这个格式是0-321的任意数字都可以输入 31行 将过滤格式保存到过滤器对象里面 32行 将验…

快人一步进入智能新纪元,《新程序员006》来了!

文 | 王启隆 曾浩辰 出品 | 《新程序员》编辑部 亲爱的 CSDN 以及《新程序员》的读者朋友们&#xff0c;金秋将至&#xff0c;《新程序员006&#xff1a;人工智能新十年》也正式与大家见面&#xff01;现在点击下方封面&#xff0c;即可订阅&#xff0c;立即阅读电子书。精美…

UNIX网络编程卷一 学习笔记 第三十章 客户/服务器程序设计范式

开发一个Unix服务器程序时&#xff0c;我们本书做过的进程控制&#xff1a; 1.迭代服务器&#xff08;iterative server&#xff09;&#xff0c;它的适用情形极为有限&#xff0c;因为这样的服务器在完成对当前客户的服务前无法处理已等待服务的新客户。 2.并发服务器&#x…

Java笔记040-反射/反射机制、Class类

目录 反射(reflection) 一个需求引出反射 反射机制 Java反射机制原理图 Java反射机制可以完成 反射相关的主要类 反射机制的优点和缺点 反射调用优化-关闭访问检查 Class类 基本介绍 代码解释部分 类加载方法 应用实例&#xff1a;Class02.java 获取Class类对象 …

【17 > 分布式接口幂等性】2. Update的幂等性原理解析

一、 根据 唯一业务号去更新 数据的情况 1.1 原理 1.2 操作 1.3 实战 Stage 1&#xff1a;表添加 version 字段 Stage 2&#xff1a;前端 > 版本号放入隐藏域 Stage 3&#xff1a;后台 > 使用版本号作为更新条件 二、更新操作没有唯一业务号&#xff0c;可使用Tok…

RP9学习-1

一.基础 1.10个面板位置示意图&#xff1a; 2.常用英文 1.鼠标点击&#xff1a;click or tap 3.工作区 1.恢复默认工作区&#xff1a; view-->reset view 2.自定义工作区&#xff1a; 可以用鼠标左键拖动面板到独立的位置或者吸附到其他面板上 3.自定义工具栏 view-->T…

Adobe Acrobat Reader界面改版 - 解决方案

问题 日期&#xff1a;2023年9月 Adobe Acrobat Reader下文简称Adobe PDF Reader&#xff0c;此软件会自动进行更新&#xff0c;当版本更新至2023.003.20284版本后。 软件UI界面会大改版&#xff1a;书签页变成了右边、工具栏变到了左边、缩放按钮变到了右下角&#xff0c;如…

打造高效的私密论坛网站:Cpolar内网穿透+HadSky轻量级搭建指南

文章目录 前言1. 网站搭建1.1 网页下载和安装1.2 网页测试1.3 cpolar的安装和注册 2. 本地网页发布2.1 Cpolar临时数据隧道2.2 Cpolar稳定隧道&#xff08;云端设置&#xff09;2.3 Cpolar稳定隧道&#xff08;本地设置&#xff09;2.4 公网访问测试 总结 前言 经过多年的基础…