C++跨类调用(类间值传递、跨类调用方法)

2024-04-25 19:08

本文主要是介绍C++跨类调用(类间值传递、跨类调用方法),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

C++跨类调用(类间值传递、跨类调用方法)

  • 1.通过全局变量实现跨类调用
    • (1)优缺点
    • (2)思想原理
    • (3)具体流程
  • 2.通过类内指针变量实现跨类调用
    • (1)优缺点
    • (2)思想原理
    • (3)具体流程

在面向对象编程的时候经常会遇到不同类实例之间的跨类调用,包括跨类值传递以及跨类调用方法,实际运用是有很多方法都可以解决这一问题,今天主要总结2个常用且通用的方法。

1.通过全局变量实现跨类调用

(1)优缺点

优点: 简单,快速,方便理解,尤其类实例个数时非常方便。
缺点: 安全性低,类实例个数多少时非常不方便,容易出现错误。

(2)思想原理

定义若干全局指针变量存储每个类的每个实例对象的指针(当然是需要互相调用的,不调用的肯定是不写咯!!!),在实例化对象建立后将全局指针变量指向该实例对象,在任何地方(包括类内)都可以利用这个指针调用相应的方法,获得相应的成员变量。注意:每个实例对象对应一个指针,不是每个类,分不清类与实例的自行百度。

(3)具体流程

以下面的例子来说明具体的流程:
:现有 类A的实例对象a想要获取类B实例化对象b的成员变量m_b的值。
(a)A.h , B.h 都无需做任何修改。
(b)B.cpp中包含A的头文件,定义一个全局的B类指针pB。

			CB * pB = new CB;

(c)在实例化b的.cpp文件中添加

			extern CB * pB;	//extern表示变量或者函数的定义在别的文件中

(d)在b实例化时将pB指向b。

			CB * b = new CB();  //调用的构造函数不同时,应该传入参数pB = b;

注:这里也可以利用B的构造函数将pB指向b,适用于只有一个B类实例时。具体做法是在B.pp中添加

			extern CB * pB;

在B的构造函数中添加

			pB = this;		//构造的实例的指针保存在pB中;

这样就可以在整个工程中随意调用b的成员变量和成员函数了,当然调用前需要用extern CB * pB;先声明。

2.通过类内指针变量实现跨类调用

(1)优缺点

优点: 安全性高,尤其类实例个数时非常快速方便。
缺点: 相对复杂,理解稍微困难。

(2)思想原理

在类内添加被调类的指针为成员变量,在被调用类的对象实例化以后,将指针(成员变量)指向该实例,之后就可以通过关联的实例完成跨类调用。

(3)具体流程

以下面的例子来说明具体的流程:
:现有 类A的实例对象a想要获取类B实例化对象b的成员变量m_b的值;
类B的实例对象b想要获取类A实例化对象a的成员变量m_a的值。

(a)A.h , B.h 中分别包含对方的头文件。
(b)CA中添加B类的指针,CB中添加A类的指针;

			CB * pB;		//A.h中添加CA * pA;		//B.h中添加

此时编译连接会报错,因为这是一个“鸡生蛋,蛋生鸡的问题”
^ _ ^ 感兴趣可以研究一下C++的编译链接过程。下一步就是解决这一问题。
(c)A.h中A类声明前添加B类声明;B.h中B类声明前添加A类声明;

			class CB;	// A.h中A类声明前class CA;	// B.h中B类声明前

(d)指针实例化各类对象后,将指针指向各类的实例对象

			CA* a = new CA();		//注意构造函数......CB* b = new CB();		//注意构造函数// 实例化完成后立即进行关联a->pB = b;b->pA = a;

此时就可用类内的指针访问其他类实例对象的成员变量以及成员函数。

说了这么多肯定很多同学在疑惑为什么第二种方法这么复杂,存在的意义何在,再次简单说明一下第二种方法存在的合理性。
通常我们定义的一个类基本就只有一个或者少数几个类实例对象,这种情况有第一种方法就可以很快的完成开发(除非BOOS不让你用全局变量)。但是如果我们有100个A类的实例对象,每个都需要单独的读取或者调用B类的100实例对象中的某个实例对象的成员变量或者成员函数呢?是不是想想就头大呢?这么多全局变量,还要对应,光写代码时就会出错,同时还毫无安全性可言。这时利用第二种方法就可以较快速的完成开发。

由于本人能力限制,如果有不对的地方还望大神指正。

这篇关于C++跨类调用(类间值传递、跨类调用方法)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/935536

相关文章

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

C++包装器

包装器 在 C++ 中,“包装器”通常指的是一种设计模式或编程技巧,用于封装其他代码或对象,使其更易于使用、管理或扩展。包装器的概念在编程中非常普遍,可以用于函数、类、库等多个方面。下面是几个常见的 “包装器” 类型: 1. 函数包装器 函数包装器用于封装一个或多个函数,使其接口更统一或更便于调用。例如,std::function 是一个通用的函数包装器,它可以存储任意可调用对象(函数、函数

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

如何在页面调用utility bar并传递参数至lwc组件

1.在app的utility item中添加lwc组件: 2.调用utility bar api的方式有两种: 方法一,通过lwc调用: import {LightningElement,api ,wire } from 'lwc';import { publish, MessageContext } from 'lightning/messageService';import Ca

06 C++Lambda表达式

lambda表达式的定义 没有显式模版形参的lambda表达式 [捕获] 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 有显式模版形参的lambda表达式 [捕获] <模版形参> 模版约束 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 含义 捕获:包含零个或者多个捕获符的逗号分隔列表 模板形参:用于泛型lambda提供个模板形参的名

浅谈主机加固,六种有效的主机加固方法

在数字化时代,数据的价值不言而喻,但随之而来的安全威胁也日益严峻。从勒索病毒到内部泄露,企业的数据安全面临着前所未有的挑战。为了应对这些挑战,一种全新的主机加固解决方案应运而生。 MCK主机加固解决方案,采用先进的安全容器中间件技术,构建起一套内核级的纵深立体防护体系。这一体系突破了传统安全防护的局限,即使在管理员权限被恶意利用的情况下,也能确保服务器的安全稳定运行。 普适主机加固措施:

webm怎么转换成mp4?这几种方法超多人在用!

webm怎么转换成mp4?WebM作为一种新兴的视频编码格式,近年来逐渐进入大众视野,其背后承载着诸多优势,但同时也伴随着不容忽视的局限性,首要挑战在于其兼容性边界,尽管WebM已广泛适应于众多网站与软件平台,但在特定应用环境或老旧设备上,其兼容难题依旧凸显,为用户体验带来不便,再者,WebM格式的非普适性也体现在编辑流程上,由于它并非行业内的通用标准,编辑过程中可能会遭遇格式不兼容的障碍,导致操

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)