C++在线运行

版本:

所属目录
点击了解高性能代码运行API
运行结果
教程手册
代码仓库
极速运行
交互输入
极速运行模式,更高效的运行,点击编辑器上方的运行按钮即刻体验吧。
以下是用户最新保存的代码
钱币找零问题 发布于:2022-11-10 21:10 分糖果的问题 发布于:2022-11-11 21:02 二分查找的变形 发布于:2022-11-08 10:24 二分查找的实现 发布于:2022-11-08 10:24 二分查找的变形 发布于:2022-11-08 09:10 基数排序的过程 发布于:2022-11-07 21:22 二分查找的实现 发布于:2022-11-07 21:11 基数排序的代码实现 发布于:2022-11-08 14:44 二分查找的变形 发布于:2022-11-07 19:50 二分查找的代码 发布于:2022-11-07 19:47 基数排序的全过程 发布于:2022-11-07 19:46 测试类的继承,构造等 发布于:2022-11-07 19:16 一个跳动的爱心 发布于:2022-11-07 14:57 二分查找。 发布于:2022-11-07 09:54 二分查找,变! 发布于:2022-11-07 09:51 基数排序。 发布于:2022-11-07 09:13 二分查找代码 发布于:2022-11-07 03:47 基数排序代码 发布于:2022-11-07 03:42 二分查找以及四种变形的实现 发布于:2022-11-07 00:05 跳格子 每次能跳2^k个格子,求n个格子共有几种跳法。 规律:let m = [log(2,n)] ([x]表示取不大于x的整数部分) f(n) = Σ(i=0,m)f(n-2^i) 发布于:2022-11-09 21:32 基数排序实现 发布于:2022-11-06 20:48 求有限整数列中的最大值 发布于:2022-11-10 12:38 二分查找的变形。 发布于:2022-11-06 13:48 二分查找7的位置。 发布于:2022-11-06 13:30 关于雅克比迭代, 高斯塞德尔迭代以及SOR迭代的C++实现 发布于:2022-11-06 00:32 iowildfidf ddsauhio 发布于:2022-11-05 20:46 一个简单的东西 发布于:2022-11-05 19:50 组合 要求m个正整数相加的和为n,输出满足这个条件的正整数组合有多少。 发布于:2022-11-05 19:34 smfghjhfkjewhghje w 发布于:2022-11-05 19:38 贪心算法求解背包问题 发布于:2022-11-06 10:50 基数排序3 44 38 5 47 15 36 26 27 2 46 4 19 50 48 发布于:2022-11-05 16:22 通过栈实现 1.括号匹配 2.中缀表达式转后缀表达式 3.后缀表达式计算(结果大于10入栈会有问题,还需后续优化) 发布于:2022-11-05 11:43 n个数不相邻的组合数 发布于:2022-11-04 21:32 指针和别名的常量转换const_cast均无法改变数字常量的原值,但可以改变文字变量型常量,如aa=cc 发布于:2022-11-04 16:52 文字常量 与数字常量的 const_cast 发布于:2022-11-04 16:41 计算a1+(n-1)*(a2-a1)结果 发布于:2022-11-04 16:17 课上练习 转换构造函数 发布于:2022-11-04 11:11 查找IP地址的所属地 发布于:2022-11-03 21:28 查找IP地址的所属地 发布于:2022-11-03 21:18 二分查找的变形 发布于:2022-11-03 21:18 二分查找的变形 发布于:2022-11-03 21:04 计数排序算法 发布于:2022-11-03 20:58 桶排序算法 发布于:2022-11-03 20:55 二分查找的代码 发布于:2022-11-03 20:45 二分查找的代码 发布于:2022-11-03 20:46 基数排序的实现 发布于:2022-11-03 20:24 桶排序代码。 发布于:2022-11-03 20:14 算法实验课 发布于:2022-11-03 19:41 顺序表代码 发布于:2022-11-03 19:19 豆子装包问题 发布于:2022-11-11 20:30 [更多]
显示目录

数据抽象



C++ 数据抽象

数据抽象是指,只向外界提供关键信息,并隐藏其后台的实现细节,即只表现必要的信息而不呈现细节。

数据抽象是一种依赖于接口和实现分离的编程(设计)技术。

让我们举一个现实生活中的真实例子,比如一台电视机,您可以打开和关闭、切换频道、调整音量、添加外部组件(如喇叭、录像机、DVD 播放器),但是您不知道它的内部实现细节,也就是说,您并不知道它是如何通过缆线接收信号,如何转换信号,并最终显示在屏幕上。

因此,我们可以说电视把它的内部实现和外部接口分离开了,您无需知道它的内部实现原理,直接通过它的外部接口(比如电源按钮、遥控器、声量控制器)就可以操控电视。

现在,让我们言归正传,就 C++ 编程而言,C++ 类为数据抽象提供了可能。它们向外界提供了大量用于操作对象数据的公共方法,也就是说,外界实际上并不清楚类的内部实现。

例如,您的程序可以调用 sort() 函数,而不需要知道函数中排序数据所用到的算法。实际上,函数排序的底层实现会因库的版本不同而有所差异,只要接口不变,函数调用就可以照常工作。

在 C++ 中,我们使用来定义我们自己的抽象数据类型(ADT)。您可以使用类 ostreamcout 对象来输出数据到标准输出,如下所示:

#include <iostream>
using namespace std;

int main( ) {
   cout << "Hello C++" <<endl;
   return 0;
}

在这里,您不需要理解 cout 是如何在用户的屏幕上显示文本。您只需要知道公共接口即可,cout 的底层实现可以自由改变。

访问标签强制抽象

在 C++ 中,我们使用访问标签来定义类的抽象接口。一个类可以包含零个或多个访问标签:

  • 使用公共标签定义的成员都可以访问该程序的所有部分。一个类型的数据抽象视图是由它的公共成员来定义的。
  • 使用私有标签定义的成员无法访问到使用类的代码。私有部分对使用类型的代码隐藏了实现细节。

访问标签出现的频率没有限制。每个访问标签指定了紧随其后的成员定义的访问级别。指定的访问级别会一直有效,直到遇到下一个访问标签或者遇到类主体的关闭右括号为止。

数据抽象的好处

数据抽象有两个重要的优势:

  • 类的内部受到保护,不会因无意的用户级错误导致对象状态受损。
  • 类实现可能随着时间的推移而发生变化,以便应对不断变化的需求,或者应对那些要求不改变用户级代码的错误报告。

如果只在类的私有部分定义数据成员,编写该类的作者就可以随意更改数据。如果实现发生改变,则只需要检查类的代码,看看这个改变会导致哪些影响。如果数据是公有的,则任何直接访问旧表示形式的数据成员的函数都可能受到影响。

数据抽象的实例

C++ 程序中,任何带有公有和私有成员的类都可以作为数据抽象的实例。请看下面的实例:

#include <iostream>
using namespace std;

class Adder{
   public:
      // 构造函数
      Adder(int i = 0)
      {
        total = i;
      }
      // 对外的接口
      void addNum(int number) {
          total += number;
      }
      // 对外的接口
      int getTotal() {
          return total;
      };
   private:
      // 对外隐藏的数据
      int total;
};
int main( ) {
   Adder a;

   a.addNum(10);
   a.addNum(20);
   a.addNum(30);

   cout << "Total " << a.getTotal() <<endl;
   return 0;
}

当上面的代码被编译和执行时,它会产生下列结果:

Total 60

上面的类把数字相加,并返回总和。公有成员 addNumgetTotal 是对外的接口,用户需要知道它们以便使用类。私有成员 total 是用户不需要了解的,但又是类能正常工作所必需的。

设计策略

抽象把代码分离为接口和实现。所以在设计组件时,必须保持接口独立于实现,这样,如果改变底层实现,接口也将保持不变。

在这种情况下,不管任何程序使用接口,接口都不会受到影响,只需要将最新的实现重新编译即可。

由JSRUN为你提供的C++在线运行、在线编译工具
        JSRUN提供的C++ 在线运行,C++ 在线运行工具,基于linux操作系统环境提供线上编译和线上运行,具有运行快速,运行结果与常用开发、生产环境保持一致的特点。

title

使用此草稿 删除草稿

  • 00:23
注册登录后可减少验证码的弹出,点击前往 注册 | 登录

皮肤:

运行模式:

嵌入代码 iframe嵌入:


服务器已安装大部分常用的依赖库,但仍会存在一些未被安装的库, 可以通过本窗口立即安装所需依赖库,请确保库名正确,否则无法安装成功。


请输入依赖库的名称:

请选择语言: