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

資訊專欄INFORMATION COLUMN

【許曉笛】49行代碼就能發幣?而且EOS連例子都給你了

Freeman / 1485人閱讀

摘要:相關文章和視頻推薦許曉笛智能合約案例解析圓方圓學院匯集大批區塊鏈名師,打造精品的區塊鏈技術課程。

Daniel Larimer 在他的博客介紹了EOS新的智能合約架構(EOS團隊的開發速度實在是太嚇人,根本追不上)。他給出了最簡單的一個新幣種的智能合約代碼,僅有49行就能完成一個新幣種的開發,一個新的“愛息歐”就誕生了。讓我們一步一步實現吧。

首先實現私有成員,建立一個 account 結構體,這個結構體里保存的是所有持有我們這種代幣的人的賬戶和余額。

   private:
      //account 結構體 
      struct account {
         //EOS 賬戶名
         account_name owner;
         //余額
         uint64_t     balance;
         //主鍵
         uint64_t primary_key()const { return owner; }

下一步 我們要利用 Boost 庫中的多索引列表,將上面聲明的結構體放入一個列表中,方便查詢和修改。

      eosio::multi_index _accounts;

接著,實現 add_balance() 函數,這個私有函數的目的是給特定的 EOS 賬戶增加特定的代幣。

      void add_balance( account_name payer, account_name to, uint64_t q ) {
         //在列表中查詢,看要收幣的用戶是否已經在列表中。
         auto toitr = _accounts.find( to );
         //如果不在列表中,說明用戶從未持有過這種幣,要將用戶加入列表
         if( toitr == _accounts.end() ) {
            //增加一個用戶
           _accounts.emplace( payer, [&]( auto& a ) {
              a.owner = to;
              //因為之前沒有這種幣,用戶名下的余額為要接收的數量
              a.balance = q;
           });
           //如果用戶在列表中,說明已經持有或持有過這種幣
         } else {
           _accounts.modify( toitr, 0, [&]( auto& a ) {
               //直接將余額增加要轉入的數量
              a.balance += q;
              //判斷用戶余額是否溢出(余額增加了q,之后數量應該大于q)
              eosio_assert( a.balance >= q, "overflow detected" );
           });
         }
      }

之后就要實現公有方法了,首先是構造函數,別忘了初始化 _accounts 列表。

  public:
      simpletoken( account_name self )
      :contract(self),_accounts( _self, _self){}

實現公有的 transfer(轉賬)函數,將代幣從一個賬戶轉移到另一個賬戶。

      void transfer( account_name from, account_name to, uint64_t quantity ) {
         //從付款方獲取權限
         require_auth( from );
         //從列表中搜索發幣方賬戶
         const auto& fromacnt = _accounts.get( from );
         //驗證付款方余額,是否透支
         eosio_assert( fromacnt.balance >= quantity, "overdrawn balance" );
         //從付款方減去代幣
         _accounts.modify( fromacnt, from, [&]( auto& a ){ a.balance -= quantity; } );
         //收款方增加代幣(之前實現的私有函數)
         add_balance( from, to, quantity );
      }

OK,是不是以為大功告成了?還有最重要的 issue(發行)函數,要不從哪“印錢?”

      void issue( account_name to, uint64_t quantity ) {
         //得到合約主人的權限
         require_auth( _self );
         //直接印錢
         add_balance( _self, to, quantity );

最后一步,將我們的 transfer 和 issue 函數接口提供給 EOS 系統,通過一個宏就可以快速實現。

EOSIO_ABI( simpletoken, (transfer)(issue) )

這個宏是咋回事?我們看看 dispacher.hpp 文件中對這個宏的定義,其實是替開發者實現了 apply 函數,使得開發者可以專注于業務邏輯。

#define EOSIO_ABI( TYPE, MEMBERS ) 
extern "C" { 
   void apply( uint64_t receiver, uint64_t code, uint64_t action ) { 
      auto self = receiver; 
      if( code == self ) { 
         TYPE thiscontract( self ); 
         switch( action ) { 
            EOSIO_API( TYPE, MEMBERS ) 
         } 
         eosio_exit(0); 
      } 
   } 
} 

大功告成,看看全部的代碼吧,是不是49行就搞定了?不過 EOS 表示以后會有系統的標準代幣,連以上的具體邏輯都不用我們實現了,不過這段代碼對系統學習 EOS 智能合約架構還是很有意義的。

#include 

class simpletoken : public eosio::contract {
   public:
      simpletoken( account_name self )
      :contract(self),_accounts( _self, _self){}

      void transfer( account_name from, account_name to, uint64_t quantity ) {
         require_auth( from );

         const auto& fromacnt = _accounts.get( from );
         eosio_assert( fromacnt.balance >= quantity, "overdrawn balance" );
         _accounts.modify( fromacnt, from, [&]( auto& a ){ a.balance -= quantity; } );

         add_balance( from, to, quantity );
      }

      void issue( account_name to, uint64_t quantity ) {
         require_auth( _self );
         add_balance( _self, to, quantity );
      }

   private:
      struct account {
         account_name owner;
         uint64_t     balance;

         uint64_t primary_key()const { return owner; }
      };

      eosio::multi_index _accounts;

      void add_balance( account_name payer, account_name to, uint64_t q ) {
         auto toitr = _accounts.find( to );
         if( toitr == _accounts.end() ) {
           _accounts.emplace( payer, [&]( auto& a ) {
              a.owner = to;
              a.balance = q;
           });
         } else {
           _accounts.modify( toitr, 0, [&]( auto& a ) {
              a.balance += q;
              eosio_assert( a.balance >= q, "overflow detected" );
           });
         }
      }
};

EOSIO_ABI( simpletoken, (transfer)(issue) )

相關文章和視頻推薦

【許曉笛】 EOS智能合約案例解析(1)

圓方圓學院匯集大批區塊鏈名師,打造精品的區塊鏈技術課程。 在各大平臺都長期有優質免費公開課,歡迎報名收看。
公開課地址:https://ke.qq.com/course/345101

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

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

相關文章

  • 曉笛EOS 區塊數據結構

    摘要:區塊長啥樣對于一個區塊鏈項目來說,最核心的數據莫過于區塊數據,區塊數據結構是整個區塊鏈項目的技術基礎。區塊頭首先是區塊頭數據結構,包括了哈希時間戳默克爾根見證人賬戶等。完整交易信息總結我們用圖形繪出了區塊數據結構,便于大家理解。 EOS 區塊長啥樣? 對于一個區塊鏈項目來說,最核心的數據莫過于區塊數據,區塊數據結構是整個區塊鏈項目的技術基礎。不過由于 EOS 項目一直在快速迭代,區塊數...

    imingyu 評論0 收藏0
  • 曉笛EOS:IPFS落地的重要途徑

    摘要:寫在前面,這一篇文章是許曉笛在北京開發者圓桌會議上的發言實錄,感謝主辦方戴嘉樂和董天一的邀請,感謝編輯們。我這次分享題目是有可能有點標題黨,前面拉了三個字有可能是落地的一個非常重要的途徑。共識機制共識機制,就是所有代幣持有人選舉。 寫在前面,這一篇文章是許曉笛 2018.05.20 在北京 《IPFS開發者圓桌會議》上的發言實錄,感謝主辦方戴嘉樂和董天一的邀請,感謝編輯們。先介紹一下《...

    tuomao 評論0 收藏0
  • 曉笛EOS 上線前,先搞懂這兩個基本概念

    摘要:的跟其他區塊鏈項目是類似的,都是一個基本功能本地儲存密鑰,僅此而已。公網上線后,一定要將存有密鑰的加密,并且將文件單獨備份好。字面意思是賬戶,但我覺得有個概念更適合法人。代幣就是由持有的。對于權限,則需要列表里至少兩個賬戶的授權才能行使。 如果你曾經嘗試在本地運行 EOS 測試節點,會發現編譯、運行并不是特別復雜,但官方教程里兩個概念很容易把人搞暈: Account(賬戶) 和 Wal...

    alogy 評論0 收藏0
  • 曉笛EOS智能合約案例解析(1)

    摘要:構造函數為空,參數為智能合約賬戶名。每個智能合約類都要繼承類類構造函數創建代幣函數聲明函數,這個函數用來新建一種代幣,并輸入代幣的各種屬性,同時函數也是一個。 詳解 EOS 智能合約的 hpp 文件 為了幫助大家熟悉 EOS 智能合約,EOS 官方提供了一個代幣(資產)智能合約 Demo —— eosio.token。eosio.token 智能合約目前還不是特別完善,個別功能還沒有完...

    forsigner 評論0 收藏0
  • 曉笛EOS 智能合約案例解析(2)

    摘要:相關文章和視頻推薦許曉笛智能合約案例解析許曉笛智能合約案例解析圓方圓學院匯集大批區塊鏈名師,打造精品的區塊鏈技術課程。 詳解 EOS 智能合約的 cpp 文件 之前的文章介紹了 eosio.token 智能合約的 hpp 文件,這次向大家介紹 eosio.token.cpp 文件,cpp 文件即 C++ 代碼文件,智能合約所有的業務邏輯內容都是在 cpp 文件中實現的。 eosio.t...

    mengbo 評論0 收藏0

發表評論

0條評論

Freeman

|高級講師

TA的文章

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