【C++】——入门基础

命名空间

在这里插入图片描述

当C语言遇到命名冲突时,很难解决,所以C++关键字namespace就是针对这种问题的。
在这里插入图片描述

如何使用命名空间内的成员呢?

  1. 加命名空间名称及限定符( ::)

在这里插入图片描述

  1. 展开命名空间全部成员(风险较大,适合日常小练习)

在这里插入图片描述

还有一个比较折中的办法,展开某个成员就行

在这里插入图片描述

输入与输出

  1. 在C++中,输入和输出(I/O)操作是编程中的基础部分。C++提供了多种方式来进行数据的输入和输出,但最常用和基础的两种方式是使用标准输入输出流对象:cin 用于输入,cout 用于输出。这些对象是在 < iostream > 头文件中定义的。
  2. cout/cin/endl等都属于C++标准库,C++标准库都放在⼀个叫std(standard)的命名空间中,所以要 通过命名空间的使⽤⽅式去⽤他们。
#include <iostream>  
// std是C++标准库的命名空间名,C++将标准库的定义实现都放到这个命名空间中
using namespace std;
  1. 使⽤C++输⼊输出更⽅便,通过插入(<<)和提取(>>)运算符,能够自动处理多种数据类型的输入输出。
#include <iostream>
using namespace std;
int main()
{
	cout << "Hello Word!" << endl;
	int a;
	double b;
	float c;
	//可以自动识别变量的类型
	cin >> a >> b >> c;
	cout << a << " " << b << "\n" << c << endl;
	return 0;
}

缺省参数

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

void Func(int a = 1)//缺省值
{
	cout << a << endl;
}
int main()
{
	Func();//没有传参,就使用缺省参数
	Func(10);//传参,使用制定的实参
	return 0;
}

缺省参数分类:

● 全缺省

void Func(int a = 0, int b = 1, int c = 2)
{
	cout << "a=" << a << endl;
	cout << "b=" << b << endl;
	cout << "c=" << c << endl;
}

● 半缺省

void Func(int a, int b = 1, int c = 2)
{
	cout << "a=" << a << endl;
	cout << "b=" << b << endl;
	cout << "c=" << c << endl;
}

注意:

  1. 全缺省就是全部形参给缺省值,半缺省就是部分形参给缺省值。C++规定半缺省参数必须从右往左 依次连续缺省,不能间隔跳跃给缺省值。
  2. 带缺省参数的函数调⽤,C++规定必须从左到右依次给实参,不能跳跃给实参。
  3. 函数声明和定义分离时,缺省参数不能在函数声明和定义中同时出现,必须在函数声明时给缺省值。

函数重载

函数重载是函数的一种特殊情况,C++允许在同一作用域中声明几个功能类似的同名函数,这些同名函数的形参列表(参数个数 或 类型 或 类型顺序)不同,常用来处理实现功能类似数据类型不同的问题。

函数重载的主要目的是让同一个函数名能够根据不同的参数类型或数量执行不同的功能,这样既可以提高代码的可读性,又可以让函数调用更加灵活。

函数重载可以分为三类:

// 1、参数类型不同
int ADD(int left, int right)
{
	cout << "int ADD(int left, int right)" << endl;
	return left + right;
}
double ADD(double left, double right)
{
	cout << "double ADD(int left, int right)" << endl;
	return left + right;
}
// 2、参数个数不同
void f()
{
	cout << "void f()" << endl;
}
void f(int a)
{
	cout << "void f(int a)" << endl;
}
// 3、参数顺序不同
void func(int a, char b)
{
	cout << "void func(int a, char b)" << endl;
}
void func(char b, int a)
{
	cout << "void func(char b, int a)" << endl;
}

引用

引用不是新定义一个变量,而是给已存在变量取了一个别名,编译器不会为引用变量开辟内存空
间,它和它引用的变量共用同一块内存空间。

类型标识符 &引用名 = 目标变量名;

在这里插入图片描述

  1. 引用在定义时必须初始化
void func()
{
	int a = 10;
	// int& ra;   // 该条语句编译时会出错
	int& ra = a;
	int& rra = a;
}
  1. 一个变量可以有多个引用
  2. 引用一旦引用一个实体,再不能引用其他实体

对引用的操作与对变量直接操作完全一样,因为它们实际上是同一个变量的不同名称。

void func(int& x)
{
	x++;//当x++时,a也会发生改变
}
int main() 
{
	int a = 0;
	func(a);
}

引用和指针的区别

引用和指针功能有重叠,但是不可替代。

  1. 引用概念上定义一个变量的别名,指针存储一个变量地址。
  2. 引用在定义时必须初始化,指针没有要求
  3. 引用在初始化时引用一个实体后,就不能再引用其他实体,而指针可以在任何时候指向任何
    一个同类型实体
  4. 没有NULL引用,但有NULL指针
  5. 在sizeof中含义不同:引用结果为引用类型的大小,但指针始终是地址空间所占字节个数(32
    位平台下占4个字节)
  6. 引用自加即引用的实体增加1,指针自加即指针向后偏移一个类型的大小
  7. 有多级指针,但是没有多级引用
  8. 访问实体方式不同,指针需要显式解引用,引用编译器自己处理
  9. 引用比指针使用起来相对更安全

const引用
const引用是一种特殊的引用,它允许你引用一个对象但不允许通过这个引用来修改该对象的内容。当你声明一个const引用时,你实际上是在告诉编译器:“这个引用将指向某个对象,但我保证不会通过这个引用来修改那个对象。”

权限可以缩小,不能放大

int main()
{
	const int a = 10;
	const int& b = a;
	//权限可以缩小,不能放大
	int x = 1;
	const int& y = x;
	return 0;
}

内敛函数

  1. 以inline修饰的函数叫做内联函数,编译时C++编译器会在调用内联函数的地方展开,没有函数调用建立栈帧的开销,内联函数提升程序运行的效率。
  2. inline对于编译器而言只是一个建议,内联函数适用于那些体积小、调用频繁且对性能有较高要求的函数。通过减少函数调用的开销,内联函数可以提高程序的执行效率。并不是所有的内联函数请求都会被编译器接受,编译器会根据实际情况决定是否进行内联展开。
  3. inline不建议声明和定义分离,分离会导致链接错误。因为inline被展开,就没有函数地址了,链接就会找不到。
inline void f(int i)
{
	cout << i << endl;
}
int main()
{
 	f(10);
 	return 0;
}

指针控制nullptr

在这里插入图片描述
C++中NULL指0,所以当遇到下面这种情况时,就会出现歧义

void f(int x)
{
	cout << "void f(int x)" << endl;
}
void f(int* ptr)
{
	cout << "void f(int* ptr)" << endl;
}
int main()
{
	f(0);
	f(NULL);
	return 0;
}

他到底调用哪一个函数呢,因为函数重载会调用最匹配的函数。由于0是int类型,所以编译器会优先选择int参数的void f(int x)函数。
所以C++11中引入nullptr,nullptr是一个特殊的关键字。nullptr是一种特殊类型的字面常量,它可以转换成任意类型的指针类型。使用nullptr定义空指针可以避免类型转换的问题,因为nullptr只能被隐式的转换成指针类型,而不能被转换为整数类型。

希望这篇博客对你有所帮助!!!

  • 21
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
### 回答1: 《CMake——入门到精通》是一本介绍CMake的书籍。CMake是一个跨平台的开源构建工具,它可以用于自动化构建、测试和部署应用程序、库和模块。 这本书从CMake的基本概念和用法入手,逐步深入介绍了CMake的各种功能和高级用法。首先,书中介绍了CMake的安装和配置,以及CMake项目的基本结构。然后,书中详细讲解了如何编写CMakeLists.txt文件来描述项目的构建过程,包括如何定义源文件、头文件和链接库,如何设置编译选项和链接选项,以及如何生成不同平台和编译器下的构建配置。 在介绍完CMake的基本使用后,书中着重讲解了CMake的高级功能和技巧。比如,如何使用CMake进行跨平台开发,如何进行自定义构建规则,如何配置项目的安装和打包,以及如何对大型项目进行模块化管理等等。同时,书中还提供了大量的示例代码和实用技巧,帮助读者更好地理解和应用CMake。 总的来说,《CMake——入门到精通》是一本系统而全面的CMake教程,适合想要学习和掌握CMake的开发人员阅读。无论是初学者还是有一定经验的开发者,都可以从这本书中获取到实用的知识和经验,提高项目构建的效率和质量。无论是在学习中还是在实际工作中,这本书都可以成为CMake的权威参考指南。 ### 回答2: 《cmake——入门到精通.pdf》是一本关于CMake的书籍。CMake是一个跨平台的开源构建工具,用于管理软件项目的构建过程。本书旨在帮助读者从入门到精通掌握CMake的使用。 这本书首先介绍了CMake的基本概念和原理,包括如何编写CMakeLists.txt文件以及如何配置和生成项目的构建系统。然后,书中详细介绍了CMake的常用功能和命令,包括设置编译选项、指定源文件、添加库和链接库等。此外,本书还深入讲解了CMake的高级用法,如多目录项目管理、条件编译、自定义函数和宏等。 除了基本功能和用法,本书还涵盖了CMake与其他工具和框架的集成,如与Qt、OpenGL和Boost等。读者可以学习如何使用CMake来管理复杂项目和库的构建过程。 《cmake——入门到精通.pdf》也提供了大量的示例和实战项目,帮助读者更好地理解和应用CMake。通过阅读本书,读者将能够全面了解CMake的工作原理和常用技巧,掌握使用CMake构建和管理项目的能力。 总之,借助《cmake——入门到精通.pdf》,读者可以系统地学习和掌握CMake的基本概念和高级用法,并能够灵活应用CMake来管理复杂项目的构建过程。这本书对于软件开发者和项目管理者来说,是一本非常实用和有价值的参考书。 ### 回答3: 《CMake入门到精通.pdf》是一本介绍CMake工具的书籍。CMake是一个跨平台的开源构建工具,可以用于管理和自动化C++项目的构建过程。该书以系统的方式介绍了CMake的基本概念、语法和用法。 首先,书中详细解释了CMake的背景和作用。CMake的主要功能是生成与平台无关的构建脚本,在不同的操作系统和编译器上都可以使用。它可以通过简单的配置文件来管理项目的依赖关系和编译选项。 其次,书中介绍了CMake的基本语法和常用命令。CMake使用一种类似于脚本的语言来描述项目的构建过程,通过编写CMakeLists.txt文件来配置项目。书中示例详细展示了如何编写CMakeLists.txt文件,包括设置项目名称、指定源文件、添加库和链接库等等。 然后,书中深入讲解了CMake的高级用法和技巧。CMake提供了丰富的功能来处理复杂的项目结构和构建需求,例如条件判断、循环、宏定义等。书中通过实际案例演示了这些高级特性的使用方法,帮助读者更好地理解和运用CMake。 最后,书中还介绍了CMake与其他开发工具的集成,如CTest、CPack和CDash等。CTest用于自动化测试,CPack用于生成安装包,CDash用于持续集成。书中展示了如何使用这些工具来进一步提高项目的开发效率和质量。 总之,《CMake入门到精通.pdf》通过全面而系统的方式介绍了CMake工具的使用方法,适合初学者和有一定经验的开发者阅读。读者可以通过学习这本书,掌握CMake的基本概念和语法,了解CMake在实际项目中的应用,提高项目的构建效率和可维护性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值