C++抽象數(shù)據(jù)類(lèi)型介紹
公眾號(hào):Coder梁(ID:Coder_LT)
我們?cè)趯W(xué)數(shù)據(jù)結(jié)構(gòu)的時(shí)候,經(jīng)常遇到的一個(gè)概念就是抽象數(shù)據(jù)類(lèi)型(Abstract Data Type),簡(jiǎn)稱(chēng)ADT。
維基百科中的定義是:抽象數(shù)據(jù)類(lèi)型是計(jì)算機(jī)科學(xué)中具有類(lèi)似行為的特定類(lèi)別的數(shù)據(jù)結(jié)構(gòu)的數(shù)學(xué)模型,或者具有類(lèi)似語(yǔ)義的一種或多種程序設(shè)計(jì)語(yǔ)言的數(shù)據(jù)類(lèi)型。
從這段定義來(lái)看,非常地費(fèi)解,其實(shí)我們只需要抓住核心。核心就是接口和實(shí)現(xiàn)的分離。我們?cè)谑褂靡粋€(gè)ADT的時(shí)候,只需要和接口進(jìn)行交互,而不必關(guān)心接口中的實(shí)現(xiàn)細(xì)節(jié)。同樣,數(shù)據(jù)也是隱藏不可見(jiàn)的,也需要通過(guò)接口進(jìn)行交互。
也就是說(shuō)接口是數(shù)據(jù)類(lèi)型唯一的交互方式,除此之外,用戶(hù)無(wú)法接觸到ADT的數(shù)據(jù)以及實(shí)現(xiàn)細(xì)節(jié)。
舉個(gè)例子:以棧舉例,如果我們不將棧設(shè)計(jì)成ADT,那么用戶(hù)在使用棧的時(shí)候,可能就需要自己創(chuàng)建一個(gè)數(shù)組來(lái)存儲(chǔ)棧中的數(shù)據(jù),通過(guò)調(diào)用一些方法來(lái)實(shí)現(xiàn)棧的功能。但這勢(shì)必需要用戶(hù)了解棧的原理,以及數(shù)據(jù)存儲(chǔ)的細(xì)節(jié)。ADT會(huì)做一個(gè)良好的封裝,用戶(hù)只需要了解每個(gè)接口的功能,調(diào)用對(duì)應(yīng)的接口實(shí)現(xiàn)自己想要的邏輯即可。
我們來(lái)看一下C++ Primer當(dāng)中實(shí)現(xiàn)的棧的例子。
首先,我們需要知道棧一共有哪些接口,大概有如下這么幾個(gè):
- 創(chuàng)建空棧
- 可添加數(shù)據(jù)到棧頂
- 可從棧頂彈出數(shù)據(jù)
- 可查看棧是否為空
- 可查看棧是否已滿(mǎn)
然后,我們遵守C++中面向?qū)ο蟮脑O(shè)計(jì)思路,將它封裝在一個(gè)類(lèi)當(dāng)中。
首先我們來(lái)定義這個(gè)類(lèi):
#ifndef STACK__H_
#define STACK__H_
typedef unsigned long Item;
class Stack {
?private:
? ? ? ? enum {MAX=10};
? ? ? ? Item items[MAX];
? ? ? ? int top;
? ? public:
? ? ?Stack();
? ? ?bool isempty() const;
? ? ?bool isfull() const;
? ? ?bool push(const Item &item);
? ? ?bool pop(Item &item);
};
#endif我們來(lái)看下這個(gè)定義,會(huì)發(fā)現(xiàn),其中的數(shù)據(jù)都被設(shè)定成了private,也就是用戶(hù)無(wú)法直接訪問(wèn)到數(shù)據(jù)。只能通過(guò)public的接口進(jìn)行交互,也無(wú)須關(guān)心其中的實(shí)現(xiàn)細(xì)節(jié),可以當(dāng)做黑盒使用。
最后, 我們?cè)賮?lái)看下C++ Primer當(dāng)中給出的實(shí)現(xiàn):
#include "stack.h"
Stack::Stack() {
? ? top = 0;
}
bool Stack::isempty() const {
? ? return top == 0;
}
bool Stack::isfull() const {
? ? return top == MAX;
}
bool Stack::push(const Item &item) {
? ? if (top < MAX) {
? ? ? ? items[top++] = item;
? ? ? ? return true;
? ? }
? ? return false;
}
bool Stack::pop(Item &item) {
? ? if (top > 0) {
? ? ? ? item = items[--top];
? ? ? ? return true;
? ? }
? ? return false;
}到此這篇關(guān)于C++抽象數(shù)據(jù)類(lèi)型介紹的文章就介紹到這了,更多相關(guān)C++抽象數(shù)據(jù)類(lèi)型內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
c++隱式類(lèi)型轉(zhuǎn)換存在的問(wèn)題解析
隱式轉(zhuǎn)換,是指不需要用戶(hù)干預(yù),編譯器私下進(jìn)行的類(lèi)型轉(zhuǎn)換行為,很多時(shí)候用戶(hù)都不知道具體進(jìn)行了哪些轉(zhuǎn)換,這篇文章主要介紹了c++隱式類(lèi)型轉(zhuǎn)換存在的陷阱,需要的朋友可以參考下2022-03-03
C/C++ Crypto密碼庫(kù)調(diào)用的實(shí)現(xiàn)方法
Crypto 庫(kù)是C/C++的加密算法庫(kù),這個(gè)加密庫(kù)很流行,基本上涵蓋了市面上的各類(lèi)加密解密算法,感興趣的可以參考一下2021-06-06
Android App仿微信界面切換時(shí)Tab圖標(biāo)變色效果的制作方法
這篇文章主要介紹了Android App仿微信界面切換時(shí)Tab圖標(biāo)變色效果的制作方法,重點(diǎn)講解了圖標(biāo)的繪制技巧,需要的朋友可以參考下2016-04-04
高效實(shí)現(xiàn)整型數(shù)字轉(zhuǎn)字符串int2str的方法
下面小編就為大家?guī)?lái)一篇高效實(shí)現(xiàn)整型數(shù)字轉(zhuǎn)字符串int2str的方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-03-03
C++異步數(shù)據(jù)交換實(shí)現(xiàn)方法介紹
這篇文章主要介紹了C++異步數(shù)據(jù)交換實(shí)現(xiàn)方法,異步數(shù)據(jù)交換,除了阻塞函數(shù) send() 和 recv() 之外,Boost.MPI 還支持與成員函數(shù) isend() 和 irecv() 的異步數(shù)據(jù)交換2022-11-11
C++用mysql自帶的頭文件連接數(shù)據(jù)庫(kù)
現(xiàn)在正做一個(gè)接口,通過(guò)不同的連接字符串操作不同的數(shù)據(jù)庫(kù)。要用到mysql數(shù)據(jù)庫(kù)。通過(guò)網(wǎng)上的一些資料和自己的摸索,大致清楚了C++連接mysql的方法。可以通過(guò)2種方法實(shí)現(xiàn)。第一種方法是利用ADO連接,第二種方法是利用mysql自己的api函數(shù)進(jìn)行連接。今天主要來(lái)講解下使用API2016-07-07
C語(yǔ)言函數(shù)棧幀的創(chuàng)建和銷(xiāo)毀介紹
大家好,本篇文章主要講的是C語(yǔ)言函數(shù)棧幀的創(chuàng)建和銷(xiāo)毀介紹,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下2021-12-12

