无敌C++大王养成篇一

news2024/11/25 7:30:33

1.命名空间

namespace

c语⾔项⽬类似下⾯程序这样的命名冲突是普遍存在的问题,C++引⼊namespace就是为了更好的解决 这样的问题

#include<stdio.h>
//#include<stdlib.h>
 
int rand = 10;
 
int main()
{
	printf("%d\n",rand);  
}
 //运行时编译没有报错!


// 将头文件<stdlib.h>注释取消, 报错了

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

在这里插入图片描述

报错的原因就在于,将头文件<stdlib.h>放开,在编译阶段,编译器会将头文件自动展开(拷贝),而头文件<stdlib.h>中包含函数随机值生成rand,全局域中的int类型的变量rand,与库函数rand同名, 命名冲突,编译器在发现同一作用域内有重复定义时,无法确定应该使用哪个定义,因此会报错

过往学习C的过程, 用C完成一个大型项目,不得不为了尽可能避免命名冲突选择及其长且复杂的命名风格。
C++中,namespace(命名空间)是用来组织代码的一种方式,它通过将变量、函数、类等放在不同的命名空间中,避免名称冲突。使用命名空间的目的是对标识符的名称进行本地化,以避免命名冲突和名字污染。

  • 定义命名空间,需要namespace关键字,后⾯跟命名空间的名字,然后接⼀对{}即可,{}中 即为命名空间的成员。命名空间中可以定义变量/函数/类型等。

类比C中的结构体:


namespace Test
{
	//变量
	int rand;
	//函数
	void func()
	{
		return;
	}
	//类
	class test
	{
	public:
		void Test()
		{
			return;
		}
	private:
		int a;
		int b;
	};
}
  • namespace本质是定义出⼀个域,这个域是命名空间域,和全局域各自独立,不同的域可以定义同名的变量

  • C++中域有函数局部域全局域命名空间域类域;域影响的是编译时语法查找⼀个变量/函数/ 类型出处(声明或定义)的逻辑,有了域隔离,名字冲突就解决。在C语言阶段, 局部域和全局域除了影响编译查找逻辑,同时影响变量的生命周期,而类域和命名空间域则不会。

  • namespace只能定义在全局,支持嵌套定义

  • 在这里插入图片描述
    在这里插入图片描述

namespace同名的情况?

  • 项目工程中可能会出现同名的命名空间的情况, 不必担心,编译器会自动合并成同一个, 不会有编译型错误。

  • C++标准库都放在⼀个叫std(standard)的命名空间中。

C语言中令人恼火的命名冲突的问题可以用命名空间来解决了!

#include<stdlib.h>
namespace Test
{
	int rand = 10;
}
int main()
{
	// 默认是访问的是全局的rand函数地址
	printf("%p\n", rand);
	// 指定Test命名空间中的rand
	printf("%d\n", Test::rand);
}

命名空间使⽤

编译查找一个变量的声明定义时,默认在局部或者全局查找,不会进入命名空间查找。
使用命名空间中定义的变量/函数,有三种⽅式:

  • 指定命名空间访问,项⽬中推荐这种⽅式。

  • using将命名空间中某个成员展开,项⽬中经常访问的不存在冲突的成员推荐这种⽅式。

namespace Test
{
	int a = 10;
	int b = 20;
}
using Test::a;//a成员被打开
 
int main()
{
	printf("a=%d,b=%d\n", a, Test::b);
	return 0;
}
  • 展开命名空间中全部成员,项⽬不推荐,容易冲突,仅作刷题日常练习使用即可。

namespace Test
{
	int a = 10;
	int b = 20;
}
using namespace Test;//展开命名空间的全部成员
 
int main()
{
	printf("a=%d,b=%d\n", a, b);
	return 0;
}

C++输⼊&输出

  • < iostream >是Input Output Stream 的缩写,是标准的输⼊、输出流库,定义了标准的输⼊、输 出对象。

  • std::cin 是 istream 类的对象,它主要⾯向窄字符(narrow characters (of type char))的标准输入流。

  • std::cout 是 ostream 类的对象,它主要⾯向窄字符的标准输出流。

  • std::endl是⼀个函数,流插⼊输出时,相当于插⼊⼀个换⾏字符加刷新缓冲区。

  • >>是流提取运算符。(C这两个运算符是位运算左移/右移, 不过这里可以充当流提取的作用。)

  • 使⽤C++输⼊输出更方便,不需要像printf/scanf输⼊输出时那样,手动指定格式,C++的输入输出可以自动识别类型。 C++的流更好地支持自定义类型的输入与输出。

  • IO流涉及类和对象,运算符重载、继承等面向对象的知识,仅简单认识⼀下C++IO流的用法,IO流库其后进一步说明。

  • cout/cin/endl等都属于C++标准库,C++标准库都放在⼀个叫·std(standard)·的命名空间中。使用它们要通过std的命名空间与域作用限定符::

  • 日常练习可以using namespace std;完全展开标准库,实际项目别这么干。

• 这里我们没有包含<stdio.h>,也可以使⽤printf和scanf,在包含间接包含了。vs系列 编译器是这样的,其他编译器可能会报错

#include
using namespace std;//日常小练习和OJ刷题推荐使用,大型项目不推荐,风险太大

int main1()
{
   int a = 10;
   double b = 5.9;
   char c = 'h';
   cout <<"a="<< a << " b=" << b << " c=" << c << endl;//自动识别类型
   printf("a=%d b=%0.1lf c=%c\n", a, b, c);
   return 0;
}

int main()
{
   int a = 10;
   double b = 5.9;
   char c = 'h';
   cin >>a >> b >> c;//可以自动识别类型
   cout << "a=" << a << " b=" << b << " c=" << c << endl;//自动识别类型
   printf("a=%d b=%0.1lf c=%c\n", a, b, c);
   return 0;
}

在io需求⽐较⾼的地⽅,如部分⼤量输⼊的竞赛题中,加上以下3⾏代码, 可以提⾼C++IO效率

#include<iostream>
using namespace std;
int main()
{
 ios_base::sync_with_stdio(false);
 cin.tie(nullptr);
 cout.tie(nullptr);
 return 0;

缺省参数

缺省参数(也称为默认参数)是在声明或定义函数时为某个参数提供的默认值。如果在调用函数时没有为该参数提供实际值(实参),则使用缺省值;如果提供了实参,则使用实参覆盖默认值。

#include<iostream>
using namespace std;

void greet(string name = "world") {
	cout << "Hello " << name << endl;
}

int main(void) {
	greet(); //不执行则参数默认为缺省值“world”
	greet("Java");
	greet("CPP");
	return 0;
}

在这里插入图片描述
缺省参数分为全缺省和半缺省。

  • 全缺省:全部形参给缺省值。
void Func(int a = 10, int b = 20, int c = 30)
{
cout<<"a = "<<a<<endl;
cout<<"b = "<<b<<endl;
cout<<"c = "<<c<<endl;
  • 半缺省:自右向左按顺序填充, 不能间隔。
void Func(int a, int b = 20, int c = 30)
{
cout<<"a = "<<a<<endl;
cout<<"b = "<<b<<endl;
cout<<"c = "<<c<<endl;
  • 缺省参数(默认参数)只能在函数的定义中提供,而不能在声明中提供,或者在声明和定义中重复指定(必须一致)。
//a.h
void Func(int a = 10);
// a.cpp
void Func(int a = 20)
{}
// 注意:如果生命与定义位置同时出现,恰巧两个位置提供的值不同,那么编译器无法确定到底该用那个缺省值。
  • 缺省值应该是常量字面量或者位于静态区(或全局变量)

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Grafana 可视化配置

Grafana 是什么 Grafana 是一个开源的可视化和监控工具&#xff0c;广泛用于查看和分析来自各种数据源的时间序列数据。它提供了一个灵活的仪表盘&#xff08;dashboard&#xff09;界面&#xff0c;用户可以通过它将数据源中的指标进行图表化展示和监控&#xff0c;帮助分析趋…

语音转文字工具全解析

无论是学生群体记录课堂笔记&#xff0c;职场人士整理会议纪要&#xff0c;还是自媒体创作者捕捉灵感火花&#xff0c;录音转文字软件都以其独特的便利性和高效性赢得了广泛的好评。今天&#xff0c;就让我们一起探索那些深受大家喜爱的录音转文字工具吧。 1.365在线转文字 链…

C++ | Leetcode C++题解之第397题整数替换

题目&#xff1a; 题解&#xff1a; class Solution { public:int integerReplacement(int n) {int ans 0;while (n ! 1) {if (n % 2 0) {ans;n / 2;}else if (n % 4 1) {ans 2;n / 2;}else {if (n 3) {ans 2;n 1;}else {ans 2;n n / 2 1;}}}return ans;} };

Window 本地启动Nacos

前言 本文帮助大家快速windows环境本地启动naco&#xff08;以版本2.2.3为例&#xff09; 进一步深入学习nacos推荐我的另外一篇文章&#xff1a; springCloud组件专题&#xff08;一&#xff09; --- Nacos_springcloud中的nacos如何使用-CSDN博客 ** 在本地启动nacos之前&…

C:字符函数与字符串函数-学习笔记

目录 1、字符分类函数 2、字符转换函数 3、字符串函数 4、strlen 函数的使用与模拟实现 4.1 strlen函数的使用 4.2 strlen函数的模拟实现 1、字符分类函数 C语言中有一系列的函数是专门做字符分类的&#xff0c;也就是一个字符是属于什么类型的字符的。 这些函数的使用都…

Vue(10)——自定义指令

自定义指令 自定义指令&#xff1a;可以封装一些dom操作&#xff0c;扩展额外功能。 全局注册-语法&#xff1a; Vue.directive(指令名,{ "inserted"(el){ inserted指指令所绑定的元素被添加到页面时自动调用 //可以对el标签扩展额外功能 el.focus() } }) 局部…

基于python+django+vue+MySQL的酒店推荐系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、SSM项目源码 系统展示 【2025最新】pythondjangovueMySQL的酒店推…

NLP中文本生成任务

文本生成任务 1.生成式任务2.自回归模型实现3.Encoder-Decoder结构3.1Attention机制出现3.2Attention思想3.3soft - Attention3.4hard - Attention3.5Teacher Forcing3.6详解Mask Attention3.6.1通过Mask控制训练方式 4.生成式任务评价指标5.生成式任务常见问题5.1采样策略5.2指…

深入解析Java内存模型:从堆到栈的全面剖析

在Java程序运行的背后&#xff0c;JVM&#xff08;Java Virtual Machine&#xff0c;Java虚拟机&#xff09;负责管理和分配内存。理解Java的内存模型&#xff08;Java Memory Model, JMM&#xff09;是编写高效、稳定程序的关键&#xff0c;尤其在并发编程中&#xff0c;内存管…

rose 聊开源—2 如何快速上手一个开源项目

在前面的一篇开源项目系列中&#xff0c;主要介绍了目前开源项目蓬勃发展的态势&#xff0c;并且拥有一个开源项目&#xff0c;对我们个人履历、职业发展等都有非常多的好处。 这一次就来跟大家分享一下&#xff0c;面对一个开源项目&#xff0c;我们应该如何上手&#xff0c;快…

【Android笔记】Android Studio打包 提示Invalid keystore format

前言 Android项目通过Android Studio生产签名文件进行打包。提示 com.android.ide.common.signing.KeytoolException: Failed to read key hocsdn from store "/Users/ho/TestProject/app/ho_developer.jks": Invalid keystore format 不合法的签名文件格式&#…

在职研生活学习--20240907

开学第一天 9月7日&#xff0c;中南大学商学院迎来了一支充满活力的队伍——2024级MBA新生集体整装待发&#xff0c;我们满怀期待地登上了前往长沙望城柏乐园的大巴&#xff0c;准备开启一场为期两天一夜的素质拓展与团队建设之旅。 迎新幼儿园PPT 出发 抵达柏乐园&#xff0c;…

Android生成Java AIDL

AIDL:Android Interface Definition Language AIDL是为了实现进程间通信而设计的Android接口语言 Android进程间通信有多种方式&#xff0c;Binder机制是其中最常见的一种 AIDL的本质就是基于对Binder的运用从而实现进程间通信 这篇博文从实战出发&#xff0c;用一个尽可能…

openssl的使用

1、编译 Github下载&#xff1a;https://github.com/openssl/openssl 官网下载&#xff1a;https://openssl-library.org/source/index.html 官网历史版本&#xff1a;https://www.openssl.org/source/old/ 1.1 Windows下编译 我的文章&#xff1a;OPC UA使用 Openssl库编译…

Golang | Leetcode Golang题解之第398题随机数索引

题目&#xff1a; 题解&#xff1a; type Solution []intfunc Constructor(nums []int) Solution {return nums }func (nums Solution) Pick(target int) (ans int) {cnt : 0for i, num : range nums {if num target {cnt // 第 cnt 次遇到 targetif rand.Intn(cnt) 0 {ans …

移动跨平台框架Flutter详细介绍和学习线路分享

Flutter是一款移动应用程序SDK&#xff0c;一份代码可以同时生成iOS和Android两个高性能、高保真的应用程序。 Flutter目标是使开发人员能够交付在不同平台上都感觉自然流畅的高性能应用程序。我们兼容滚动行为、排版、图标等方面的差异。 在全世界&#xff0c;Flutter正在被越…

基于SpringBoot+Vue+MySQL的滑雪场管理系统

系统展示 用户前台界面 管理员后台界面 系统背景 在快速发展的冰雪运动热潮下&#xff0c;为了提升滑雪场的管理效率与顾客体验&#xff0c;我们设计并实现了一套基于SpringBoot后端框架、Vue前端框架以及MySQL数据库的滑雪场管理系统。该系统旨在通过数字化手段&#xff0c;优…

(pandas读取DataFrame列报错)raise KeyError(key) from err KeyError: (‘name‘, ‘age‘)

&#xff08;pandas读取DataFrame列报错&#xff09;raise KeyError(key) from err KeyError: (‘name‘, ‘age‘) 欢迎来到英杰社区https://bbs.csdn.net/topics/617804998 欢迎来到我的主页&#xff0c;我是博主英杰&#xff0c;211科班出身&#xff0c;就职于医疗科技公司&…

瑞吉外卖—读写分离

文章目录 1. 概述2. MySQL主从复制2.1 介绍2.1 配置2.1.1 前置条件2.1.2 主库Master2.1.3 从库Slave 3. 读写分离案例3.1 背景3.2 Sharding-JDBC介绍3.3 入门案例 1. 概述 读写分离、主从复制。就是dml操作在主库、query操作在备份的从库。分担压力&#xff0c;减轻单点故障。…

标准库标头 <barrier>(C++20)学习

此头文件是线程支持库的一部分。 类模板 std::barrier 提供一种线程协调机制&#xff0c;阻塞已知大小的线程组直至该组中的所有线程到达该屏障。不同于 std::latch&#xff0c;屏障是可重用的&#xff1a;一旦到达的线程组被解除阻塞&#xff0c;即可重用同一屏障。与 std::l…