打造公鏈(1)

區(qū)塊

一個(gè)包含最關(guān)鍵信息的簡化版本的區(qū)塊,其數(shù)據(jù)結(jié)構(gòu)在go語言定義如下:

type Block struct {
    Timestamp   int64
    Data    []byte
    PrevBlockHash   []byte
    Hash    []byte
}

我們先不管復(fù)雜的區(qū)塊頭是如何定義的,Hash字段是如何計(jì)算的呢?

Hash = SHA256(PrevBlockHash + Timestamp + Data)

區(qū)塊鏈

區(qū)塊鏈就是將區(qū)塊有序鏈起來,然后通過區(qū)塊的hash能快速檢索到一個(gè)塊辐怕。

為了實(shí)現(xiàn)鏈起區(qū)塊和檢索區(qū)塊的功能,在go語言里从绘,用一個(gè)array和map的數(shù)據(jù)結(jié)構(gòu)就能解決問題寄疏。

type Blockchain struct {
    blocks []*Block
}

簡單的版本一初現(xiàn)雛形

區(qū)塊鏈原型:一個(gè)數(shù)組存了一些有序的區(qū)塊,每一個(gè)區(qū)塊都跟前一個(gè)區(qū)塊相關(guān)聯(lián)僵井,這里加入新的區(qū)塊是很容易的赁还,但真實(shí)的區(qū)塊鏈要復(fù)雜多,
需要工作量證明(PoW)驹沿,當(dāng)然本質(zhì)上是一個(gè)共識(shí)機(jī)制,就是一個(gè)節(jié)點(diǎn)添加區(qū)塊蹈胡,需要獲得其他節(jié)點(diǎn)的認(rèn)同渊季,從而形成的一個(gè)共識(shí)(consensus)朋蔫。

main.go

package main
    
    import (
        "time"
        "strconv"
        "bytes"
        "crypto/sha256"
        "fmt"
    )
    
    type Block struct {
        Timestamp   int64
        PrevBlockHash   []byte
        Hash    []byte
        Data    []byte
    }
    
    type BlockChain struct {
        blocks []*Block
    }
    
    func NewBlock(data string,prevBlockHash []byte) *Block{
        block := &Block{
            Timestamp:time.Now().Unix(),
            PrevBlockHash:prevBlockHash,
            Hash:[]byte{},
            Data:[]byte(data)}
        block.SetHash()
        return block
    }
    
    // Hash = sha256(PrevBlockHash + Data + Timestamp)
    func (b *Block) SetHash(){
        timestamp := []byte(strconv.FormatInt(b.Timestamp,10))
        headers := bytes.Join([][]byte{b.PrevBlockHash, b.Data, timestamp}, []byte{})
        hash := sha256.Sum256(headers)
        b.Hash = hash[:]
    }
    
    func NewGenesisBlock() *Block{
        return NewBlock("Genesis Block",[]byte{})
    }
    
    // 創(chuàng)建一個(gè)有創(chuàng)世塊的鏈
    func NewBlockChain() *BlockChain{
        return &BlockChain{[]*Block{NewGenesisBlock()}}
    }
    
    func (blockchain *BlockChain) AddBlock(data string){
        prevBlock := blockchain.blocks[len(blockchain.blocks)-1]
        newBlock := NewBlock(data,prevBlock.Hash)
        blockchain.blocks = append(blockchain.blocks,newBlock)
    }
    
    func main() {
        blockchain := NewBlockChain()
        blockchain.AddBlock("Send 1 BTC to Silver")
        blockchain.AddBlock("send 2 BTC to Silver again")
        for _,block := range blockchain.blocks{
            fmt.Printf("Prev hash: %x\n",block.PrevBlockHash)
            fmt.Printf("Data: %s\n", block.Data)
            fmt.Printf("Hash: %x\n", block.Hash)
            fmt.Println()
        }
    }

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市却汉,隨后出現(xiàn)的幾起案子驯妄,更是在濱河造成了極大的恐慌,老刑警劉巖合砂,帶你破解...
    沈念sama閱讀 221,273評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件青扔,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡翩伪,警方通過查閱死者的電腦和手機(jī)微猖,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,349評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來缘屹,“玉大人凛剥,你說我怎么就攤上這事∏嶙耍” “怎么了犁珠?”我有些...
    開封第一講書人閱讀 167,709評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長互亮。 經(jīng)常有香客問我犁享,道長,這世上最難降的妖魔是什么豹休? 我笑而不...
    開封第一講書人閱讀 59,520評(píng)論 1 296
  • 正文 為了忘掉前任炊昆,我火速辦了婚禮,結(jié)果婚禮上慕爬,老公的妹妹穿的比我還像新娘窑眯。我一直安慰自己,他們只是感情好医窿,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,515評(píng)論 6 397
  • 文/花漫 我一把揭開白布磅甩。 她就那樣靜靜地躺著,像睡著了一般姥卢。 火紅的嫁衣襯著肌膚如雪卷要。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,158評(píng)論 1 308
  • 那天独榴,我揣著相機(jī)與錄音僧叉,去河邊找鬼。 笑死棺榔,一個(gè)胖子當(dāng)著我的面吹牛瓶堕,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播症歇,決...
    沈念sama閱讀 40,755評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼郎笆,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼谭梗!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起宛蚓,我...
    開封第一講書人閱讀 39,660評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤激捏,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后凄吏,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體远舅,經(jīng)...
    沈念sama閱讀 46,203評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,287評(píng)論 3 340
  • 正文 我和宋清朗相戀三年痕钢,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了图柏。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,427評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡盖喷,死狀恐怖爆办,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情课梳,我是刑警寧澤距辆,帶...
    沈念sama閱讀 36,122評(píng)論 5 349
  • 正文 年R本政府宣布,位于F島的核電站暮刃,受9級(jí)特大地震影響跨算,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜椭懊,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,801評(píng)論 3 333
  • 文/蒙蒙 一诸蚕、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧氧猬,春花似錦背犯、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,272評(píng)論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽妄均。三九已至,卻和暖如春丰包,著一層夾襖步出監(jiān)牢的瞬間禁熏,已是汗流浹背邑彪。 一陣腳步聲響...
    開封第一講書人閱讀 33,393評(píng)論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人宙彪。 一個(gè)月前我還...
    沈念sama閱讀 48,808評(píng)論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像您访,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子剪决,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,440評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容