solidity基本语法

本文介绍了Solidity编程语言的基础操作,如加减乘除运算,并展示了如何使用SafeMath库来确保数学运算的安全性。此外,还详细讲解了ERC20代币标准,包括totalSupply、balanceOf和transfer等核心函数的实现,以及如何在智能合约中进行转账操作。通过一个名为BasicToken的合约,阐述了如何继承ERC20Basic并实现相关功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

solidity 版本
pragma solidity ^0.5.0;
.mul 乘法
.div 除法
.sub 减法
.add 加法
library 库
library SafeMath {
  function mul(uint256 a, uint256 b) internal pure returns (uint256 c) {
    if (a == 0) {
      return 0;
    }
    c = a * b;
    assert(c / a == b);
    return c;
  }
}

contract BasicToken{
	 //使用之前的工具类  只要是uint256类型的都可以用这个库里的方法   
	using SafeMath for uint256;
	//账户及余额的mapping 其实就像一个map key是地址 value是余额
	mapping(address => uint256) balances;
	function transfer((address _to, uint256 _value) public returns (bool success){
		balances[msg.sender] = balances[msg.sender].sub(_value);
	}
}
//https://eips.ethereum.org/EIPS/eip-20
// erc20协议提供的基本核心函数
contract ERC20Basic {
//查询合约上代币总数
  function totalSupply() public view returns (uint256);
  //查询指定地址代币余额
  function balanceOf(address who) public view returns (uint256);
  //代币交易
  function transfer(address to, uint256 value) public returns (bool);
  event Transfer(address indexed from, address indexed to, uint256 value);
}

//is 继承  继承了上面ERC20Basic合约
contract BasicToken is ERC20Basic {
  function transfer(address _to, uint256 _value) public returns (bool) {
	  require(_to != address(0));
	  require(_value <= balances[msg.sender]);
	
	  balances[msg.sender] = balances[msg.sender].sub(_value);
	  balances[_to] = balances[_to].add(_value);
	  emit Transfer(msg.sender, _to, _value);
	  return true;
 }
  
 function balanceOf(address _owner) public view returns (uint256) {
    return balances[_owner];
 }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值