智能合约是在区块链上运行的计算机代码,其中包含一组规则,在该规则下该智能合约的各方同意彼此进行交互。如果满足预定义规则,协议将自动执行。 智能合约代码促进、验证并强制协商或履行协议或交易。这是分布式自动化的最简单形式。 它是一种涉及数字资产和两方或多方的机制,其中部分或所有参与者将资产存入智能合约,并根据某些数据自动在这些参与者之间重新分配资产,在合约开始时,这些数据是未知的。
S6matrix。这是Metaforce中的第二个模型,称为中的第二个模型,S6矩阵。S6矩阵怎么样,也就是下面的?它有六个要点。第一排的两点在哪里?也就是说,每次进来的资金上涨,你不拿,但是在二线。你的钱是第一,第二,第三个位置是100%,然后是100%或者100%。第二行的最后一个位置叫循环位。不管是在哪里S3矩阵还是S在6矩阵中,所有循环BT都有相同的含义。
循环位的作用是清空和重置你的矩阵,因为只有在仓位清空后,你才能享受到入境资金的利润。你能理解你的合作伙伴吗?S在6矩阵中,循环位是第二行的第二位或第四位,所以这取决于哪个位置先来,然后循环位会帮助你重新投资,然后位置会改变。简单地说,在S在6矩阵中,以下六点可能来自你的上级,你的上级或上级的下属,或你的左朋友,或你的右朋友,或你的下属朋友,360度。
S6矩阵的第一排有两个位置,也就是说会给你的上级。然后,倒数四个位置中有三个位置,你得到了100%。其中一个是帮助你重置矩阵的圆形位置。所以在这里,很多合作伙伴不知道的是,第一排的两个位置必须给你的上级。答案是,这是你上级的第二排。也许是给你的上级,直接拿了100%。也许他是一个圆,然后重置整个点。S矩阵可享受全球公共行。本文由系统开发对接V:MrsFu123编辑整理发布。
一、编写合约
合约示例,一个简单的做加法的合约
pragma solidity ^0.4.7;
contract addcontract {
function add(uint a,uint b) returns(uint d) {
return a + b;
}
}
二、编译合约
通过remix编译可以获得abi与data如下:
abi =[{“constant”:false,“inputs”:[{“name”:“a”,“type”:“uint256”},{“name”:“b”,“type”:“uint256”}],“name”:“add”,“outputs”:[{“name”:“d”,“type”:“uint256”}],“payable”:false,“stateMutability”:“nonpayable”,“type”:“function”}]
data=“0x6080604052348015600f57600080fd5b50609d8061001e6000396000f300608060405260043610603e5763ffffffff7c0100000000000000000000000000000000000000000000000000000000600035041663771602f781146043575b600080fd5b348015604e57600080fd5b50605b600435602435606d565b60408051918252519081900360200190f35b01905600a165627a7a72305820f6266436f5e17e3985b58d99a115b831979da26bec9abec3f8db4082fe369fa10029”
三、部署合约
addContract = hpb.contract(abi)
addcontract = addContract.new({from:hpb.coinbase,data:data,gas:4700000}) ,返回交易hash:“0x7a9e50ee550d909f9d8fbdc849dc2bddcdd2485ffafb5eeb52c1ebbff68d1802”
至此,可以在txpool中看到有一条交易,挖矿打包后,合约部署成功
可通过addcontract.address查看合约地址,
也可通过交易hash查看:hpb.getTransactionReceipt(“0x7a9e50ee550d909f9d8fbdc849dc2bddcdd2485ffafb5eeb52c1ebbff68d1802”)
4、调用合约
合约部署完毕,调用合约
myContract = addContract.at(addcontract.address) // 或者这里直接使用地址
myContract.add.sendTransaction(1,2,{from:hpb.coinbase}) //返回交易hash :“0x4298e32d61c4a2447d862295cefdef0bc89490df65dff06f20a57c1962d7d84e”
此时可以看到txpool中有一条交易。
另外也可以通过myContract.add.call(1,2)来直接调用合约,但不产生交易,而是直接返回结果3。
五、代码分析
那么问题就来了,通过sendTransaction接口发送的交易并没有返回结果,那能找到该交易产生的结果吗?
下面从代码角度看一下通过sendTransaction接口执行的1+2后的结果在哪里。
直接看合约call的部分代码evm.go中的call
1、先判余额是否是否满足本次转账要求,满足的话先进行转账,根据input然后执行合约run
2、在run中,重点在for循环中,先通过op = contract.GetOp(pc) 获取操作码,操作码及其对应函数的定义在jump_table.go中
3、然后通过operation := in.cfg.JumpTable[op]获取对应的操作函数,并进行stack的校验
4、然后res, err := operation.execute(&pc, in.evm, contract, mem, stack) 获取操作的返回结果,res存储了返回结果
5、如果当前操作的operation.returns是true则将res存储到in.returnData中。
6、没有错误的情况继续下一个操作,转到第2步
通过上面的代码运行可以,返回的结果在res中,而这个结果在交易中是不进行保存的。所以通过sendTransaction发起的交易是无法查询结果的。
因此在实际应用中,通常是使用sendTransaction去设置变量的值并打包进区块中,然后通过call来调用进行相应变量的数据处理并返回结果。
六、合约示例
根据上述总结,比如合约是这样的
pragma solidity ^0.4.25;
contract mytest{
uint public a;
function seta(uint ina) public{
a = ina;
}
function geta()public returns (uint b){
return a;
}
}