当前位置: 首页 > news >正文

初始化列表友元嵌套

在类中我们存在构造函数

e.g

class Stack

{

Stack(int capacity = 4)

{

.......

}

private:

int * arr;

int _capacity;

int _num;

};

在学习之前我们要明白为{}中时进行赋值操作,而非真正意义上的初始化,因此对于一些必须要初始化的类型就会出现问题,比如const & 没有默认构造函数的自定义类型

所以我们cpp中专门进行处理 初始化列表 专门用来进行初始化

我在学的时候,就有一个问题,既然这样为什么在一开始设计的时候不直接把初始化列表集成到{}中?

但说白了,首先说结论,逻辑会出现问题.

1.

{} 是一个语法块,他的执行完全是按照代码顺序,而在内存中声明顺序决定的这些成员在内存的先后顺序.

2.

{} 中会出现重复的问题,初始化只能进行一次,语法块中能进行多次赋值操作,会混淆

因此我们要接受初始化列表,他其实是很有作用的

结构:(每两个之间用逗号 ',',最后不用加 ;)

class Stack

{

Stack(int capacity = 4)

:_capacity(capacity) ---初始化列表就是一个专门用来初始化的地方

,i(1)

{

.......

}

private:

int * arr;

int _capacity;

const int i;

int _num;

};

友元

1.友元函数-->解决了外部访问类中private/protected 成员

class Stack

{

friend void Get_capacity(const Stack& st);

Stack(int capacity = 4)

:_capacity(capacity) ---初始化列表就是一个专门用来初始化的地方

,i(1)

{

.......

}

private:

int * arr;

int _capacity;

const int i;

int _num;

};

void Get_capacity(const Stack & st);

这样声明就代表着这个函数是这个类的友元的函数(想象成朋友),可以访问 非public成员.

2.友元类

class Stack1 class Stack2

{{

friend class Stack2;

Stack1(int capacity = 4)Stack2(int capacity = 5)

:_capacity(capacity):_capacity(capacity)

,i(1),i(1)

{{

.............

}}

private:privat:

int * arr;int* arr;

int _capacity;int _capacity;

const int i;const int i;

int _num;int _num;

};};

表示stack 2 中能够调用stack1中的非公开成员,但不是stack1能调用stack2中的非公开成员

嵌套:

class Stack

{

Stack(int capacity = 4)

:_capacity(capacity)

,i(1)

{

.......

}

class S

{

S(int capacity = 4)

:_capacity(capacity)

,i(1)

{

.......

}

private:

int * arr;

int _capacity;

const int i;

int _num;

};

private:

int * arr;

int _capacity;

const int i;

int _num;

};

这里需要特别注意,可以进行类比,你在全局中定义了class stack 就相当于在class stack中定义了class S,所以这两个类完全是独立的类!!!

1.在没有外部类实例的情况下,你无法调用非静态的成员,可以想象成还没有定义,因此在要是想调用外部类的成员时,要创建一个实例,通过这个实例来实现对外部类成员的调用,在调用的功能上时和友元类相同的

#include<iostream>

using namespace std;

class A

{

private:

static int _k;

int _h = 1;

public:

class B // B默认就是A的友元

{

public:

void foo(const A& a)

{

cout << _k << endl; //OK

cout << a._h << endl; //OK

}

int _b1;

};

};

int A::_k = 1;

int main()

{

A::B b;

A aa;

b.foo(aa);

return 0; }

因为这两个可以是作为独立的类,因此A类的大小是 4 ,静态变量,函数都不算作A类的内存大小

http://www.jsqmd.com/news/165865/

相关文章:

  • 无需Anaconda臃肿包!轻量级Miniconda-Python3.9玩转PyTorch
  • 2025沙发垫沙发巾厂家电话推荐:优质之选任你挑 - 栗子测评
  • 2025洛阳汽车窗膜服务TOP5权威推荐:深度测评指南 - 工业推荐榜
  • Markdown+Jupyter:用Miniconda-Python3.9打造优雅的技术博客写作环境
  • CUDA安装后PyTorch仍用CPU?Miniconda-Python3.9镜像torch.cuda.is_available()验证
  • 全域电商店铺品牌代运营是做哪些服务的?
  • 读书笔记2
  • 基于Miniconda-Python3.9的大模型Token生成环境搭建指南
  • 2025年靠谱瓦楞包装纸箱加工厂排名:售后好、技术强的值得选生产厂推荐 - myqiye
  • 2025年SSD厂家推荐榜:龙芯ssd/加固存储服务器ssd/工控机ssd/工业嵌入式主板ssd/加固平板电脑ssd/加固笔记本电脑ssd源头厂家精选 - 品牌推荐官
  • 接口自动化测试之pytest 运行方式及前置后置封装
  • 如何利用尺寸管理实现从被动救火到主动预防的质量转型?
  • 2025年不锈钢筛管/筛板/水帽/中排/V型筛板实力厂家推荐:江苏润达筛管筛板有限公司,适配工业水处理、石油、化工多场景过滤需求 - 品牌推荐官
  • 2025年佛山座椅电梯专业供应商排行榜,新测评精选座椅电梯服务厂商推荐 - mypinpai
  • Spring Boot进行单元测试,一个思路解决重启低效难题
  • 2025 北京眼镜城配镜指南:5 家高口碑店铺实测 专业与性价比双选 - 品牌推荐排行榜
  • 2025年ICP办理机构权威推荐榜:ICP许可证/备案/经营许可证/证书代办/网络经营许可证,合规咨询与一站式服务厂家精选 - 品牌推荐官
  • PyTorch安装踩坑总结:Windows/Linux/Mac通用解决方案
  • 清华源、阿里云源哪个更快?Miniconda pip源切换实测对比
  • 【onnx-mlir】DialectBuilder设计学习
  • 可见光/近红外单光子探测器实力生产商,国产品牌哪家口碑好? - 品牌推荐大师
  • 别再当“RAG复读机“了!智能体让大模型开发“智商“飙升,小白必看!
  • 从申请到获批:新加坡移民公司成功案例有哪些?揭示核心竞争力! - 速递信息
  • 从零开始搭建深度学习环境:Miniconda + PyTorch + CUDA全流程
  • 2025液压管件批发零售,优质快速交货液压接头厂家盘点 - 栗子测评
  • 网关路由设计与性能优化
  • 2025同步带厂家哪家好?深耕行业的优质厂商大盘点 - 栗子测评
  • 工业物联网助力打造数字化工厂与智能制造管理体系
  • 计算机毕业设计springboot在线美食点评系统 基于SpringBoot的云端舌尖口碑平台 SpringBoot驱动的网络餐饮体验分享社区
  • 2025宁波液压管件出口商/英文网站液压管件工厂测评 - 栗子测评