DeFi流动性质押挖矿系统开发流程及规则
DeFi流动性质押系统开发,【I88-系统1928-8024开发】,由允许存储和显示信息的代码组成,任何人都可以看到。由于区块链网络的性质,该信息是不可变的,这意味着它不能被更改。如果发布的智能合约包含代码错误,它将永远保持这种状态。智能合约用于确定某些操作,如验证所有权、显示代币元数据以及启用和记录传输
首先使用修改器做了一次时间戳校验,传入的时间戳必须大于当前区块的时间戳。
modifier ensure(uint deadline){
require(deadline>=block.timestamp,'UniswapV2Router:EXPIRED');
并以密码学方式保证的不可篡改和不可伪造的分布式账本。广义来讲,区块链技术是利用块链式数据结构来验证与存储数据、利用分布式节点共识算法来生成和更新数据、利用密码学的方式保证数据传输和访问的安全、利用由自动化脚本代码组成的智能合约来编程和操作数据的一种全新的分布式基础架构与计算范式。
然后调用了_addLiquidity
//****ADD LIQUIDITY****
function _addLiquidity(
address tokenA,//yp
address tokenB,//Weth
uint amountADesired,//yp amount
uint amountBDesired,//msg.value
uint amountAMin,//滑点后
uint amountBMin//滑点后
)internal virtual returns(uint amountA,uint amountB){
//create the pair if it doesn't exist yet
//创建币对
if(IUniswapV2Factory(factory).getPair(tokenA,tokenB)==address(0)){
IUniswapV2Factory(factory).createPair(tokenA,tokenB);
}
现在区块链技术的大规模应用还处于萌芽阶段,随着区块链技术的普及,现有的商业模式和利益分配规则一定会受到巨大冲击,互联网巨头企业对用户数据的垄断将被打破,让之前无法掌握这些数据的企业和组织也能够投身到相关的技术创新中去,从而推动整体技术的发展。
(uint reserveA,uint reserveB)=UniswapV2Library.getReserves(factory,tokenA,tokenB);
if(reserveA==0&&reserveB==0){
(amountA,amountB)=(amountADesired,amountBDesired);
}else{
uint amountBOptimal=UniswapV2Library.quote(amountADesired,reserveA,reserveB);
//计算出来的weth数量小于发送的eth数量
if(amountBOptimal<=amountBDesired){
require(amountBOptimal>=amountBMin,'UniswapV2Router:INSUFFICIENT_B_AMOUNT');
(amountA,amountB)=(amountADesired,amountBOptimal);
}else{//大于。
uint amountAOptimal=UniswapV2Library.quote(amountBDesired,reserveB,reserveA);
assert(amountAOptimal<=amountADesired);
require(amountAOptimal>=amountAMin,'UniswapV2Router:INSUFFICIENT_A_AMOUNT');
(amountA,amountB)=(amountAOptimal,amountBDesired);
商业逻辑(即合约)是基于概率的,也就是说合约有可能会按照约定条款执行也有可能不会;而智能合约则是高度确定的,也就是说合约百分之百会给按照规定条款执行。智能合约之所以能分毫不差地执行,是因为它们所在的块链环境具有去中心化、无须许可、防篡改和永远在线的特性
首先使用修改器做了一次时间戳校验,传入的时间戳必须大于当前区块的时间戳。
modifier ensure(uint deadline){
require(deadline>=block.timestamp,'UniswapV2Router:EXPIRED');
并以密码学方式保证的不可篡改和不可伪造的分布式账本。广义来讲,区块链技术是利用块链式数据结构来验证与存储数据、利用分布式节点共识算法来生成和更新数据、利用密码学的方式保证数据传输和访问的安全、利用由自动化脚本代码组成的智能合约来编程和操作数据的一种全新的分布式基础架构与计算范式。
然后调用了_addLiquidity
//****ADD LIQUIDITY****
function _addLiquidity(
address tokenA,//yp
address tokenB,//Weth
uint amountADesired,//yp amount
uint amountBDesired,//msg.value
uint amountAMin,//滑点后
uint amountBMin//滑点后
)internal virtual returns(uint amountA,uint amountB){
//create the pair if it doesn't exist yet
//创建币对
if(IUniswapV2Factory(factory).getPair(tokenA,tokenB)==address(0)){
IUniswapV2Factory(factory).createPair(tokenA,tokenB);
}
现在区块链技术的大规模应用还处于萌芽阶段,随着区块链技术的普及,现有的商业模式和利益分配规则一定会受到巨大冲击,互联网巨头企业对用户数据的垄断将被打破,让之前无法掌握这些数据的企业和组织也能够投身到相关的技术创新中去,从而推动整体技术的发展。
(uint reserveA,uint reserveB)=UniswapV2Library.getReserves(factory,tokenA,tokenB);
if(reserveA==0&&reserveB==0){
(amountA,amountB)=(amountADesired,amountBDesired);
}else{
uint amountBOptimal=UniswapV2Library.quote(amountADesired,reserveA,reserveB);
//计算出来的weth数量小于发送的eth数量
if(amountBOptimal<=amountBDesired){
require(amountBOptimal>=amountBMin,'UniswapV2Router:INSUFFICIENT_B_AMOUNT');
(amountA,amountB)=(amountADesired,amountBOptimal);
}else{//大于。
uint amountAOptimal=UniswapV2Library.quote(amountBDesired,reserveB,reserveA);
assert(amountAOptimal<=amountADesired);
require(amountAOptimal>=amountAMin,'UniswapV2Router:INSUFFICIENT_A_AMOUNT');
(amountA,amountB)=(amountAOptimal,amountBDesired);
商业逻辑(即合约)是基于概率的,也就是说合约有可能会按照约定条款执行也有可能不会;而智能合约则是高度确定的,也就是说合约百分之百会给按照规定条款执行。智能合约之所以能分毫不差地执行,是因为它们所在的块链环境具有去中心化、无须许可、防篡改和永远在线的特性