区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。是一个共享的分布式账本,其中交易通过附加块永久记录。
本质上来说,智能合约是一段程序,它以计算机指令的方式实现了传统合约的自动化处理。智能合约程序不只是一个可以自动执行的计算机程序,它本身就是一个系统参与者,对接收到的信息进行回应,可以接收和储存价值,也可以向外发送信息和价值。这个程序就像一个可以被信任的人,可以临时保管资产,总是按照事先的规则执行操作。简单讲,智能合约就是双方在区块链资产上交易时,触发执行的一段代码,这段代码就是智能合约。提前规定好合约的内容,当在满足触发合约条件的时候,程序就会自动执行合约内容。
function addLiquidity(
address tokenA,
address tokenB,
uint amountADesired,
uint amountBDesired,
uint amountAMin,
uint amountBMin,
address to,
uint deadline
) external virtual override ensure(deadline) returns (uint amountA, uint amountB, uint liquidity) {
(amountA, amountB) = _addLiquidity(tokenA, tokenB, amountADesired, amountBDesired, amountAMin, amountBMin);
address pair = UniswapV2Library.pairFor(factory, tokenA, tokenB);
TransferHelper.safeTransferFrom(tokenA, msg.sender, pair, amountA);
TransferHelper.safeTransferFrom(tokenB, msg.sender, pair, amountB);
liquidity = IUniswapV2Pair(pair).mint(to);
}
function addLiquidity(
address tokenA, // 添加流动性 tokenA 的地址
address tokenB, // 添加流动性 tokenB 的地址
uint amountADesired, // 期望添加 tokenA 的数量
uint amountBDesired, // 期望添加 tokenB 的数量
uint amountAMin, // 添加 tokenA 的最小数量
uint amountBMin // 添加 tokenB 的最小数量
address to, // 获得的 LP 发送到的地址
uint deadline // 过期时间
) external virtual override ensure(deadline) returns (
uint amountA, // 实际添加 tokenA 的数量
uint amountB // 实际添加 tokenB 的数量
uint liquidity // 获得 LP 的数量
) {
...
}