c++初阶学习----入门(上)
大家好啊。最近学习了一点关于c++的知识。这不就迫不及待的来与大家分享了嘛。但我这也是现学现卖所以咧。有很多遗落甚至不对的地方希望大家可以在评论区里面指出来。这样也可以增加大家对知识的巩固。
c语言与c++的联系
不知道大家看到c++会不会不由自主的联想到C语言啊。毕竟都是编程语言而且都带有一个c那么联想到应该很正常吧。反正开始的时候我身边的人是这样的。每当有人说着c++。哦,那个人不是学c语言的嘛。应该会吧。但是我开始对c++一点都不知道啊。但是经过今天的学习。我知道了。c++与c语言确实有很大的联系。
更加准确的说C++是在C语言的基础上发展而来的,它是完全兼容C语言的。大家还记得我们以前在vs里面创建项目的时候后缀打的是.c。当然写c++的代码vs还是适用的。只是后面我们创建c++项目的时候用的是.cpp了。
还有就是我们也可以在.cpp里面写c语言的代码。但是不能再.c里面写c++的代码。因为c++是在c语言的基础上延伸发展的。也可以说c++是以c语言为基础而衍生出来的更加先进的编程语言。 好了大家只是需要知道c++是以c语言为基础发展的并且c++包含c语言就可以了。
第一个代码
不知道大家是否还记得刚开始玩c语言的时候写的第一个代码是什么了。但是我觉得我当时写的第一个代码是关于printf的。然后对于c++的话我们这里也是实现关于printf的。大家可以看一下:
大家发现了吧。这个代码实现的效果与c语言中的printf是一样的。并且除了前期准备啊。代码量还像也差不多的。但是其中还有一些什么东西不理解啊。比如说什么std啊cout啊还有什么endl啊。大家别急。接下来我们就一一来讲解。
命名空间
对于c++的第一个正式知识点我们来讲讲命名空间namespace那命名空间的含义是啥咧。这个我们先来看看比较官方的解释是个啥:在C/C++中,变量,函数和后⾯要学到的类都是⼤量存在的,这些变量、函数和类的名称将都存在于全局作⽤域中,可能会导致很多冲突。使⽤命名空间的⽬的是对标识符的名称进⾏本地化,以避免命名冲突或名字污染,namespace关键字的出现就是针对这种问题的。
也就是说命名空间就是为了解决我们c语言中的名字重复。避免冲突。那么光讲的话也不能让大家理解,那么我们直接举个例子:
大家看一下上面的两个区别。一个报错一个成功打印了。大家还记得rand的作用吧。rand是生成一个随机数的。反正这也就表明嘛。这是库函数,在c语言中如果出现这样的话就不能实现效果,但是在c++里面我们只需要命名一下空间那么就变的合理了。这下子大家知道namespace的作用了吧。
并且大家也看到了namespace的用法就是namespace+名字。然后{}。在括号里面可以写可以定义变量/函数/类型等。就是说出来上面这个以外还可以定义一个变量以外还可以定义结构体,函数这些。
只要定义好了之后就可以正常使用了。 并且还可以嵌套命名空间就是一个命名空间里面还可以写其他的命名空间。
大家应该发现了吧。我在使用命名空间的时候再打印的时候是写的yh::rand。这就是使用命名空间的最基本的指定命名空间访问,大家可以理解为yh->rand。这是我们后面使用最常见且为最稳妥的一个用法了。还有一个用法就是using将命名空间中某个成员展开。什么意思咧。以上面这张图片来说就是将命名空间中的其中一些指定的成员,比如说经常使用的,免得每次都要指定。那么具体是什么样子的咧:
这里我们只放开了yh空间中的a。所以我们在使用的时候,只有a可以不在特定的引用了。其他的还是需要特定引用。 那既然有指定开,或者或是半开,那么有没有全开咧。嘿,可还真有。展开命名空间中全部成员 。含义显而易见吧,就是把整个 命名空间全部展开。这样就不需要大家特定指引了。但是这虽然看起来要号一些。但是项⽬不推荐,冲突⻛险很⼤。因为你本来就是为了防止命名冲突的,你这又全部展开了。岂不是没干了。但我们写代码较少的话也可以用,毕竟少嘛。风险也较小。但后面上班了。写项目了还是尽量或者别用:
大家也看到这里就了解了命名空间如何创建以及命名空间的三种用法了吧。
输入与输出
当我们学习了namespace后,我们就来聊聊代码中的第二个新知识点cout。大家可以稍微看一下下面的解释。
我们前面说过c++是c语言的发展。那么接下里我们要讲一个爽点。我们都还记得我们c语言输入与输出变量的话都需要确定我们输入与输出的类型。但是大家看我的那个代码,输出的时候我并没用写类型啊。是不是,这就是c++与c语言相比的一个爽点。
还有就是大家可以在io需求⽐较⾼的地⽅,如部分⼤量输⼊的竞赛题中,加上以下3⾏代码可以提⾼C++IO效率 。ios_base::sync_with_stdio(false); cin.tie(nullptr); cout.tie(nullptr);反正就是没写对我们现在是无差的。但是写了还是有意的。我们只管写进可以了。
缺省参数
什么叫缺省参数啊。没怎么听过啊。那么缺省参数就是声明或定义函数时为函数的参数指定⼀个缺省值。在调⽤该函数时,如果没有指定实参 则采⽤该形参的缺省值,否则使⽤指定的实参,缺省参数分为全缺省和半缺省参数。(有些地⽅把缺省参数也叫默认参数)
并且在c++中缺省参数分为半缺与全缺。名字显而易见,全缺就是没有指定实参。半缺就是有一部分确定了实参。
C++规定半缺省参数必须从右往左依次连续缺省,不能间隔跳跃给缺省值。带缺省参数的函数调⽤,C++规定必须从左到右依次给实参,不能跳跃给实参。函数声明和定义分离时,缺省参数不能在函数声明和定义中同时出现,规定必须函数声明给缺省值。
就是说缺省参数定义的话只能从右向左缺。就是右边开始没有。调用的话就是翻过来的。然后声明必须确定缺省值。那么上面是什么意思咧。我们来讲讲。
我们可以看看我们上面写的这个代码。第一个Func我们就没传参数啊。我在引用的时候写了a与b的值。这就是我们在没有传参的时候使用默认的参数。并且这个还是一个全缺省参数。怎么看的咧。什么看我们在引用的时候是不是直接都赋了值的。也就是说就算我们在调用的时候没有传参,c++还是加油用默认参数给出一个答案。
接下来就是半缺,我们讲过,我们在写的时候从右向左。调用的时候从左向右。我们如果是半缺的话就不能像全缺那样,一个都不写。比如说:
我们可以看到半缺的时候我们如果一个没写,系统是会提醒的。这就表明我们半缺你要保证我们使用的式子每一个都有参数。那个缺了就补那个。并且不能跳跃。这也是系统不允许的。我们至少要保证完成这个样子。
对于缺省参数我们还有一个知识点就是缺省参数不能声明和定义同时给。什么意思咧。大家看一下下面的这个照片就知道了 。
总结
好的,上面就是c++的初阶学习的上篇了,然后我们接下来还会有一个下篇。这里我们主要先交代一些让大家消化一下,毕竟刚从c语言转到c++的话,可能还会有一点不理解,所以先给大家一点时间看一下,消化一下。这里只是开胃菜,然后大家还是需要把这些记住,因为后面对于c加加的学习和使用的话会用的比较多。
原文地址:https://blog.csdn.net/2302_80318761/article/details/140301195
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!