对C++中作用域标示符的认识

在类的继承与派生中,为了保证标示符的唯一,就出现了标示符,形式是“::”。就是双冒号。

使用形式:类名::数据成员

类名::成员函数(参数)

一:多继承并且上级无基类的情况

在这种情况下,如果派生类中声明了 基类中同名的成员,就会出现同名隐藏。如果是成员函数,即使形参表不同,也不是重载函数,因为重载函数是在同一个作用域中声明的。但如果在派生类中的同名成员前使用“using   类名::成员函数(参数)“这种形式,那么如果参数表不同,就是重载函数了。当出现同名隐藏时,使用对象 访问同名成员时,只能访问新增的同名成员,如果要访问基类的同名成员,就要使用标示符来进行限定。如果派生类中没有同名成员,要访问基类的成员也要使用标示符进行限定。

二:多继承并且有上级基类的情况

在这种情况中,要访问间接基类的成员,要使用直接基类名进行限定才行。

在这种情况中,会出现同名成员有多个副本的情况,占用内存,要解决这个问题就出现了虚基类的概念。

以上就是我对于作用域标示符的认识。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C语言作用域标识主要有局部作用域、类作用域和全局作用域。局部作用域包括函数原型作用域和块作用域,它们限定了变量的有效区域。类作用域是指在类的定义声明的成员变量和成员函数的作用域。全局作用域是指在整个程序文件声明的变量和函数的作用域,也可以使用命名空间来定义全局作用域。 在C语言,可以使用using操作来简化对程序库标识的使用。使用using namespace std;可以将std命名空间标识引入到当前的作用域,这样就可以直接使用cout、cin等输入/输出流的功能了。 另外,C语言的头文件命名规范发生了变化。早期的实现将标准库功能定义在全局空间,声明在带.h后缀的头文件里。然而,C标准为了和C++区别,也为了正确使用命名空间,规定头文件不使用后缀.h。因此,如果使用<iostream.h>头文件,相当于在C调用函数库,使用的是全局命名空间;而使用<iostream>头文件时,必须使用namespace std;来正确使用iostream库标识。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [[C++]标识作用域与可见性](https://blog.csdn.net/weixin_60479183/article/details/128593804)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值