首页 > 编程语言 >C++基础入门(命名空间,函数,引用)

C++基础入门(命名空间,函数,引用)

时间:2024-03-21 10:34:00浏览次数:34  
标签:std 函数 int C++ 引用 内联 入门

文章目录

前言

欢迎来到这篇关于C++的入门博客!C++是一门强大而又广泛应用的编程语言,作为一门面向对象的编程语言,C++可以让你更好地组织和管理代码,提高代码的重用性和可维护性。它广泛应用于游戏开发、嵌入式系统、图形界面设计等领域,并且被用于构建各种高性能的应用程序。无论你想要开发一个游戏、编写一个操作系统,还是创建一个复杂的应用程序,C++都能提供你所需的强大工具和灵活性。学习C++无疑会让你从中受益匪浅。那么话不多说,让我们开始今天的学习吧。

1,命名空间

C++的命名空间(Namespace)是一种用于将标识符封装在特定命名空间内的机制。它可以避免不同组织或库中的命名冲突,并提供了更好的代码组织和模块化的能力。
简单来说就是比如你定义了一个max函数,同时又定义了一个max变量,两者重名,没法编译通过,那么我们就可以把他们分别放到不同的命名空间,这样就可以很好的区别他们。
命名空间可以通过关键字namespace来定义,其语法如下:

namespace 名称 {
    // 在命名空间内,可以定义变量、函数、类等,
    //这些定义在命名空间内的标识符将默认属于该命名空间。
}

那我们如何访问命名空间内的东西呢?
我们可以使用::作用域限定符。使用方法如下:

#include<iostream>//c++输入输出要用的头文件
namespace uma//我自己定义的命名空间
{
	int max;
}
int main()
{
	int a = 0, b = 1;
	uma::max = std::max(a, b);//uma::max指的是我定一个整形变量,而std::max则是c++标准库中的函数用于比较两者大小返回较大者
	std::cout << uma::max;//std::cout是c++标准库的输出函数
return 0;
}

std是c++标准库的命名空间的名字,所以在使用c++标准库中的东西时需要加上std::才能使用。
cin是C++的输入函数类似于scanf,而cout是C++的输出函数类似于printf。
使用方法:

int main()
{
	int n;
	std::cin >> n;//>>是流提取操作符,这样我们就可以往n里输入数据
	std::cout << n;//<<是流插入操作符,这样我们就可以输出n
return 0;
}

但是我们会发现每次都要写一下std::非常的麻烦,那么我们就可以在头文件下面加上这样一句话。

#include<iostream>
using namespace std;//有了这句话以后我们在使用c++标准库中的东西时
                    //就再也不用在前面加上std::了
int main()
{
	int n;
	cin >> n;
	cout << n;
return 0;
}

还可以这样写:

#include<iostream>
using std::cout;//这样写的话在使用cout和cin时就不需要加上std::了但是其他的标准库函数还是需要的
using std::cin;
int main()
{
	int n;
	cin >> n;
	cout << n;
return 0;
}

命名空间还可以嵌套使用。即在一个命名空间中再建一个命名空间。
命名空间可以合并,同一个工程中允许存在多个相同名称的命名空间编译器最后会合成同一个命名空间中。

2,函数

相较于c语言,c++的函数也进行了许多的优化。

函数重载

在c语言中,不能有重复的函数名,但是在c++中却可以实现,我们称之为函数重载。C++中允许在同一作用域中声明几个功能类似的同名函数。这些同名函数形参列表(参数个数,类型,顺序,注意没有返回值哦)必须不同。
我来给大家做个演示:

	#include<iostream>
using namespace std;
int Max(int x, int y)
{
	return x > y ? x : y;
}
double Max(double x, double y)
{
	return x > y ? x : y;
}
	int main()
	{
		int a = Max(1, 2);
		double b = Max(1.0, 2.5);
		cout << a << " " << b;
	return 0;
	}

编译器会根据参数的类型和顺序找到相应的函数并调用。

缺省参数

缺省参数是声明定义函数时为函数的参数指定一个默认值。在调用时,如果没有指定实参则用默认值。举个例子:

	#include<iostream>
using namespace std;
int Max(int x, int y = 10)
{
	return x > y ? x : y;
}

	int main()
	{
		int a = Max(1);
		cout << a ;
	return 0;
	}

在这个例子中调用Max时只有一个参数,所以y会被指定为默认值10,所以输出的结果为10。
一个函数可以设置多个缺省值但是需要注意的是:半缺省参数必须从左往右依次给出,缺省参数不能再函数声明和定义中同时出现,缺省值必须是常量或者全局变量。

内联函数

C++的内联函数是一种在调用时直接将函数体插入到调用处的函数。内联函数使用关键字inline来进行声明和定义。如下:

	#include<iostream>
using namespace std;
inline int Max(int x, int y )
{
	return x > y ? x : y;
}

	int main()
	{
		int a = Max(1,2);
		cout << a ;
	return 0;
	}

当调用Max时,函数会自动展开为 x > y ? x : y;
内联函数可以提高程序的执行速度,因为在调用内联函数时不需要进行函数调用的开销,而是直接将函数体插入到调用处,这样可以减少函数栈帧的创建和销毁的开销。
这样有点类似于宏,但是比起宏更不容易出错。
内联函数适用于函数体较小且频繁调用的情况。由于内联函数会将函数体复制到每个调用处,所以如果函数体较大或者被频繁调用的地方较多,则内联函数可能会导致代码膨胀,进而增加内存占用。
要注意的是,C++编译器对内联函数的使用有一定的限制,最终是否将函数作为内联函数处理由编译器决定。编译器通常会根据函数体的复杂度和调用情况进行判断。如果要强制将函数作为内联函数处理,可以使用编译器指令或者在函数定义处添加inline关键字。
在使用内联函数时,需要注意以下几点:
1,内联函数通常应该定义在头文件中,以便在每个调用处都能够看到函数体。
2,内联函数的定义和声明应该放在同一个头文件中,以便编译器能够将函数体插入到调用处。
3,内联函数不能包含递归调用。

3,引用

C++的引用是一种为现有变量创建别名的机制。引用可以被看作是变量的别名,通过引用可以使用相同的内存地址来访问变量的内容。引用在C++中提供了更加灵活、方便和安全的方式来操作变量。
引用的定义使用&符号,将引用与已存在的变量进行绑定。例如:

int a = 10;
int& b = a;//将变量b定义为整型引用,与变量a绑定在一起。
b++;       //这样,在后续使用b时,实际上是对a的操作。
//此时a = 11

引用的使用有以下几个特点:
引用必须在声明时进行初始化,一旦绑定了一个变量,就不能再指向其他变量。
引用是一个常量指针,无法改变它的引用对象。
引用不占用额外的内存空间,它只是原变量的另一个名字。
对引用的操作实际上是对引用对象的操作。
在sizeof中引用结果为引用类型的大小
没有多级引用
在函数中,引用可以作为参数也可以作为返回值。
在作为参数时,形参是引用类型变量,其实就是实参的一个别名,在被调用函数中,对引用变量的所有操作等价于对实参的操作,这样,整个函数执行完毕后,原先的实参的值将会发生改变。被调函数对形参做的任何操作都影响了主调函数中的实参变量。
作为返回值时需要注意如果返回值出了函数之后会被销毁的话就不能用

尾声

如果觉得博主写的不错的话,不要忘记给博主一个免费的点赞,关注,收藏哦~,下一期我将分享c++类和对象的学习,我们下期不见不散!

标签:std,函数,int,C++,引用,内联,入门
From: https://blog.csdn.net/Tokai___Teio/article/details/136870597

相关文章

  • 零基础入门Python全套教程(无偿分享,学完可就业!)
    Python在2017年世界脚本语言排行榜中排名第1,也是多领域首选语言,作为一种高级程序语言,其核心设计哲学是代码可读性和语法,能够让程序员用很少的代码来表达自己的想法。现在Python作为时下越来越流行的编程语言,成为越来越多的人的青睐,越来越多的人开始学习Python,而对于小白来......
  • C++ 参数传递浅析
    全文目录概述值传递(pass-by-value)什么是变量?值传递的例子指针传递(pass-by-pointer)什么是指针?指针传递的例子引用传递(pass-by-reference)什么是引用?引用和指针的异同引用传递的例子写在最后小结概述众所周知C++参数传递有三种,分别问值传递、指针传递、引用传......
  • C++内置 new /delete 运算符浅析
    全文目录malloc()/free()原型解析简化版本用法举例new/delete静态/动态类型new/delete运算符原型常用但没有注意区分的例子使用new分配对象的生存期那new/delete都做什么事呢几个注意点写在最后malloc()/free()提到new/delete运算符就不得不说malloc()/f......
  • 尚硅谷Vue3入门到实战,最新版vue3+TypeScript前端开发教程
    1.创建Vue3工程npmcreatevue@latest或者npminitvue@latest输入项目名和需要的工具后进入项目如果项目报错使用命令安装Node.js的项目依赖包npmi启动vue项目,查看项目是否创建完成npmrundev直接删掉src然后创建src文件夹,在该文件夹中创建main.ts和App.vue文件......
  • 鸿蒙 HarmonyOS学习日记 Day 1 安装与入门
    提示:学习本课程应该有一定的前端基础文章目录一、学前准备1、了解官网2、进行下载3、初始化4、项目创建二、ArkTS基础入门1、认识和存储数据2、数组3、函数4、箭头函数5、对象6、联合类型7、枚举类型一、学前准备1、了解官网https://www.openharmony.cn/mainP......
  • 项目管理平台-01-jira 入门介绍 缺陷跟踪管理系统,为针对缺陷管理、任务追踪和项目管理
    拓展阅读Devops-01-devops是什么?Devops-02-Jpom简而轻的低侵入式在线构建、自动部署、日常运维、项目监控软件代码质量管理SonarQube-01-入门介绍项目管理平台-01-jira入门介绍缺陷跟踪管理系统,为针对缺陷管理、任务追踪和项目管理的商业性应用软件项目管理平台-01-Phab......
  • C++模板实现之谜:为何只能在头文件中?解密原因与高级分离技术
     概述:C++中模板必须在头文件中实现,因为编译器需要可见的实现以生成模板具体实例的代码。通过头文件,确保模板在每个编译单元中都能被正确展开,提高可维护性。在C++中,模板只能在头文件中实现的主要原因是编译器在使用模板时需要生成对应的代码,而这部分代码必须在编译时可见。以......
  • python中出现Microsoft Visual C++ 14.0 or greater is required
    我尝试下载了Microsoftvisualc++14.0,但是依然不管用,而且它是真的很大…… 直接安装相应依赖也不管用(可能其他人管用?)——condainstalllibpythonm2w64-toolchain-cmsys2链接:https://blog.csdn.net/qzzzxiaosheng/article/details/125119006 然后我有找到一个,看着描......
  • C++ 函数模板
    C++函数模板函数模板在C++中,函数模板是一种允许函数以一种类型无关的方式来操作的工具。它们使得函数能够处理不同类型的数据而不需要为每种类型编写重复的代码。函数模板的核心思想是“参数化类型”,这意味着在定义函数时,可以使用一个或多个通用类型参数,而在函数被调用时......
  • 机器学习最全详细入门指南
    Fieldofstudythatgivescomputerstheabilitytolearnwithoutbeingexplicitlyprogrammed.机器学习研究和构建的是一种特殊算法(而非某一个特定的算法),能够让计算机自己在数据中学习从而进行预测。所以,机器学习不是某种具体的算法,而是很多算法的统称。机器学习包......