【概念】

做服务的时候main里面不能单独有东西,都得包起来。

Identifier expected是因为没有main函数

雾草,task3还要加proxy, add再干别的。难受!妈的,什么代理模式设计的要求都没注意到,太粗心了。

main函数client里面不能丢,保证基本功能,其他的额外方法丢进proxy。

constructor在main方法外面,main调用constructor来形成object https://blog.csdn.net/caohaicheng/article/details/14147099

public class Platypus {
String name; Platypus(String input) {
name = input;
} Platypus() {
this("John/Mary Doe");
} public static void main(String args[]) {
Platypus p1 = new Platypus("digger");
Platypus p2 = new Platypus();
System.out.println(p1.name + "----" + p2.name);
}
}
---------------------
作者:hai_cheng001
来源:CSDN
原文:https://blog.csdn.net/caohaicheng/article/details/14147099
版权声明:本文为博主原创文章,转载请附上博文链接!

构造函数里就是原来的变量,后面还要用。不是全是0,新建的时候全是0就行了。

多做了一次json,就会出现斜线。看来第打印数组用普通数组就行了。

字符串连接只能用加号,不能用append。

override是重写,名字一样,重新写一遍。

static的nonce是全局的,这个类中都一样,所以类产生的每个block中都是一样的了。所以此处不能用static全局变量。当初学的时候不理解全局变量的意思啊。static 方法可以直接调用方法名。static的方法里面不能够调用instance变量。谁用谁知道。

mostRecentBlock全局化以后,hash value就都一样了。所以要小心使用全局化了之后的东西,特别是计算不一样的值的时候。或者更新一下全局化变量。

target不是全局变量的话,重新求一遍就行了。

genesis hash的nonce也是需要根据难度来更新的,不能不遵守规定。

currentHash 定义和检验的时候时间戳其实是一样的:block创建的时候调用constructor, 两者同时计时。

一个改了好久的错:nonce应该是算好之后在给hash去用,因为hash里要用nonce。并列变量中如果有函数关系,就要先求出其中的自变量。

修复的时候也是先修复nonce,再修复hash。

nonce是根据数据来哈希,用工作量来匹配哈希的一个东西。所以数据变了,对应的工作量要改变。看Javadoc的时候只注意了函数实现,硬凑着能写就行。没真正理解概念的意思。还是要尽量第一遍理解得透彻一些。

卧槽,main函数里没有调用constructor,新建一个object。因为构造、赋值都在constructor里面。太智障了,哎。

当有service里包括blockchain时,在长的service函数里面初始化,constructor里面可以加第一个值。不要在短的blockchain函数里再初始化一次,容易混乱。

【方法论】

妈的,看来还是要先懂lab啊,不懂lab没法写啊。

出现exception的时候可以.tostring()打印出来,如org.json.JSONException: JSONObject["duration"] not found.

XML先执行,再执行URL注释的pattern,妈的,这谁知道啊。不过学到一个方法:把URL输入到浏览器里看。

如何找出别的TA不会改的bug:先看输入哪个操作没错,然后值得怀疑的地方一个个打。

       Blockchain.blockList = new ArrayList<Block>();
//System.out.println("链长1 = " + Blockchain.blockList.size());
//System.out.println("genesis nonce = " + genesis.nonce);
Blockchain.blockList.add(genesis);
//System.out.println("链长2 = " + Blockchain.blockList.size()); //get the genesis block's hash as the chain hash
String genesisHash = genesis.calculateHash();
Blockchain.hashOfNewBlock = genesisHash;
//这里改了,括号里的Blockchain.blockList忘了指定是哪个,乱了
mostRecentBlock = Blockchain.blockList.get(Blockchain.blockList.size() - 1);
//System.out.println("链长3 = " + Blockchain.blockList.size());

两行new了一个class,明明不空,却有NPE:把变量全都打印出来,好狠!

client走不到,client没有得到初始化的东西,真尴尬。要思考调用的流程。


网豆可以右键格式化,我擦。

妈的,这次没注意前后几个project的联系。后面要大改,艹。

一个task没有全部想清楚就动笔写是很不好的,可能导致后面全都要改。

设计的时候想法很自然,但是真的没有想到一些细节上的bug。

搜索stackoverflow,然后看英文

debug 的F8:step over直接跳过了,step in 才会执行具体的细节。

在循环的之前之中之后都可以打印,哪里不对打哪里。

genesis block可以先定义,再修改。这是一个重要的思维。如:结束的时间定义在外面,循环之后更新结果。

另一个class调用的时候不打印,说明函数里面有问题。这时候需要在函数里面打印,发现了nonce计算的没有加1.

有错的时候就要立刻Return false,不要犹豫,会忘了。

第一层输入的字符串必须要处理不是123456的情况,否则很容易测试的时候不小心全盘崩掉。在while(true)里面加一层大的try catch。

一个类的代码很长,就很烦,鼠标滚来滚去都很烦。不如多分几个,切身体会!

重启IDE后先把glassfish打开,再做后面的部署。

【细节】

从网上引用的时候,变量名没改,客户端和服务器都写的一样的,哭了。代码粘过来以后一定要全都改了。

URL加斜线才能访问

json里面要单独加。没有赋值错了啊,不能这样加!

println就是换行了,不需要再加/n

加两次system.in就能输入两个变量了,不用连接之后的。

成员变量如果非得写,可以设置初始值。不过一般不写

    //可以先设为全局的吧?如果要用,后面会改
static Integer blockID = 0;
static Integer difficulty = 0;
static String transaction = "";
static Integer operationID;

import一个包,最后要加*

nonce = nonce.add(new BigInteger("1")); 得写等号,这也是无奈了

tostring必须要指定是这个class来用,让数组来用的没有,只有Java自带的tostring。

注意下细节:修改完整个链以后,chain hash也要跟着改。indexStartToError不要忘记及时更新

每次创造一个block出来以后,必须要加到数组中,别忘了更新。

要比较的字符串变量不要加双引号,不然是比较字符串名字。好吧,智障了。

nonce是类里通用的,是成员变量。不能在方法中重新定义,值会错。

您应该包装输出,以便在屏幕截图中更好地显示它,并且它将更容易调试。你可以通过以下方式包装:右键单击NetBeans控制台并选择Wrap text。可以把输出结果包起来。

注意client里连接的端口号是不是和serverproject打开的URL一样的,否则连不上

默认方法hello要删掉,后面部署之后再删更麻烦。




























project3 blockchain的更多相关文章

  1. 区块链(Blockchain)

    一 .什么是区块链? 区块链(Blockchain)是由节点参与的分布式数据库系统[1],它的特点是不可更改,不可伪造,也可以将其理解为账簿系统(ledger).它是比特币的一个重要概念,完整比特币区 ...

  2. BitCoin - BlockChain

    BitCoin 比特币, 参考: BlockChain 区块链, 参考: 参考

  3. Ubuntu配置Open BlockChain

    /* 以前只是听说过BlockChain,没怎么了解过,最近导师在搞Blockchain,让我配一下Open BlockChain的环境,于是就硬着头皮配了一下,还挺顺利的. 由于没接触过BlockC ...

  4. Blockchain概述--转

    编者按:著名投资人 Fred Wilson 的同事 Joel Monegro 近日参加了纽约比特币 workshop HackBit聚会,其间他们讨论了比特币式的思维方式对未来十年世界的影响,而这种影 ...

  5. BlockChain:Py实现区块链简单场景应用:程序猿记录在区块里的收入记录图——Jason niu

    # -*- coding: utf-8 -*- ''' Created on 2018年3月11日 @author: Jason niu ''' import hashlib #该模块实现了诸多安全哈 ...

  6. Learn to securely share files on the blockchain with IPFS!

    https://medium.com/@mycoralhealth/learn-to-securely-share-files-on-the-blockchain-with-ipfs-219ee47d ...

  7. 「About Blockchain(一)」达沃斯年会上的区块链

    「About Blockchain(一)」 --达沃斯年会上的区块链 写在前面:1月23日到26日,在瑞士达沃斯召开了第48届世界经济论坛.这个新闻本没有引起我格外的关注,直到前两天张老师分享给我一篇 ...

  8. 一、Bitcoin比特币与BlockChain区块链技术

    一.比特币历史 2008 年 10 月 31 日,一个网名叫中本聪(英文翻译过来滴)的家伙发布比特币唯一的白皮书:<Bitcoin:A Peer-to-PeerElectronic Cash S ...

  9. Blockchain For Dummies(IBM Limited Edition

    Blockchain For Dummies(IBM Limited Edition)笔记 该系列内容主要介绍用于商业的区块链,有人说区块链之于贸易,犹如因特网之于信息.在商业领域区块链可以用于交易任 ...

随机推荐

  1. MySQL binlog2sql-闪回数据

    binlog2sql 从MySQL binlog解析出你要的SQL.根据不同选项,你可以得到原始SQL.回滚SQL.去除主键的INSERT SQL等. 用途 数据快速回滚(闪回) 主从切换后新mast ...

  2. 如何让SQLServer的 itemNum 字段 按照数字大小顺序排序

    我的 itemNum 从1到20,可是超过了SQLServer的默认排序这样的1101112...19234567如何才能让排序成为这样1234567891011.. . 解决办法:因为 itemNu ...

  3. Supervisor配置

    Supervisor(http://supervisord.org/)是用Python开发的一个client/server服务,是Linux/Unix系统下的一个进程管理工具,不支持Windows系统 ...

  4. 部署Redis4.x单机版及配置RDB和AOF持久化

    一.环境及软件 OS soft version  CentOS 7.5   redis-4.0.12(目前是4.x最新) 二.下载及编译Redis [root@localhost ~]# wget h ...

  5. Flink安装部署

    官网:https://ci.apache.org/projects/flink/flink-docs-release-1.7/ops/deployment/cluster_setup.html cd ...

  6. 使用gitblit搭建git服务器

    前言 一直在学习新技术,我想都整理到博客上.公司还在坚持用svn,之前学过git都快要忘记了,此篇博客记录搭建基于gitblit的git服务器.当然直接使用linux也可以,不过我不是很熟悉,考虑到我 ...

  7. 【Appium自学】Android studio安装与配置(转)

    转自链接:https://www.cnblogs.com/xiadewang/p/7820377.html 1.首先下载Android studio安装包. 可以从http://www.android ...

  8. Android 开发 倒计时功能 转载

    原文地址:https://www.cnblogs.com/xch-yang/p/7920419.html Android为我们封装好了一个抽象类CountDownTimer,可以实现计时器功能: /* ...

  9. eShopOnContainers 看微服务④:Catalog Service

    服务简介 Catalog service(目录服务)维护着所有产品信息,包括库存.价格.所以该微服务的核心业务为: 产品信息的维护 库存的更新 价格的维护 架构模式 先看代码结构(下图). 主要依赖: ...

  10. winreg操作windows注册表详解示例

    #coding:utf-8 #=====================================================================#=====本程序演示了WINR ...