代码拉取完成,页面将自动刷新
同步操作将从 duke.du/go_bitcoin_example 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
package main
import (
"os"
"fmt"
"strconv"
)
//这是一个用来接收命令行参数并且控制区块链操作的文件
type CLI struct {
bc *BlockChain
}
const Usage = `
printChain "正向打印区块链"
printChainR "反向打印区块链"
getBalance --address ADDRESS "获取指定地址的余额"
send FROM TO AMOUNT MINER DATA "由FROM转AMOUNT给TO,由MINER挖矿,同时写入DATA"
newWallet "创建一个新的钱包(私钥公钥对)"
listAddresses "列举所有的钱包地址"
`
//接受参数的动作,我们放到一个函数中
func (cli *CLI) Run() {
//./block printChain
//./block addBlock --data "HelloWorld"
//1. 得到所有的命令
args := os.Args
if len(args) < 2 {
fmt.Printf(Usage)
return
}
//2. 分析命令
cmd := args[1]
switch cmd {
case "printChain":
fmt.Printf("正向打印区块\n")
cli.PrinBlockChain()
case "printChainR":
fmt.Printf("反向打印区块\n")
cli.PrinBlockChainReverse()
case "getBalance":
fmt.Printf("获取余额\n")
if len(args) == 4 && args[2] == "--address" {
address := args[3]
cli.GetBalance(address)
}
case "send":
fmt.Printf("转账开始...\n")
if len(args) != 7 {
fmt.Printf("参数个数错误,请检查!\n")
fmt.Printf(Usage)
return
}
//./block send FROM TO AMOUNT MINER DATA "由FROM转AMOUNT给TO,由MINER挖矿,同时写入DATA"
from := args[2]
to := args[3]
amount, _ := strconv.ParseFloat(args[4], 64) //知识点,请注意
miner := args[5]
data := args[6]
cli.Send(from, to, amount, miner, data)
case "newWallet":
fmt.Printf("创建新的钱包...\n")
cli.NewWallet()
case "listAddresses":
fmt.Printf("列举所有地址...\n")
cli.ListAddresses()
default:
fmt.Printf("无效的命令,请检查!\n")
fmt.Printf(Usage)
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。