【C++入门】输入输出、命名空间、缺省参数、函数重载、引用、内联函数、auto、基于范围的for循环

目录

命名空间

命名空间的定义

命名空间的使用

输入输出

缺省参数

函数重载

引用

 常引用

引用的使用场景 

内联函数

auto

基于范围的for循环


命名空间

请看一段C语言的代码:

#include <stdio.h>
#include <stdlib.h>int rand = 10;int main()
{printf("%d ", rand);return 0;
}

运行结果:

这就是自己定义的变量和库里面的函数冲突了,C语言无法解决这类问题,C++中的命名空间就是为解决这一类问题而生的。 

命名空间存在的重要意义就是为了避免命名冲突。接下来我们先了解命名空间的定义,再使用命名空间去解决这类问题。

命名空间的定义

命名空间的定义需要用到关键字namespace,格式为:

namespace 命名空间的名字

{

        / /…… 

}

例如:

namespace pcz
{int Add(int x, int y){return x + y;}
}

 命名空间中可以定义变量、函数、类等。

命名空间的使用

首先,用命名空间来解决上述命名冲突的问题。

namespace pcz
{int rand = 20;//把变量放到自己的命名空间里
}int main()
{printf("%d ", pcz::rand);return 0;
}

运行结果:

这回就没问题了。 上述代码中的符号 :: 是作用域限定符,因为在我们定义一个命名空间时,就定义了一个新的作用域,限定符前面的内容就是在告诉编译器到哪去找相应的变量、函数以及类。如果作用域限定符前面啥也没写,那么就默认到局部和全局中去找对应的变量,不会到命名空间里找。

命名空间支持嵌套。

namespace pcz
{int rand = 20;namespace ch{int Add(int x, int y){return x + y;}}
}int main()
{printf("%d ", pcz::rand);printf("%d ", pcz::ch::Add(1, 2));return 0;
}

命名空间的三种使用方式

一、用作用域限定符进行访问

二、全局展开——using namespace std;

三、部分展开——using std::cout; 

输入输出

使用标准输出对象cout(控制台)和标准输入对象(键盘)时,必须包含头文件<iostream>,以及对应的命名空间。

#include <iostream>
using namespace std;int main()
{int i = 0;cin >> i;cout << i;return 0;
}

<< : 流插入运算符

>> : 流提取运算符

cin、cout的可以自动识别类型,不用在像C语言一样需要占位符%d、%f等。 

缺省参数

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

例如:

#include <iostream>
using namespace std;int Add(int x = 1, int y = 1)
{return x + y;
}int main()
{cout << Add() << endl;return 0;
}

缺省值的使用应注意以下几个事项:

一、半缺省参数必须依次从右往左给,不能间隔给

正确写法:

#include <iostream>
using namespace std;int Add(int x, int y = 1)
{return x + y;
}int main()
{cout << Add(2) << endl;return 0;
}

错误写法:

#include <iostream>
using namespace std;int Add(int x = 3, int y)
{return x + y;
}int main()
{cout << Add(2) << endl;return 0;
}

 

二、缺省参数不能再函数声明和定义是同时出现,如果遇到声明和定义分离,那就在声明时给缺省值

三、缺省值必须是常量或者全局变量

四、C语言不支持 

函数重载

函数重载是C++的一个特性,允许在同一个作用域中定义多个同名函数,但这些函数的参数列表必须不同。编译器通过函数的参数列表来区分各个重载的函数。参数列表不同包括:参数个数不同、参数类型不同、参数顺序不同。

通过函数名修饰后,同名但不同参数列表的函数经修饰后的函数名不同,这样编译器就可以区分重载函数。C语言不支持重载函数,C语言函数名的存储是直接转换使用函数名,所以不支持重载。而C++是通过函数修饰规则来区分,只要参数不同,修饰出来的名字就不一样,就支持了重载。

#include <iostream>
using namespace std;int Add(int x, int y)
{return x + y;
}double Add(double x, double y)
{return x + y;
}int main()
{cout << Add(1, 1) << endl;cout << Add(1.2, 1.4) << endl;return 0;
}

引用

引用是给已存在变量取了一个别名,引用改变,实体也跟着改变,格式为:类型& 。注意,引用类型必须和引用实体是同种类型。

示例:


int main()
{int a = 1;int& b = a;return 0;
}

引用的特性 

一、引用在定义时必须初始化

二、一个变量可以有多个引用

三、引用一旦引用一个实体,再也不能引用其他实体了

第一个特性的演示:

int main()
{int a = 1;int& b; //未初始化引用return 0;
}

 

第三个特性演示:

 

int main()
{int a = 1;int& b = a;int c = 20;b = c;//此处不是在改变b的引用实体,而是把c的值赋给acout << a << endl;return 0;
}

 

 

 常引用

int main()
{const int a = 1;int& b = a;return 0;
}

运行结果:

这里涉及到了权限的问题。

在指针和引用中,赋值或者初始化时,权限可以保持或缩小,但不能放大。 

正确写法:

int main()
{const int a = 1;const int& b = a;return 0;
}

引用的使用场景 

一、做参数 

void Swap(int& a, int& b)
{int tmp = a;a = b;b = tmp;

二、做返回值

int& Count()
{static int n = 0;n++;// ...return n;
}

 如果出了函数作用域,返回对象还未还给操作系统,则可以用引用返回。否则,使用传值返回。

三、传值和传引用的效率分析

作为函数参数时,如果传值,函数不会直接传递实参本身,而是传递实参的一份临时拷贝。

作为返回值时,如果传值,也不会将变量直接返回,而是返回它的一份临时拷贝。

因此,传值的效率是比较低的,尤其是参数和返回值类型较大的时候。

如果传引用,因为引用是被引用实体的别名,不会进行拷贝,所以效率较高。

引用和指针的不同点

一、引用概念上定义一个变量的别名,指针存储一个变量的地址。

二、引用在定义是必须初始化,指针没有要求。

三、引用在初始化时引用一个实体后,就不能再引用其他实体了,而指针可以在任何时候改变指向。

四、没有NULL引用,但有NULL指针。

五、在sizeof中含义不同,引用结果为引用类型的大小,但指针始终是地址空间所占的字节数。

六、引用自加即引用的实体增加1,指针自加即指针向后偏移一个类型的大小。

七、有多级指针,但没有多级引用。

八、访问实体方式不同,指针需要显式解引用,引用编译器自己处理。

九、引用比指针使用起来更安全。

内联函数

以inline修饰的函数叫做内联函数,编译时C++编译器会在调用内联函数的地方展开,没有函数调用建立栈帧的开销,提升程序运行的效率。缺点是:可能会使目标文件变大。

inline对于编译器而言只是一个建议,不同编译器关于inline实现机制可能不同。

适用:函数规模小、非递归、频繁调用。

内联函数不建议声明和定义分离,因为内联函数会在调用的地方展开,没有地址,如果声明和定义分离,那么在链接的时候会报错。

 

auto

自动推到类型。

int main()
{auto i = 10;cout << i << endl;return 0;
}

注意事项:

使用auto定义变量时,必须对其进行初始化,编译器会根据初始化表达式自动推到它的实际类型,然后会用实际类型替换auto。 

auto与指针和引用结合起来使用:

int main()
{int x = 0;auto a = &x;auto* b = &x;auto& c = x;return 0;
}

用auto声明指针类型时,auto和auto*没有区别,但声明引用时,必须加上&。 

int main()
{auto a = 1, b = 2, 4;return 0;
}

以上这种写法是错误的。在同一行定义多个变量时,这些变量必须是相同的类型,否则编译器会报错。因为编译器实际只对第一个类型进行推导,然后用推导出来的类型定义其他变量。

auto不能作为函数的参数。

auto不能用来声明数组。 

基于范围的for循环

传统遍历数组的方式:

int main()
{int array[] = { 1,2,3,4,5,6 };int n = sizeof(array) / sizeof(int);for (int i = 0; i < n; i++){cout << array[i] << endl;}return 0;
}

范围for:

int main()
{int array[] = { 1,2,3,4,5,6 };int n = sizeof(array) / sizeof(int);for (auto e : array){cout << e << endl;}return 0;
}

 for循环后的括号由 :分成两部分,第一部分是范围内用于迭代的变量,第二部分则表示被迭代的范围。


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

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

相关文章

java打家劫舍 1 (力扣Leetcode 198)

打家劫舍 1 力扣原题链接 问题描述 你是一个专业的小偷&#xff0c;计划偷窃沿街的房屋。每间房内都藏有一定的现金&#xff0c;影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统&#xff0c;如果两间相邻的房屋在同一晚上被小偷闯入&#xff0c;系统会自动报…

修改aws账户的密码和MFA

要使用AWS CLI删除当前账户的多因素认证(MFA)设备并修改密码&#xff0c;你需要先确保已安装并配置了AWS CLI&#xff0c;并且你的账户有足够的权限执行这些操作。下面是如何分步进行的指导&#xff1a; 1. 删除MFA设备 首先&#xff0c;你需要找出MFA设备的序列号或ARN。可以…

《堕落的审判》吵架台词

一个人没有做某件事的原因就是这个人没有做这件事&#xff0c;与其他任何原因没有关系。所有的原因都是找理由&#xff0c;都是替罪的羔羊&#xff0c;都是自我麻醉的毒药&#xff0c;都是在饮鸩止渴。 愤怒的本质就是对自我无能的控诉。 (Sandra)-What do you expect me to do…

图论-最短路

一、不存在负权边-dijkstra算法 dijkstra算法适用于这样一类问题&#xff1a; 从起点 start 到所有其他节点的最短路径。 其实求解最短路径最暴力的方法就是使用bfs广搜一下&#xff0c;但是要一次求得所有点的最短距离我们不可能循环n次&#xff0c;这样复杂度太高&#xf…

Docker + Nginx 安装

安装Docker 1.防火墙 2.yum源 3.安装基础软件 更新yum源 wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo yum clean all #清除yum源缓存 yu…

【JavaScript编程】forEach跳出循环

在JavaScript中&#xff0c;forEach函数用于遍历数组中的每一个元素&#xff0c;并对每个元素执行一次回调函数。然而&#xff0c;forEach函数并没有内置的方法可以直接跳出整个循环&#xff0c;因为它设计之初就是为了确保每个元素都会被处理。但是&#xff0c;你可以通过一些…

每天学习python30分钟(第二天)

1.字典&#xff1a; 相当与数据结构 定义与访问 tinydict {Name: Zara, Age: 7, Class: First}print("tinydict[Name]: ", tinydict[Name]) print("tinydict[Age]: ", tinydict[Age]) tinydict[Name]: Zara tinydict[Age]: 7 也可以 tinydict1 { …

推挽输出与开漏输出

推挽输出与开漏输出 文章目录 推挽输出与开漏输出前言一、推挽输出二、开漏输出总结 前言 在使用GPIO口时&#xff0c;会遇到两种配置&#xff0c;一种叫推挽输出&#xff0c;一种叫开漏输出&#xff0c;今天就简聊一聊这两种模式的差异和选择。 一、推挽输出 如图所示&#…

力扣 1035. 不相交的线

题目来源&#xff1a;https://leetcode.cn/problems/uncrossed-lines/description/ C题解&#xff1a;经过细细一推导&#xff0c;就发现跟力扣 1143. 最长公共子序列-CSDN博客 换汤不换药。 直线不能相交&#xff0c;说明元素顺序不能改变&#xff0c;求可以绘制的最大连线数…

【数据结构与算法】二叉树遍历、判断和 diff 算法

遍历 深度优先遍历 function Node(value) {this.value valuethis.left nullthis.right null }let a new Node(a) let b new Node(b) let c new Node(c) let d new Node(d) let e new Node(e) let f new Node(f) let g new Node(g) a.left c a.right b c.l…

2024年3月29日西山居游戏运维开发面经

1&#xff0c;请做一下自我介绍吧&#xff08;简短的说了一下自己的情况&#xff0c;包括姓名&#xff0c;教育情况&#xff0c;来自什么地方&#xff09; 2&#xff0c;你刚有提到《尘白禁区》&#xff0c;你从开服就玩的吗&#xff1f; 3&#xff0c;你的简历上有写k8s&…

【Linux的进程篇章 - 冯诺依曼的体系结构】

Linux学习笔记---005 Linux冯诺依曼体系结构理解1、冯诺依曼体系结构1.1、冯诺依曼体系结构1.2、硬件层面1.3、数据层面1.4、那么冯诺依曼体系能干什么呢&#xff1f; 2、操作系统(Operastor System)2.1、概念2.2、操作系统层的核心功能 3、进程的初步理解 Linux冯诺依曼体系结…

动态规划-最长回文子串

动态规划-最长回文子串 原题描述解答中心移动思想代码实现复杂度分析时间复杂度空间复杂度 动态规划思想代码实现复杂度分析时间复杂度空间复杂度 突然觉得很有必要将学过的内容记录下来&#xff0c;这样后续在需要用到的时候就可以避免从头进行学习&#xff0c;而去看自己之前…

鸿蒙OS开发实例:【ArkTS类库多线程I/O密集型任务开发】

使用异步并发可以解决单次I/O任务阻塞的问题&#xff0c;但是如果遇到I/O密集型任务&#xff0c;同样会阻塞线程中其它任务的执行&#xff0c;这时需要使用多线程并发能力来进行解决。 I/O密集型任务的性能重点通常不在于CPU的处理能力&#xff0c;而在于I/O操作的速度和效率。…

ESP8266 WiFi物联网智能插座—上位机软件实现

1、软件架构 上位机主要作为下位机数据上传服务端以及节点调试的控制端&#xff0c;可以等效认为是专属版本调试工具。针对智能插座协议&#xff0c;对于下位机进行可视化监测和管理。 软件技术架构如下&#xff0c;主要为针对 Windows 的PC 端应用程序&#xff0c;采用WPF以及…

HCIA复习

OSI --开放式系统互联参考模型 --- 7层参考模型 TCP/IP协议栈道 --- 4层或5层 OSI&#xff1a; 应用层 抽象语言 -->编码 表示层 编码-->二进制 表示层以下都是二进制-----data&#xff08;数据&#xff09; 会话层 提供应用程序的会话地址 上三层为应用…

七、函数的使用方法

函数的调用 nameinput&#xff08;&#xff09;#输入参数并赋值name print&#xff08;name&#xff09;#d打印name 格式&#xff1a;返回值函数名&#xff08;参数&#xff09; def get_sum(n):#形式参数计算累加和:param n::return: sumsum0for i in range(1,n1):sumiprint…

echarts 图表/SVG 图片指定位置截取

echarts 图表/SVG 图片指定位置截取 1.前期准备2.图片截取3.关于drawImage参数 需求&#xff1a;如下图所示&#xff0c;需要固定头部legend信息 1.前期准备 echarts dom渲染容器 <div :id"barchart id" class"charts" ref"barchart">&…

深入探索位图技术:原理及应用

文章目录 一、引言二、位图&#xff08;Bitset&#xff09;基础知识1、位图的概念2、位图的表示3、位图操作 三、位图的应用场景1、数据查找与存储2、数据去重与排序 四、位图的实现 一、引言 位图&#xff0c;以其高效、简洁的特性在数据处理、存储和检索等多个领域发挥着举足…

React Hooks的出现解决了什么问题?

React Hooks是React 16.8版本引入的一个革命性新特性&#xff0c;它极大地改变了我们编写React组件的方式&#xff0c;并解决了许多长期存在的问题。Hooks的引入不仅简化了状态逻辑的管理&#xff0c;还提高了代码的可读性和可维护性。 一、React Hooks解决了什么问题&#xf…