国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

C++開發EOS基礎指南之類與結構

Atom / 847人閱讀

摘要:上一篇開發的文章是開發基礎指南函數參數傳遞,是一種面向對象的編程語言。析構函數是構造函數的附件,允許你在對象被銷毀或超出范圍時運行代碼。默認構造函數另一個帶兩個參數的構造函數成員函數聲明要遵循的實現不修改對象狀態的函數應該標記為。

上一篇C++開發EOS的文章是C++開發EOS基礎指南:函數參數傳遞,C++是一種面向對象的編程語言。它有一個強大的繼承系統,私有和公共成員變量,以及通過成員初始化列表在構造函數中初始化它們的好方法。析構函數是構造函數的附件,允許你在對象被銷毀或超出范圍時運行代碼。今天讓我們創建一個簡單的CryptoCurrency類,另外看看繼承。

// @url: https://repl.it/@MrToph/CPPBasics-Classes-1
#include 
#include 
#include 

//自動解析std命名空間,所以我們可以寫字符串而不是std::string
using namespace std;

//聲明一個類。
//類通常在頭文件(.h或.hpp)中聲明。
class Currency
{
    //默認情況下,成員變量和函數是私有的。
    string name;
    double priceInUSD;

    //此后的所有成員都是公共的
????//直到找到“private:”或“protected:”。
  public:
    //默認構造函數
    Currency();
    //另一個帶兩個參數的構造函數
    Currency(const string &_name, const double price);

    //成員函數聲明(要遵循的實現)
    void setName(const string &dogsName);

    void setPrice(double price);

    //不修改對象狀態的函數應該標記為const。
????//如果給定對象的const引用,則允許你調用它們。
    void print() const;

    //函數也可以在類體內定義。
????//這樣定義的函數會自動內聯。
    void bark() const { cout << name << " barks!
"; }

    // C++有析構函數。它們是建造者的標識當一個對象被刪除或超出范圍時調用它們。
    virtual ~Currency();

}; //分號必須遵循類聲明。

//類成員函數通常在.cpp文件中實現。
Currency::Currency()
{
    cout << "A currency has been created
";
}

Currency::Currency(const string &_name, double price)
{
    name = _name;
    priceInUSD = price;
    cout << name << " has been created with a price of " << price << "USD
";
}

void Currency::setName(const string ¤cyName)
{
    name = currencyName;
}

void Currency::setPrice(double price)
{
    priceInUSD = price;
}

//請注意,僅在聲明中需要“virtual”,而不是定義。
void Currency::print() const
{
    cout << name << " is at a price of " << priceInUSD << "USD
";
}

Currency::~Currency()
{
    cout << name << " has been hard forked!
";
}

//struct與類相同,但它們通常僅用于封裝數據很少包含方法,在這些情況下更喜歡類
struct block_header
{
    //默認情況下,結構字段是公共的
    uint64_t timestamp;
    uint64_t blockNumber;
    //指向block_header對象的指針
    block_header* prevBlock;
};

int main()
{
    //這會運行默認構造函數
    Currency bitcoin;
    bitcoin.setName("Bitcoin");
    bitcoin.setPrice(1E5);
    bitcoin.print();

    Currency eos("EOS", 100);
    eos.print();

    block_header genesis;
    genesis.timestamp = 1528445288;
    genesis.blockNumber = 0;

    //沒有用戶定義構造函數的結構
????//可以通過“aggregate initialization”初始化
    block_header second{1528445288, 1, &genesis};
    cout << "Timestamp of second block " << second.timestamp << "
";

    //或通過提供struct的字段名稱顯式它們需要與結構中定義的順序相同,但允許你跳過初始化值
    block_header third{.blockNumber = 2, .prevBlock = &second};
    // third.timestamp初始化為0
    cout << "Timestamp of block after block #" << third.prevBlock->blockNumber << ": " << third.timestamp << "
";
}
繼承

如果沒有強制性的Animal類示例,繼承的簡介會是什么?請注意,C++支持多重繼承,這是一種(有爭議的)功能,其中一個類可以同時從多個類繼承。在開發智能合約時,你可能永遠不需要它,所以讓我們看一下從單個類繼承的情況。

#include 

using namespace std;

class Animal
{
    string name;
    int weight;

  public:
    //默認構造函數將其值“delegates”給其他構造函數
    Animal() : Animal("Peter", 80){};

    //構造函數獲取名稱和權重并初始化
??? //具有使用相同名稱的“initializer list”的類成員
    Animal(const string &name, int weight) : name(name), weight(weight)
    {
        // we already write the function body here
        cout << name << " was created
";
    };

    void setName(const string &dogsName);
    string getName() const;

    void setWeight(int weight);

    //可以覆蓋的函數必須聲明為_virtual_
    virtual void print() const;

    //函數也可以在類聲明中定義
????//但要小心,因為它們會自動內聯。
    void eat() { weight += 5; }

    //如果要派生類,析構函數應該是虛擬的;
????//如果它不是虛擬的,那么如果通過基類引用或指針銷毀對象,則不會調用派生類的析構函數。
    virtual ~Animal();
};

void Animal::setName(const string &animalName)
{
    name = animalName;
}

string Animal::getName() const
{
    return name;
}

void Animal::setWeight(int animalWeight)
{
    weight = animalWeight;
}

//“virtual”僅在聲明中需要,而不是在定義中。
void Animal::print() const
{
    cout << name << " weighs " << weight << "kg
";
}

Animal::~Animal()
{
    cout << "Animal " << name << " died
";
}

// Dog現在是Animal的子類,并繼承了Animal的成員。
//但是如果沒有getter,可能無法直接訪問私有成員或方法。
class Dog : public Animal
{
    string breed;

  public:
    Dog(const string &name,int weight,const string &breed):Animal(name,weight),breed(breed)
    {
        cout << "Woof
";
    }

    //被重載的虛擬方法應標記為重載。
    void print() const override;
};

void Dog::print() const
{
    //調用Animal的打印功能
    Animal::print();
    //無法直接訪問.name,因為它是私有的
????//需要訪問public getter getName
    cout << Animal::getName() << " is a " << breed << " dog
";
}

int main()
{
    Dog dog("Carl", 10, "Dackel");
    dog.print();
}

分享一個交互式的在線編程實戰,EOS智能合約與DApp開發入門

EOS教程

本課程幫助你快速入門EOS區塊鏈去中心化應用的開發,內容涵蓋EOS工具鏈、賬戶與錢包、發行代幣、智能合約開發與部署、使用代碼與智能合約交互等核心知識點,最后綜合運用各知識點完成一個便簽DApp的開發。

這里是原文

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/24333.html

相關文章

  • C++開發EOS基礎指南之類結構

    摘要:上一篇開發的文章是開發基礎指南函數參數傳遞,是一種面向對象的編程語言。析構函數是構造函數的附件,允許你在對象被銷毀或超出范圍時運行代碼。默認構造函數另一個帶兩個參數的構造函數成員函數聲明要遵循的實現不修改對象狀態的函數應該標記為。 上一篇C++開發EOS的文章是C++開發EOS基礎指南:函數參數傳遞,C++是一種面向對象的編程語言。它有一個強大的繼承系統,私有和公共成員變量,以及通過成...

    awkj 評論0 收藏0
  • EOS入門指南PART6——別忙著開發,先來看看智能合約數據是怎么存的

    摘要:允許智能合約定義自己的私有數據庫表。有了多級索引,智能合約就具備了操作類似數據庫模塊的功能。因此雖然只有一列,但是的靈活性絲毫不亞于傳統的數據表。 上一章我們學習了開發智能合約之前需要知道的必要概念: 什么是webAssembly以及它在智能合約上下游中的位置; 什么是ABI以及怎樣使用eosiocpp工具產生ABI和wasm、wast hello智能合約的簡單入門:部署和調用 ...

    ranwu 評論0 收藏0
  • 【許曉笛】EOS 數據庫持久化 API —— 實戰

    摘要:查詢數據使用方法和其他迭代器操作查詢數據。數據庫服務的對象是維修技師和車主。如果查找成功,迭代器就會指向所需的數據對象。 EOS 數據庫開發實戰 上次的文章詳細講解了 EOS 數據庫的架構,本文將以官方示例為基礎,詳解 EOS 數據庫的開發實戰。 基本步驟 在智能合約里與 EOS 數據庫交互,首先要定義存儲的數據: 定義對象:具體就是定義一個 C++ 類或者 C++ 結構體,數據表...

    yck 評論0 收藏0
  • 區塊鏈開發中使用的最流行的編程語言

    摘要:我們目前正處于一個新興的區塊鏈開發行業中。,一種在以太坊開發人員中流行的新的簡單編程語言,因為它是用于開發以太坊智能合約的語言。它是全球至少萬開發人員使用的世界上最流行的編程語言之一。以太坊,主要是針對工程師使用進行區塊鏈以太坊開發的詳解。 我們目前正處于一個新興的區塊鏈開發行業中。區塊鏈技術處于初期階段,然而這種顛覆性技術已經成功地風靡全球,并且最近經歷了一場與眾不同的繁榮。由于許多...

    2shou 評論0 收藏0

發表評論

0條評論

Atom

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<