成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

EasyC++,抽象數據類型

開發 后端
我們在學數據結構的時候,經常遇到的一個概念就是抽象數據類型(Abstract Data Type),簡稱ADT。

[[440257]]

大家好,我是梁唐。

抽象數據類型

我們在學數據結構的時候,經常遇到的一個概念就是抽象數據類型(Abstract Data Type),簡稱ADT。

維基百科中的定義是:抽象數據類型是計算機科學中具有類似行為的特定類別的數據結構的數學模型,或者具有類似語義的一種或多種程序設計語言的數據類型。

從這段定義來看,非常地費解,其實我們只需要抓住核心。核心就是接口和實現的分離。我們在使用一個ADT的時候,只需要和接口進行交互,而不必關心接口中的實現細節。同樣,數據也是隱藏不可見的,也需要通過接口進行交互。

也就是說接口是數據類型唯一的交互方式,除此之外,用戶無法接觸到ADT的數據以及實現細節。

舉個例子,以棧舉例,如果我們不將棧設計成ADT,那么用戶在使用棧的時候,可能就需要自己創建一個數組來存儲棧中的數據,通過調用一些方法來實現棧的功能。但這勢必需要用戶了解棧的原理,以及數據存儲的細節。ADT會做一個良好的封裝,用戶只需要了解每個接口的功能,調用對應的接口實現自己想要的邏輯即可。

我們來看一下C++ Primer當中實現的棧的例子。

首先,我們需要知道棧一共有哪些接口,大概有如下這么幾個:

  • 創建空棧
  • 可添加數據到棧頂
  • 可從棧頂彈出數據
  • 可查看棧是否為空
  • 可查看棧是否已滿

然后,我們遵守C++中面向對象的設計思路,將它封裝在一個類當中。首先我們來定義這個類:

  1. #ifndef STACK__H_ 
  2. #define STACK__H_ 
  3.  
  4. typedef unsigned long Item; 
  5.  
  6. class Stack { 
  7.  private: 
  8.         enum {MAX=10}; 
  9.         Item items[MAX]; 
  10.         int top
  11.     public
  12.      Stack(); 
  13.      bool isempty() const; 
  14.      bool isfull() const; 
  15.      bool push(const Item &item); 
  16.      bool pop(Item &item); 
  17. }; 
  18. #endif 

我們來看下這個定義,會發現,其中的數據都被設定成了private,也就是用戶無法直接訪問到數據。只能通過public的接口進行交互,也無須關心其中的實現細節,可以當做黑盒使用。

最后, 我們再來看下C++ Primer當中給出的實現:

  1. #include "stack.h" 
  2.  
  3. Stack::Stack() { 
  4.     top = 0; 
  5.  
  6. bool Stack::isempty() const { 
  7.     return top == 0; 
  8.  
  9. bool Stack::isfull() const { 
  10.     return top == MAX
  11.  
  12. bool Stack::push(const Item &item) { 
  13.     if (top < MAX) { 
  14.         items[top++] = item; 
  15.         return true
  16.     } 
  17.     return false
  18.  
  19. bool Stack::pop(Item &item) { 
  20.     if (top > 0) { 
  21.         item = items[--top]; 
  22.         return true
  23.     } 
  24.     return false

本文轉載自微信公眾號「Coder梁」,可以通過以下二維碼關注。轉載本文請聯系Coder梁公眾號。

 

責任編輯:武曉燕 來源: Coder梁
相關推薦

2021-12-12 18:13:54

C++This指針

2021-12-29 20:31:40

C++多態指針

2021-02-22 09:02:16

數據抽象類型

2021-11-26 00:03:20

C++編譯常量

2021-12-09 10:56:50

函數C++原型

2011-07-21 14:45:13

java

2021-12-08 10:43:09

C++實現

2021-12-10 10:45:36

C++函數Stock

2021-10-26 00:19:51

C++結構體存儲

2021-12-30 14:58:58

C++函數動態

2021-11-09 10:38:16

C++Const指針

2021-12-11 19:02:03

函數C++對象

2021-11-27 11:50:09

C++靜態持續

2021-11-10 10:48:36

C++函數指針

2021-10-26 15:36:17

C++枚舉值類型

2021-10-27 16:27:20

C++指針操控

2021-12-05 18:20:42

C++空間特性

2021-12-15 10:25:57

C++運算符重載

2022-01-04 16:35:42

C++Protected關鍵字

2021-10-21 18:52:00

C++數組存儲
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日本人做爰大片免费观看一老师 | 国产成人在线视频 | 国产精品一区二区三区四区五区 | 亚洲精品一区二区三区免 | 国产免费xxx | 九九热在线视频 | 一区二区精品视频 | 在线观看电影av | 午夜视频一区二区 | 免费成人在线网站 | 亚洲一在线 | 91精品国产高清一区二区三区 | 成人久久久 | 欧美日韩在线播放 | 7777精品伊人久久精品影视 | 午夜国产精品视频 | 国产在线中文字幕 | 亚洲精品久久久久久久久久久久久 | 国产韩国精品一区二区三区 | 在线免费观看日本视频 | 亚洲永久 | 亚洲精品久久久久久国产精华液 | 日韩精品一区二区三区在线播放 | 国产精品波多野结衣 | a级网站 | 久久精品网 | 999久久 | 午夜精品久久久 | 国产精品免费观看 | 日韩视频专区 | 一区二区三区四区不卡视频 | 福利视频一区 | 久久精品视频网站 | 一区二区高清 | 欧美精品欧美精品系列 | 国内精品久久久久久 | 天天拍天天插 | 亚洲经典一区 | 欧美激情一区二区三级高清视频 | 成人午夜激情 | 日韩伦理一区二区三区 |