欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++抽象數(shù)據(jù)類型介紹

 更新時間:2022年01月03日 11:23:49   作者:梁唐  
這篇文章主要介紹了C++抽象數(shù)據(jù)類型,我們在學(xué)數(shù)據(jù)結(jié)構(gòu)的時候,經(jīng)常遇到的一個概念就是抽象數(shù)據(jù)類型(Abstract Data Type),簡稱ADT。下面我們就對ADT作更多介紹,需要的朋友可以參考一下

公眾號:Coder梁(ID:Coder_LT)

我們在學(xué)數(shù)據(jù)結(jié)構(gòu)的時候,經(jīng)常遇到的一個概念就是抽象數(shù)據(jù)類型(Abstract Data Type),簡稱ADT。

維基百科中的定義是:抽象數(shù)據(jù)類型是計算機(jī)科學(xué)中具有類似行為的特定類別的數(shù)據(jù)結(jié)構(gòu)的數(shù)學(xué)模型,或者具有類似語義的一種或多種程序設(shè)計語言的數(shù)據(jù)類型。

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

也就是說接口是數(shù)據(jù)類型唯一的交互方式,除此之外,用戶無法接觸到ADT的數(shù)據(jù)以及實現(xiàn)細(xì)節(jié)。

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

我們來看一下C++ Primer當(dāng)中實現(xiàn)的棧的例子。

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

  • 創(chuàng)建空棧
  • 可添加數(shù)據(jù)到棧頂
  • 可從棧頂彈出數(shù)據(jù)
  • 可查看棧是否為空
  • 可查看棧是否已滿

然后,我們遵守C++中面向?qū)ο蟮脑O(shè)計思路,將它封裝在一個類當(dāng)中。

首先我們來定義這個類:

#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

我們來看下這個定義,會發(fā)現(xiàn),其中的數(shù)據(jù)都被設(shè)定成了private,也就是用戶無法直接訪問到數(shù)據(jù)。只能通過public的接口進(jìn)行交互,也無須關(guān)心其中的實現(xiàn)細(xì)節(jié),可以當(dāng)做黑盒使用。

最后, 我們再來看下C++ Primer當(dāng)中給出的實現(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ù)類型介紹的文章就介紹到這了,更多相關(guān)C++抽象數(shù)據(jù)類型內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++類的特種函數(shù)生成機(jī)制詳解

    C++類的特種函數(shù)生成機(jī)制詳解

    這篇文章主要給大家介紹了關(guān)于C++類特種函數(shù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-09-09
  • 使用pthread庫實現(xiàn)openssl多線程ssl服務(wù)端和客戶端

    使用pthread庫實現(xiàn)openssl多線程ssl服務(wù)端和客戶端

    使用pthread庫實現(xiàn)openssl多線程ssl服務(wù)端和客戶端,大家參考使用吧
    2014-01-01
  • C語言中實現(xiàn)協(xié)程案例

    C語言中實現(xiàn)協(xié)程案例

    這篇文章主要介紹了C語言中實現(xiàn)協(xié)程案例,本文通過將協(xié)程與線程和異步回調(diào)進(jìn)行對比,以及具體實現(xiàn)案例,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C++類的返回值是*this的成員函數(shù)問題

    C++類的返回值是*this的成員函數(shù)問題

    這篇文章主要介紹了C++類的返回值是*this的成員函數(shù)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • VC實現(xiàn)獲取本機(jī)MAC地址的方法

    VC實現(xiàn)獲取本機(jī)MAC地址的方法

    這篇文章主要介紹了VC實現(xiàn)獲取本機(jī)MAC地址的方法,需要的朋友可以參考下
    2014-07-07
  • C++中純虛函數(shù)的實例詳解

    C++中純虛函數(shù)的實例詳解

    純虛函數(shù)就是一個在基類中的虛函數(shù),差別只是在一般的虛函數(shù)聲明的后面加了“=0”,下面這篇文章主要給大家介紹了關(guān)于C++中純虛函數(shù)的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06
  • opencv3/C++ 離散余弦變換DCT方式

    opencv3/C++ 離散余弦變換DCT方式

    今天小編就為大家分享一篇opencv3/C++ 離散余弦變換DCT方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • 指針與const限定符的使用分析

    指針與const限定符的使用分析

    本篇文章對指針與const限定符的使用進(jìn)行了分析介紹。需要的朋友參考下
    2013-05-05
  • C語言實現(xiàn)獲取文件大小與創(chuàng)建修改時間

    C語言實現(xiàn)獲取文件大小與創(chuàng)建修改時間

    這篇文章主要為大家詳細(xì)介紹了如何通過C語言實現(xiàn)獲取文件大小、創(chuàng)建時間與修改時間,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-11-11
  • C語言之實現(xiàn)控制臺光標(biāo)隨意移動的實例代碼

    C語言之實現(xiàn)控制臺光標(biāo)隨意移動的實例代碼

    下面小編就為大家?guī)硪黄狢語言之實現(xiàn)控制臺光標(biāo)隨意移動的實例代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-07-07

最新評論