(Boolan) C++面向对象高级编程(二)

本文通过国王与宝箱的故事,形象地解释了C++中指针作为类设计分界点的原因,探讨了如何管理带有指针的class,包括析构函数、拷贝构造和拷贝赋值等问题。文章通过分析内存管理中的栈和堆,阐述了动态内存分配的原理和潜在的内存泄漏风险,强调了正确管理指针的重要性。

之前写到了关于不带有指针的class的设计思路和注意事项,但是对于C/C++语言来说,还有一个非常重要的概念就是指针,为什么将指针作为class设计的分界点呢?那么,之前我讲了一个关于猫ヽ(=^・ω・^=)丿的故事,那么今天我再来讲一个关于国王和宝箱的故事吧 <( ‵□′)───C<─_-)||。

关于 指 针(钥匙)的一个小故事

语文老师教导,讲故事需要先说明时间地点人物发生了啥:
话说很久很久以前(发现词语好匮乏、、、),在遥远的国度有一个国王(突然想起了和尚),他有一件十分心爱的具备魔法的宝物,每次祭奠、仪式都会用到这个宝物的魔力。

而这个宝物由十个部件组成,每次只有将十个部件全部拼接在一起才会发挥他的魔力(少了任何一块都不行(¬_¬))。由于国王爱这个宝物爱的死去活来的,为了防止他过度沉溺在宝物的喜爱中无法自拔而耽误朝政((=。=)其实我想说,到底啥宝物这么有吸引力。。。故事设定。。。(▼皿▼#) ....就这样吧)。

国王的爹爹(居然没死╮(╯_╰)╭)将这个的碎片分别锁在了十个宝箱里面(ヾ(゚∀゚ゞ)这个故事背景我实在快编不下去了.......)。。。而每个箱子都对应一把独特的钥匙(废话。。。。。一把钥匙开一把锁━━( ̄ー ̄|||━━),特殊之处在于
这 个 钥 匙 不 但 可 以 打 开 箱 子 还 可 以 记 录 箱 子 在 哪 里 ,

而国王的爹爹把这十把钥匙分别交给了十个大臣来保管,也就是只有当国王召集了十个大臣以后才能够一睹宝物的真面目。

ps: (● ̄(エ) ̄●)背景就交代在这吧,虽然不合逻辑的地方很多,但是为了说清楚这个事,也就当作合理吧。

那 么 问 题 来 了 !!!( ⊙ o ⊙ )
等到国王的爹爹死了,国王也长大了不少,决心要做一个好的国王,已经不那么迷恋那个宝物了。但是每次在使用宝物的时候,国王发现实在太麻烦了,每次都要十个大臣全来了才能取出宝物的每个部件。有好几次急用的时候(,,#゚Д゚),大臣由于各种原因不能来把要是交给国王。还有的时候,十个大臣都来了,但是谁也不知道该开哪个箱子,每次都要一个个是试也是很大无时间的。
有 没 有 办 法 能 帮 助 国 王 来 管 理 他 这 些 箱 子 呢 ( ▔•з•▔ )?*

这个 精彩绝伦(漏洞百出)的故事讲完了,但是这里面其实引出来的问题值得我们探讨一下的。方法太多了,我来简单说说几个拙见吧。

  • 方法一:
    将十个宝箱和每个大臣手里面的钥匙按照对应关系编号[0-9],至于摆放顺序其实无所谓了,每个箱子上都有自己的编号,每次大臣来齐了就能很快的打开所有的箱子了。(好像和之前比只是加上了序号)
    • 总结:
      1 能够方便快速的打开箱子(真的快速吗?!难道箱子是乱放的,难道不需要找吗)
      2 但是每次打开箱子都必须十个大臣到场,如果少了其中某个就不能打开全部箱子了(而且每次去开箱子的时候都需要所有大臣在场,否则,去了五号箱子那,发现其余大臣都在,唯独五号大臣不在,就抓瞎了)
  • 方法二:
    还是先将箱子和钥匙进行编号,然后将9号箱子的钥匙以及他所在位置放在8号箱子中,将8号箱子的钥匙以及他所在位置放在7号箱子中......将1号箱子的钥匙以及他所在位置放在0号箱子中。
    完成了钥匙和位置的分配,现在只需要一个大臣拿着钥匙就能开启所有的箱子啦~ ~ ~ ~ ~ ~

    • 总结:
      1 只需保存一个箱子的钥匙就可以管理所有的10个箱子啦(听起来不错,但真就这么简单吗?!)
      2 不需要担心钥匙和箱子位置具体在哪的问题(真的吗?!)
      3 拿着钥匙的那个大臣权利集中,一旦他丢了钥匙,所有箱子都无法打开
      4 如果中间某个箱子的位置或者钥匙放错了或者忘记了放进去~~~~那么后续的箱子就等于丢了(拿到了第一把钥匙也打不开后面的锁了、、、、)
      5 假设某一天国王想看看第十个箱子里面的东西的时候~ ~ ~那就麻烦了,得把前面几个箱子都打开才行(十个箱子好像好像还好,那假设有十万个或者十亿个箱子呢?他也许就只为了看看最后一个箱子就变成了一个开了一辈子箱子的国王(为啥突然想起来做木匠活的皇帝....))
      6 如果某天国王想要在这群箱子中插入个箱子,只需要管理需要插入位置前后的箱子就行了(这个优点今天可能用不到(  ̄ー ̄)(  ̄ー ̄)就先放着吧)
  • 方法三:
    将十个箱子并排放在一起,[ 0 ][ 1 ][ 2 ][ 3 ]....[ 9 ],箱子之间会形成自然顺序。将下个箱子的钥匙放在上个箱子上(这时候不需要保存位置啦,因为就在他旁边嘛)。也就是将9号箱子的钥匙以及他所在位置放在8号箱子上,将8号箱子的钥匙以及他所在位置放在7号箱子上......将1号箱子的钥匙以及他所在位置放在0号箱子上(注意没有放在箱子里面!!!)。

    • 总结
      1 箱子的位置不用担心了,都在这一排摆着呢(但是需要考虑的是万一、、、没有地方放下这么多连续的箱子可怎么办,也就是对空间的要求更高了,十个箱子好像还好~~但是加入十万个、十亿个箱子呢?)
      2 保存一个钥匙就可以管理全部的箱子了,也存在权利过分集中的问题,如果,外面的那把钥匙丢了、、、、箱子全都报废了
      3 如果这时候国王想要看看其中某个箱子,那么只需要按照序号去看看就行了,毕竟钥匙就放在之前的箱子上面(如果这里是十万个箱子,国王也可以不费劲的从里面找出他想要的那个~ ~ ~ ~)
      4 突然某一天国王想插入一个箱子,如果箱子是插在最后没啥问题,很容易,但是、、、、如果国王想要插入的位置是第一个,那么国王得把所有的箱子往后诺一个位置才行,如果是十亿个箱子呢?又出现了个挪了一辈子箱子的国王
  • 你TM弄了这么久箱子!!(# ゚Д゚)到底想干嘛(# ゚Д゚)?!

    其实这个故事虽然存在很多不合理的地方,但实际是想做一个关于 数 据 结 构 的比喻。

    • 每个箱子里面保存的“宝藏”,就相当于——数据
    • 箱子以及箱子所处的位置,就相当于——内存

      C/C++毕竟是 直 接 面 对 内 存 的语言,所以程序员难免要考虑这些“箱子们和钥匙们” 的摆放和打开的问题

      还 有 就 是 ,这 些 管 理 方 法 后 面 肯 定 是 有 用 的 ~ ~ ~ ~ ~ ~, 就 先 放 在 这 里 , 我 之 后 再 提

回到之前的一个问题,为什么类要用带有指针和不带指针来进行区分呢???

考虑柔性负荷的综合能源系统低碳经济优化调度【考虑碳交易机制】(Matlab代码实现)内容概要:本文围绕“考虑柔性负荷的综合能源系统低碳经济优化调度”展开,重点研究在碳交易机制下如何实现综合能源系统的低碳化与经济性协同优化。通过构建包含风电、光伏、储能、柔性负荷等多种能源形式的系统模型,结合碳交易成本与能源调度成本,提出优化调度策略,以降低碳排放并提升系统运行经济性。文中采用Matlab进行仿真代码实现,验证了所提模型在平衡能源供需、平抑可再生能源波动、引导柔性负荷参与调度等方面的有效性,为低碳能源系统的设计与运行提供了技术支撑。; 适合人群:具备一定电力系统、能源系统背景,熟悉Matlab编程,从事能源优化、低碳调度、综合能源系统等相关领域研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①研究碳交易机制对综合能源系统调度决策的影响;②实现柔性负荷在削峰填谷、促进可再生能源消纳中的作用;③掌握基于Matlab的能源系统建模与优化求解方法;④为实际综合能源项目提供低碳经济调度方案参考。; 阅读建议:建议读者结合Matlab代码深入理解模型构建与求解过程,重点关注目标函数设计、约束条件设置及碳交易成本的量化方式,可进一步扩展至多能互补、需求响应等场景进行次开发与仿真验证。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值