命名空间,缺省参数和函数重载

2024-06-04 12:36

本文主要是介绍命名空间,缺省参数和函数重载,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言:本文章主要介绍一些C++中的小语法。

目录

命名空间

namespace的使用

访问全局变量

namespace可以嵌套

 不同文件中定义的同名的命名空间可以合并进一个命名空间,并且其中不可以有同名的变量

C++中的输入和输出

缺省参数(默认参数)

缺省参数又分为全缺省和部分缺省

既有声明又有定义的情况下

函数重载

不同作用域下的函数可以同名

调用歧义问题:

为什么C不支持函数重载,C++支持?


命名空间

为什么要有命名空间?

命名空间是解决C语言中命名重复的问题

比如,以下代码(在c++环境下运行)的情况:

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

在C语言中rand是一个函数名,而在该代码中定义了一个与rand函数名重名的变量。

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

以上代码的打印结果是:

 

为什么是1呢?

在C语言中局部优先,所以打印的是main函数中rand的值。

为什么没有报变量重定义的错呢?

因为rand这个变量是在不同的域中定义的,一个定义在局部域中,另一个定义在全局域中,所以没有命名重复。


 

namespace的使用

开辟一个命名空间域,可以在里面定义变量,函数,结构体等。与其他域中定义的一样的名字的变量不构成重名。

#include <stdio.h>namespace _name
{int rand = 0;
}int rand = 1;int main()
{int rand = 2;printf("%d", rand);
}

 下面代码的运行结果是:

另一份代码:

#include <stdio.h>namespace _name
{int rand = 0;
}//int rand = 1;int main()
{//int rand = 2;printf("%d", rand);
}

上面的代码会报错:rand未定义 

 

为什么呢?

编辑器的默认查找规则:

1.先去局部域中去找

2.去全局域中去找

3.但不去命名空间域中去查找。

那么如何使用命名空间中定义的变量,结构体,函数等呢?

:: 两个冒号是域作用限定符

1.全展开命名空间

#include <stdio.h>namespace _name
{int rand = 0;
}
using namespace _name;//展开命名空间//int rand = 1;int main()
{//int rand = 2;printf("%d", rand);
}

建议:在大型项目中不建议直接全展开,在平时刷题时写代码时随便用。

展开命名空间的本质:影响查找规则:

1.先去局部域中去找

2.去全局域中去找

3.但不去命名空间域中去查找。

 

2.指定访问

#include <stdio.h>namespace _name
{int rand = 0;
}
//using namespace _name;//int rand = 1;int main()
{//int rand = 2;//指定访问printf("%d", _name::rand);
}

3.指定某一个展开

#include <stdio.h>namespace _name
{int rand = 0;
}
//using namespace _name;
using _name::rand;//指定某一个展开//int rand = 1;int main()
{//int rand = 2;//printf("%d", _name::rand);printf("%d", rand);
}

访问全局变量

#include <stdio.h>namespace _name
{int rand = 0;
}
//using namespace _name;
using _name::rand;int rand = 1;int main()
{//int rand = 2;//printf("%d", _name::rand);printf("%d", ::rand);//访问全局域中的rand
}

namespace可以嵌套

namespace _name
{int rand = 0;namespace bit{int rand = 1;}
}

 不同文件中定义的同名的命名空间可以合并进一个命名空间,并且其中不可以有同名的变量

//test.h
namespace _name
{int rand1 = 1;
}
//test.c
#include <stdio.h>
#include "test.h"
namespace _name
{int rand = 0;
}using namespace _name;int main()
{printf("%d", rand1);return 0;
}

C++中的输入和输出

#include <iostream>
using namespace std;int main()
{int i;cin >> i;//相当于scanf("%d",&i);cout << i << endl;//相当于printf("%d",i);cout << "hello world" << endl;//相当于printf("hello world\n");
}

运行结果: 

代码解析:

#include<iostream>: io流,里面有定义的命名空间std

using namespace std:展开std这个命名空间,该空间中有定义的cin和cout

cout:console output 控制台输出

<<:流插入

cin: console input 控制台输入

>>: 流提取

endl:相当于“\n”,也就是换行

cin<< 可以自动识别数据的类型,相较于scanf更方便一些。


缺省参数(默认参数)

函数的全部参数或部分参数有默认值,并且调用时,可以不为有默认值的参数传参。

void f(int a = 1)//形参a有默认值,为1
{cout << a << endl;
}

以下有两份代码:

#include <iostream>
using namespace std;void f(int a = 1)
{cout << a << endl;
}int main()
{f();//不传值,那么调用时形参a为默认值1return 0;
}

#include <iostream>
using namespace std;void f(int a = 1)
{cout << a << endl;
}int main()
{f(2);//传值return 0;
}

 

缺省参数又分为全缺省和部分缺省

全缺省就是:全部的形参都有默认值

部分缺省: 形参从右向左顺序缺省,不能出现跳跃,所以传值的时候也不能跳跃传值

//全缺省
void f(int a = 0, int b = 1, int c = 2)
{//....
}//部分缺省
void f(int a, int b = 1, int c = 2)
{//....
}//错误示范,不是从右向左顺序缺省
void f(int a = 0, int b, int c = 2)
{//....
}

既有声明又有定义的情况下

只在定义中给形参加默认参数

//既有声明又有定义
void f(int a = 0, int b = 1, int c = 2);
void f(int a, int b, int c )
{//....
}

函数重载

函数重载的条件:同一作用域,函数名相同,形参列表不同(形参的类型不同,类型的数量不同,类型的顺序不同)

//都在全局域中定义,下面的函数参数列表都与第一个比较
void f(int a,char b)
{cout << "heihei" << endl;
}//类型顺序不同
void f(char b, int a)
{cout << "haha" << endl;
}
//数量不同
void f(int a, char b,int c)
{cout << "wuwu" << endl;
}
//类型不同
void f(double a, char b)
{cout << "lalala" << endl;
}

不同作用域下的函数可以同名

namespace tmp
{void f()//在命名空间域中定义的f函数{cout << "hello world" << endl;}}void f()//在全局域中定义的f函数
{cout << "heihei" << endl;
}

因为两个函数的作用域不同,就算将命名空间展开两个f函数仍不构成重载。

调用歧义问题:

void f(int a = 10)
{}
void f()
{}
int main()
{f();return 0;
}

 即使函数重载了,也可能出现函数调用不明确的问题。

为什么C不支持函数重载,C++支持?

C中是不支持函数重载的,C++支持函数重载,

函数的地址:就是函数中有一堆需要执行的指令,而函数的地址就是需要执行的第一条指令的地址。

原因:链接时,

C是直接用函数名找函数的地址

C++是用修饰后的函数名找函数的地址 

结语:希望这篇文章能够让你有所收获。

这篇关于命名空间,缺省参数和函数重载的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1030095

相关文章

Python调用另一个py文件并传递参数常见的方法及其应用场景

《Python调用另一个py文件并传递参数常见的方法及其应用场景》:本文主要介绍在Python中调用另一个py文件并传递参数的几种常见方法,包括使用import语句、exec函数、subproce... 目录前言1. 使用import语句1.1 基本用法1.2 导入特定函数1.3 处理文件路径2. 使用ex

MySQL中时区参数time_zone解读

《MySQL中时区参数time_zone解读》MySQL时区参数time_zone用于控制系统函数和字段的DEFAULTCURRENT_TIMESTAMP属性,修改时区可能会影响timestamp类型... 目录前言1.时区参数影响2.如何设置3.字段类型选择总结前言mysql 时区参数 time_zon

Python如何使用seleniumwire接管Chrome查看控制台中参数

《Python如何使用seleniumwire接管Chrome查看控制台中参数》文章介绍了如何使用Python的seleniumwire库来接管Chrome浏览器,并通过控制台查看接口参数,本文给大家... 1、cmd打开控制台,启动谷歌并制定端口号,找不到文件的加环境变量chrome.exe --rem

Linux中Curl参数详解实践应用

《Linux中Curl参数详解实践应用》在现代网络开发和运维工作中,curl命令是一个不可或缺的工具,它是一个利用URL语法在命令行下工作的文件传输工具,支持多种协议,如HTTP、HTTPS、FTP等... 目录引言一、基础请求参数1. -X 或 --request2. -d 或 --data3. -H 或

Oracle的to_date()函数详解

《Oracle的to_date()函数详解》Oracle的to_date()函数用于日期格式转换,需要注意Oracle中不区分大小写的MM和mm格式代码,应使用mi代替分钟,此外,Oracle还支持毫... 目录oracle的to_date()函数一.在使用Oracle的to_date函数来做日期转换二.日

详解Spring Boot接收参数的19种方式

《详解SpringBoot接收参数的19种方式》SpringBoot提供了多种注解来接收不同类型的参数,本文给大家介绍SpringBoot接收参数的19种方式,感兴趣的朋友跟随小编一起看看吧... 目录SpringBoot接受参数相关@PathVariable注解@RequestHeader注解@Reque

Java向kettle8.0传递参数的方式总结

《Java向kettle8.0传递参数的方式总结》介绍了如何在Kettle中传递参数到转换和作业中,包括设置全局properties、使用TransMeta和JobMeta的parameterValu... 目录1.传递参数到转换中2.传递参数到作业中总结1.传递参数到转换中1.1. 通过设置Trans的

java如何调用kettle设置变量和参数

《java如何调用kettle设置变量和参数》文章简要介绍了如何在Java中调用Kettle,并重点讨论了变量和参数的区别,以及在Java代码中如何正确设置和使用这些变量,避免覆盖Kettle中已设置... 目录Java调用kettle设置变量和参数java代码中变量会覆盖kettle里面设置的变量总结ja

spring 参数校验Validation示例详解

《spring参数校验Validation示例详解》Spring提供了Validation工具类来实现对客户端传来的请求参数的有效校验,本文给大家介绍spring参数校验Validation示例详... 目录前言一、Validation常见的校验注解二、Validation的简单应用三、分组校验四、自定义校

SpringBoot中Get请求和POST请求接收参数示例详解

《SpringBoot中Get请求和POST请求接收参数示例详解》文章详细介绍了SpringBoot中Get请求和POST请求的参数接收方式,包括方法形参接收参数、实体类接收参数、HttpServle... 目录1、Get请求1.1 方法形参接收参数 这种方式一般适用参数比较少的情况,并且前后端参数名称必须