【C++】C++入门第一课(c++关键字 | 命名空间 | c++输入输出 | 缺省参数)

目录

前言

C++关键字

命名空间

1.命名空间的定义

A.标准命名空间定义

B.命名空间允许嵌套定义

C.同名命名空间的合并

 2.命名空间的使用

加命名空间名称及作用限定符 

使用using将命名空间中某个成员引入

使用using namespace命名空间名称引入

C++的输入和输出

缺省参数

缺省参数的概念

缺省参数的分类和使用

结语


前言

本篇博客就是C++的开篇了,C++是在C的基础之上,容纳进去了面向对象编程思想,并增加了许多有用的库,以及编程范式等。熟悉C语言之后,对C++学习有一定的帮助。很多人考虑到关于语言选择的问题,不知道学完C后该去学什么语言。这里我想说的就是,主流语言基本上是互通的,当你学精一门以后,再上手其他的语言也会非常快。如果你要问C++难不难,我只能说学起来不简单。但C++其难学易用,相信在正真学懂之后,你一定会爱上这门语言的。

入门篇的博客主要是补充C语法的不足,以及C++是如何对C语言设计不合理的地方进行优化的,比如:作用域方面、IO方面、函数方面、指针方面、宏方面等。同时也要为后面类和对象的学习打基础。

C++关键字

C++共计63个关键字,C语言只有32个关键字,可以给大家预览一下:

asmdoifreturntrycontinue
autodoubleinlineshorttypedeffor
booldynamic_castintsignedtypeidpublic
breakelselongsizeoftypenamethrow
caseenummutablestaticunionwchar_t
catchexplicitnamespacestatic_castunsigneddefault
charexportnewstructusingfriend
classexternoperatorswitchvirtualregister
constfalseprivatetemplatevoidtrue
const_castfloatprotectedthisvolatilewhile
deletegotoreinterpret_cast

命名空间

在C/C++代码编写的过程中,变量、函数和后面要学到的类都是大量存在的,这些变量、函数和类的名称将都存在于全局作用域中,可能会导致很多冲突。使用命名空间的目的是对标识符的名称进行本地化,以避免命名冲突或名字污染,namespace关键字的出现就是针对这种问题而想出的解决方式。

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

上面这段代码会这样报错,原因是rand在头文件<stdlib.h>中已经被定义为一个函数,再次定义rand为变量会出现名称冲突,C语言没办法解决类似这样的命名冲突问题,所以C++提出了namespace来解决。

 在将rand放入命名空间xsr中后,运行此段代码会生成一段随机数,因为此时并未指定命名空间的rand,所以打印的依然是在头文件<stdlib.h>中定义的rand()函数地址

 我们只需要指定域,就可以达到打印域中rand的效果

int main()
{
	printf("%d\n", xsr::rand);
	return 0;
}

接下来我们就来讲讲关于命名空间使用的定义和几种使用方法。 

1.命名空间的定义

定义命名空间,就需要使用到namespace关键字,后面跟命名空间的名字,然后接一对{ }即可{ }
中即为命名空间的成员

A.标准命名空间定义

namespace xsr
{
	// 命名空间中可以定义变量/函数/类型
	int rand = 10;
	int Add(int left, int right)
	{
		return left + right;
	}
	struct Node
	{
		struct Node* next;
		int val;
	};
}

定义一个命名空间相当于定义了一个新的作用域,命名空间中的所有内容都局限于该命名空间中

B.命名空间允许嵌套定义

namespace N1
{
	int a;
	int b;
	int Add(int left, int right)
	{
		return left + right;
	}
	namespace N2
	{
		int c;
		int d;
		int Sub(int left, int right)
		{
			return left - right;
		}
	}
}

这个时候,N2就是N1里面定义的一个命名空间,可以通过N1间接访问命名空间N2

C.同名命名空间的合并

同一个工程中允许存在多个相同名称的命名空间,编译器最后会合成为同一个命名空间

//test.cpp
namespace N1
{
	int a;
	int b;
	int Add(int left, int right)
	{
		return left + right;
	}
	namespace N2
	{
		int c;
		int d;
		int Sub(int left, int right)
		{
			return left - right;
		}
	}
}

// test.h
namespace N1
{
	int Mul(int left, int right)
	{
		return left * right;
	}
}

一个工程中的test.h和上面test.cpp中两个N1会被合并成一个,这就是相同名称命名空间的合并,在同一个文件中的两个同名的命名空间也会如此。

注:一个命名空间就定义了一个新的作用域,命名空间中的所有内容都局限于该命名空间中

 2.命名空间的使用

既然学会了定义命名空间,那么如何使用命名空间中的内容呢?

我们以这一段代码为例:

#include<stdio.h>
namespace xsr
{
	int a = 1;
	int b = 2;
	int Add(int left, int right)
	{
		return left + right;
	}
	struct Node
	{
		struct Node* next;
		int val;
	};
}
int main()
{
	printf("%d\n", a);
	printf("%d\n", b);
	struct Node newnode;
	printf("%d\n", Add(a, b));
	return 0;
}

这时会这样报错

加命名空间名称及作用限定符 

 使用第一种方式,加命名空间名称做限定符,就需要这样改:

int main()
{
	printf("%d\n", xsr::a);
	printf("%d\n", xsr::b);
	struct xsr::Node newnode;
	printf("%d\n", xsr::Add(xsr::a, xsr::b));
	return 0;
}

这时候代码就可以成功跑起来了,这里注意一点,域名在指定结构体时是加在结构体名称前struct关键字后的

但是如果要反复使用其中的某个变量和函数,每次都加上域名的指定一定不会好受,下面介绍两种展开方式来解决此类问题。 

使用using将命名空间中某个成员引入

我们使用using将命名空间中某个成员引入,如果你想用这样的方式展开函数和结构体也可以,方法都是类似的。

using xsr::a;
using xsr::b;
using xsr::Node;
using xsr::Add;
int main()
{
	printf("%d\n", a);
	printf("%d\n", b);
	struct Node newnode;
	printf("%d\n", Add(a, b));
	return 0;
}

这时候,就可以访问到域中的内容了。

使用using namespace命名空间名称引入

using namespace xsr;
int main()
{
	printf("%d\n", a);
	printf("%d\n", b);
	struct Node newnode;
	printf("%d\n", Add(a, b));
	return 0;
}

这时的展开你可以直接去访问域中定义好的结构体,就像在全局变量中定义的那样。 

当你没有展开命名空间时,编译器默认的规则是,先去局部域找,找不到再去全局域中去找,这个时候域中是不会纳入查找范围的。

当展开命名空间后,编译器默认查找规则为:

  1. 先去当前域找
  2. 再去全局域中找
  3. 最后再去展开的命名空间去找

注:如果两个或两个以上展开的命名空间中同名变量,编译器同样会报错。

 想问问你之前是否见过别写C++,开头经常有这样一段代码:

#include<iostream>
using namespace std;

其实using namespace std; 的本质就是展开头文件<iostream>中定义的一个命名空间,这个命名空间的名字就叫做std。 

关于命名空间的使用总结为:

  1. 指定命名空间访问
  2. 部分展开:using xsr::a;
  3. 全局展开:using namespace std;(大型项目中不推荐,容易产生冲突)

C++的输入和输出

C++作为以C为的基础发展而来的一门语言,也有其自己独特的输入输出方式,跟初学C语言学printf和scanf时一样,C++中使用输入输出流来实现打印和接收信息

#include<iostream>
using namespace std;
int main()
{
	cout << "Hello C++" << endl;
	return 0;
}

std是C++标准库的命名空间名,C++将标准库的定义实现都放到这个命名空间中。

说明:

  1. 使用cout标准输出对象(控制台)和cin标准输入对象(键盘)时,必须包含< iostream >头文件以及按命名空间使用方法使用std。
  2. cout和cin是全局的流对象,endl是特殊的C++符号,表示换行输出(等同于C语言中的'\n'),他们都包含在包含<iostream >头文件中.
  3. <<是流插入运算符,>>是流提取运算符。
  4. 使用C++输入输出更方便,不需要像printf/scanf输入输出时那样,需要手动控制格式。C++的输入输出可以自动识别变量类型。
  5. 实际上cout和cin分别是ostream和istream类型的对象,>>和<<也涉及运算符重载等知识,这些知识我们我们后续才会学习,所以我们这里只是简单学习他们的使用。

注:早期的标准库将所有功能在全局域中实现,声明在.h后缀的头文件中,使用时只需包含对应头文件即可,后来将其实现在std命名空间下,为了和C头文件区分,也为了正确使用命名空间,规定C++头文件不带.h;旧编译器(vc 6.0)中还支持<iostream.h>格式,后续编译器已不支持,因此推荐使用<iostream>+std的方式。

下面是关于cin和cout的简单使用: 

#include <iostream>
using namespace std;
int main()
{
	int a;
	double b;
	char c;
	// cin和cout可以自动识别变量的类型
	cin >> a;
	cin >> b >> c;
	cout << a << endl;
	cout << b << " " << c << endl;
	return 0;
}

cout和cin还有很多更复杂的用法,比如控制浮点数输出精度,控制整形输出进制格式等等。因为C++兼容C语言的用法,我们可以用C来穿插控制输入输出,同时这些又用得不是很多,我们这里就不展开学习了。后续遇到需要特别学习的再展开论述。

std命名空间的使用建议:

  1. 在日常练习中,可以用using namespace std直接展开即可,比较方便。
  2. 但是使用1方式直接展开,相当于吧标准库完全暴露了出来,如果我们跟库进行了重定义类型/对象/函数,就很容易出现冲突。平时练习时一般很少出现这种情况,但正真项目开发的代码较多,规模大,就很容易出现。所以建议在项目开发中使用,像std::cout这样使用时指定命名空间 和 using std::cout展开常用的库对象/类型等方式。

缺省参数

缺省参数的概念

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

#include<iostream>
using namespace std;
void Fun(int a = 0)
{
	cout << a << endl;
}
int main()
{
	Fun();// 没有传参时,使用参数的默认值
	Fun(5);// 传参时,使用指定的实参
	return 0;
}

缺省参数的分类和使用

1.全缺省参数

void Func(int a = 10, int b = 20, int c = 30)
{
    cout<<"a = "<<a<<endl;
    cout<<"b = "<<b<<endl;
    cout<<"c = "<<c<<endl;
}

2.半缺省参数

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

  1. 半缺省参数必须从右往左依次来给出,不能间隔着给(给函数缺省参数传参时也只能从左往右依次传,不能间隔着传)
  2. 缺省参数不能在函数声明和定义中同时出现(如果同时有声明和定义,需要将缺省值放在声明中,此时给定义放缺省值会报错)
  3. 缺省值必须是常量或者全局变量
  4. C语言不支持(C语言的编译器不支持缺省参数)
#include<iostream>
using namespace std;
void Fun(int a = 10, int b = 20, int c = 30)
{
	cout << a << " " << b << " " << c << endl;
}
int main()
{
	Fun(1, 2, 3);
	Fun(1, 2);
	Fun(1);
	Fun();
	// 使用缺省参数传参时,必须严格从左往右依次传参
	// 以下皆为错误写法
	// Fun( , ,3);
	// Fun( ,2, );
	return 0;
}

结语

本篇博客是C++语法的第一课,是C++对C语言不足之处的一些补充,讲了关于C++解决命名冲突命名空间的定义和使用,C++的基本输入输出流和缺省参数等内容。

关于C++入门,还需要一篇博客的量才能基本讲解完毕,感谢大家的支持。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

C++类基础5——拷贝构造函数,拷贝赋值运算符(复制构造函数,复制赋值运算符)

拷贝控制操作 当定义一个类时&#xff0c;我们显式地或隐式地指定在此类望的对象拷贝&#xff0c;移动、赋值和销毁时做什么。 一个类通定义五种特殊的成员函数来控制这些操作&#xff0c;包括&#xff1a;拷贝构造函数(copy consinuctor)、拷贝赋值运算符(copy-assignment op…

如何修复开机但不显示任何内容的计算机?这里提供详细步骤

前言​ 计算机“无法开机”的最常见方式是PC实际开机但在显示器上不显示任何内容。你看到电脑机箱上的灯,可能看到里面的风扇在转,甚至可能听到声音,但屏幕上什么也没有显示,请按照我们提供的顺序尝试以下常见修复方法。 测试显示器 在对计算机的其余部分进行更复杂和耗时…

Mac 下安装maven教程

note&#xff1a;网上已经有很多该类型教程了&#xff0c;这边自身保留一份&#xff0c;方便后面使用&#xff1b; 一、安装地址&#xff1a;官网 二、安装步骤 $ tar -xvf apache-maven-3.3.9-bin.tar.gz //mac支持手动点击解压 $ sudo mv -f apache-maven-3.3.9 /usr…

C语言函数递归调用

在C语言中&#xff0c;函数可以直接或间接地调用自身&#xff0c;这种函数调用自身的过程称为递归调用。递归是一种强大的编程技巧&#xff0c;能够简化程序结构、提高代码的可读性和可维护性。本文将介绍C语言函数递归调用的原理、应用场景以及注意事项。 以下是我整理的关于…

HANA中的内存及磁盘使用统计

1. 引言 在实际使用中&#xff0c;通过HANA的admin控制台&#xff0c;确实可以得到很多重要的信息。但有的时候不如人愿&#xff0c;你需要提供相应的SQL语句得到具体的信息。 比如&#xff0c;我要得到所有的行表的内存及磁盘占用信息&#xff1b;我需要得到所有列表的内存及…

[WebGL] 实例化绘制性能测试

实例化绘制&#xff08; Instanced Drawing &#xff09;是 OpenGL / WebGL 等图形 API 中常用的性能优化技术&#xff0c;它适用于同样的模型绘制次数非常多的场景&#xff0c;能够有效的降低显存占用和图形 API 接口调用的次数&#xff0c;达到性能提升的效果。以前我只知道怎…

蓝桥杯 java 承压计算

题目: 思路&#xff1a; 1&#xff1a;其中的数字代表金属块的重量(计量单位较大) 说明每个数字后面不一定有多少个0 2&#xff1a;假设每块原料的重量都十分精确地平均落在下方的两个金属块上&#xff0c;最后&#xff0c;所有的金属块的重量都严格精确地平分落在最底层的电子…

QT 二维坐标系显示坐标点及点与点的连线-通过定时器自动添加随机数据点

QT 二维坐标系显示坐标点及点与点的连线-通过定时器自动添加随机数据点 功能介绍头文件C文件运行过程 功能介绍 上面的代码实现了一个简单的 Qt 应用程序&#xff0c;其功能包括&#xff1a; 创建一个 MainWindow 类&#xff0c;继承自 QMainWindow&#xff0c;作为应用程序的…

物联网学习1、什么是 MQTT?

MQTT&#xff08;Message Queuing Telemetry Transport&#xff09;是一种轻量级、基于发布-订阅模式的消息传输协议&#xff0c;适用于资源受限的设备和低带宽、高延迟或不稳定的网络环境。它在物联网应用中广受欢迎&#xff0c;能够实现传感器、执行器和其它设备之间的高效通…

FLASH的读取与写入

FLASH的写入 结合HAL库所给参数&#xff1a; 查阅具体使用芯片的参考手册。 就不在详细解释&#xff0c;英文自行翻译。具体代码如下&#xff1a; /*FLASH写入程序*/ void WriteFlashTest(uint32_t L, uint32_t addr, uint32_t *Data,int Page) {int i0;/* 1/4解锁FLASH*/HAL…

揭秘五力模型:轻松掌控企业竞争命脉,决策不再迷茫!

五力分析模型又成为波特五力模型是由著名的管理学者迈克尔波特(Michael Porter)在20世纪80年代初提出的一种理论框架&#xff0c;它对企业营销中的战略制定产生了全球性的深远影响。这一模型被广泛应用于企业竞争战略的分析&#xff0c;可以帮助企业有效地分析企业在营销环境中…

python-pytorch获取FashionMNIST实际图片标签数据集

在查看pytorch官方文档的时候&#xff0c;在这里链接中https://pytorch.org/tutorials/beginner/basics/data_tutorial.html的Creating a Custom Dataset for your files章节&#xff0c;有提到要自定义数据集&#xff0c;需要用到实际的图片和标签。 在网上找了半天没找到&a…

蓝海项目!黑科技引爆全网流量小红书拉新,单日暴力收益7000+,小白也能轻松上手【揭秘】

众所周知&#xff0c;自去年以来&#xff0c;图文作品在各大平台如快手和抖音的流量大增&#xff0c;这得益于这些平台与小红书的竞争。目前&#xff0c;小红书也在积极推广&#xff0c;成功推荐新用户下载应用的奖励高达15元&#xff0c;这一数字几乎是其他平台的几倍。此外&a…

【TypeScript】解决字面量类型推断错误的四种方式

解决字面量类型推断错误的四种方式 方式一&#xff1a;对象属性使用类型断言方式二&#xff1a;传参使用类型断言方式三&#xff1a;对象使用类型断言方式四&#xff1a;对象属性使用变量&#xff0c;变量使用字面量类型参考 declare function handleRequest(url: string, meth…

深入理解HDFS工作原理:大数据存储和容错性机制解析

** 引言&#xff1a; ** 在当今数据爆炸的时代&#xff0c;存储和管理大规模数据成为了许多组织面临的重要挑战。为了解决这一挑战&#xff0c;分布式文件系统应运而生。Hadoop分布式文件系统&#xff08;HDFS&#xff09;作为Apache Hadoop生态系统的核心组件之一&#xff…

Java | Leetcode Java题解之第2题两数相加

题目&#xff1a; 题解&#xff1a; class Solution {public ListNode addTwoNumbers(ListNode l1, ListNode l2) {ListNode head null, tail null;int carry 0;while (l1 ! null || l2 ! null) {int n1 l1 ! null ? l1.val : 0;int n2 l2 ! null ? l2.val : 0;int sum…

罗永浩直播阿里云服务器ECS u1性能如何?值得买吗?

罗永浩直播卖阿里云服务器&#xff0c;企业专享云服务器ECS通用算力型u1实例是什么&#xff1f;性能如何&#xff1f;目前阿里云服务器ECS u1实例&#xff0c;2核4G&#xff0c;5M固定带宽&#xff0c;80G ESSD Entry盘&#xff0c;优惠价格199元一年&#xff0c;罗永浩今晚直播…

算法学习16:数论03(容斥原理、博弈论)

算法学习16&#xff1a;数论03&#xff08;容斥原理、博弈论&#xff09; 文章目录 算法学习16&#xff1a;数论03&#xff08;容斥原理、博弈论&#xff09;前言一、容斥原理&#xff1a;求多个集合的并集二、博弈论1.Nim游戏&#xff1a;2.集合N-im游戏 总结 前言 提示&#…

【AI系列】Python NLTK 库和停用词处理的应用

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

04 | Swoole 源码分析之 epoll 多路复用模块

首发原文链接&#xff1a;Swoole 源码分析之 epoll 多路复用模块 大家好&#xff0c;我是码农先森。 引言 在传统的IO模型中&#xff0c;每个IO操作都需要创建一个单独的线程或进程来处理&#xff0c;这样的操作会导致系统资源的大量消耗和管理开销。 而IO多路复用技术通过…