Meta Force 原力元宇宙互助dapp系统开发源代码
Force 与之前的项目 Forsage 的主要区别在于,佛萨奇项目系统I34-开发I633-搭建53I9,新平台上的交互是预先铺设的,因此,Meta Force 中出现的所有新内容都将是单个系统的组成部分。虽然在以前的项目中,它和其他人一样,但当个智能合约没有考虑到新程序时,与 Meta Force 中的程序不同,这个基础是提前准备的。
S6matrix。这是Metaforce中的第二个模型,称为中的第二个模型,S6矩阵。S6矩阵怎么样,也就是下面的?它有六个要点。排的两点在哪里?也就是说,每次进来的资金上涨,你不拿,但是在二线。你的钱是,第二,第三个位置是100%,然后是100%或者100%。第二行的后一个位置叫循环位。不管是在哪里S3矩阵还是S在6矩阵中,所有循环BT都有相同的含义。
循环位的作用是清空和重置你的矩阵,因为只有在仓位清空后,你才能享受到入境资金的利润。你能理解你的合作伙伴吗?S在6矩阵中,佛萨奇项目系统I34-开发I633-搭建53I9,循环位是第二行的第二位或第四位,所以这取决于哪个位置先来,然后循环位会帮助你重新投资,然后位置会改变。简单地说,在S在6矩阵中,以下六点可能来自你的上级,你的上级或上级的下属,或你的左朋友,或你的右朋友,或你的下属朋友,360度。
S6矩阵的排有两个位置,也就是说会给你的上级。然后,倒数四个位置中有三个位置,你得到了100%。其中一个是帮助你重置矩阵的圆形位置。所以在这里,很多合作伙伴不知道的是,排的两个位置必须给你的上级。答案是,这是你上级的第二排。也许是给你的上级,直接拿了100%。也许他是一个圆,然后重置整个点。S矩阵可享受全球公共行。
一、编写合约合约示例,一个简单的做加法的合约
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 = hp***ntract(abi)addcontract = addContract.new({from:hp***inbase,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:hp***inbase}) //返回交易hash :“0x4298e32d61c4a2447d862295cefdef0bc89490df65dff06f20a57c1962d7d84e”此时可以看到txpool中有一条交易。另外也可以通过myContract.add.call(1,2)来直接调用合约,但不产生交易,而是直接返回结果3。
五、代码分析那么问题就来了,佛萨奇项目系统I34-开发I633-搭建53I9,通过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来调用进行相应变量的数据处理并返回结果。
S6matrix。这是Metaforce中的第二个模型,称为中的第二个模型,S6矩阵。S6矩阵怎么样,也就是下面的?它有六个要点。排的两点在哪里?也就是说,每次进来的资金上涨,你不拿,但是在二线。你的钱是,第二,第三个位置是100%,然后是100%或者100%。第二行的后一个位置叫循环位。不管是在哪里S3矩阵还是S在6矩阵中,所有循环BT都有相同的含义。
循环位的作用是清空和重置你的矩阵,因为只有在仓位清空后,你才能享受到入境资金的利润。你能理解你的合作伙伴吗?S在6矩阵中,佛萨奇项目系统I34-开发I633-搭建53I9,循环位是第二行的第二位或第四位,所以这取决于哪个位置先来,然后循环位会帮助你重新投资,然后位置会改变。简单地说,在S在6矩阵中,以下六点可能来自你的上级,你的上级或上级的下属,或你的左朋友,或你的右朋友,或你的下属朋友,360度。
S6矩阵的排有两个位置,也就是说会给你的上级。然后,倒数四个位置中有三个位置,你得到了100%。其中一个是帮助你重置矩阵的圆形位置。所以在这里,很多合作伙伴不知道的是,排的两个位置必须给你的上级。答案是,这是你上级的第二排。也许是给你的上级,直接拿了100%。也许他是一个圆,然后重置整个点。S矩阵可享受全球公共行。
一、编写合约合约示例,一个简单的做加法的合约
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 = hp***ntract(abi)addcontract = addContract.new({from:hp***inbase,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:hp***inbase}) //返回交易hash :“0x4298e32d61c4a2447d862295cefdef0bc89490df65dff06f20a57c1962d7d84e”此时可以看到txpool中有一条交易。另外也可以通过myContract.add.call(1,2)来直接调用合约,但不产生交易,而是直接返回结果3。
五、代码分析那么问题就来了,佛萨奇项目系统I34-开发I633-搭建53I9,通过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来调用进行相应变量的数据处理并返回结果。