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

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

相关文章

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

MySQL高级查询之JOIN、子查询、窗口函数实际案例

《MySQL高级查询之JOIN、子查询、窗口函数实际案例》:本文主要介绍MySQL高级查询之JOIN、子查询、窗口函数实际案例的相关资料,JOIN用于多表关联查询,子查询用于数据筛选和过滤,窗口函... 目录前言1. JOIN(连接查询)1.1 内连接(INNER JOIN)1.2 左连接(LEFT JOI

MySQL中FIND_IN_SET函数与INSTR函数用法解析

《MySQL中FIND_IN_SET函数与INSTR函数用法解析》:本文主要介绍MySQL中FIND_IN_SET函数与INSTR函数用法解析,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一... 目录一、功能定义与语法1、FIND_IN_SET函数2、INSTR函数二、本质区别对比三、实际场景案例分

Spring Boot项目部署命令java -jar的各种参数及作用详解

《SpringBoot项目部署命令java-jar的各种参数及作用详解》:本文主要介绍SpringBoot项目部署命令java-jar的各种参数及作用的相关资料,包括设置内存大小、垃圾回收... 目录前言一、基础命令结构二、常见的 Java 命令参数1. 设置内存大小2. 配置垃圾回收器3. 配置线程栈大小

C++ Sort函数使用场景分析

《C++Sort函数使用场景分析》sort函数是algorithm库下的一个函数,sort函数是不稳定的,即大小相同的元素在排序后相对顺序可能发生改变,如果某些场景需要保持相同元素间的相对顺序,可使... 目录C++ Sort函数详解一、sort函数调用的两种方式二、sort函数使用场景三、sort函数排序

C语言函数递归实际应用举例详解

《C语言函数递归实际应用举例详解》程序调用自身的编程技巧称为递归,递归做为一种算法在程序设计语言中广泛应用,:本文主要介绍C语言函数递归实际应用举例的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录前言一、递归的概念与思想二、递归的限制条件 三、递归的实际应用举例(一)求 n 的阶乘(二)顺序打印

SpringBoot利用@Validated注解优雅实现参数校验

《SpringBoot利用@Validated注解优雅实现参数校验》在开发Web应用时,用户输入的合法性校验是保障系统稳定性的基础,​SpringBoot的@Validated注解提供了一种更优雅的解... 目录​一、为什么需要参数校验二、Validated 的核心用法​1. 基础校验2. php分组校验3

C/C++错误信息处理的常见方法及函数

《C/C++错误信息处理的常见方法及函数》C/C++是两种广泛使用的编程语言,特别是在系统编程、嵌入式开发以及高性能计算领域,:本文主要介绍C/C++错误信息处理的常见方法及函数,文中通过代码介绍... 目录前言1. errno 和 perror()示例:2. strerror()示例:3. perror(

Kotlin 作用域函数apply、let、run、with、also使用指南

《Kotlin作用域函数apply、let、run、with、also使用指南》在Kotlin开发中,作用域函数(ScopeFunctions)是一组能让代码更简洁、更函数式的高阶函数,本文将... 目录一、引言:为什么需要作用域函数?二、作用域函China编程数详解1. apply:对象配置的 “流式构建器”最