solidity基本语法

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];
 }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Solidity是一种面向智能合约的编程语言,用于在以太坊平台上开发去中心化应用(DApp)。它的基本语法结构包括以下几个方面: 1. 声明:使用关键字`contract`来声明一个合约,类似于面向对象编程中的类。例如:`contract MyContract { ... }` 2. 状态变量:在合约中声明的变量称为状态变量,它们存储在以太坊区块链上。可以使用关键字`uint`、`bool`、`address`等来声明不同类型的变量。例如:`uint public myNumber;` 3. 函数:合约中的函数用于定义合约的行为。可以使用关键字`function`来声明函数,并指定函数的可见性(如`public`、`private`等)。例如:`function myFunction() public { ... }` 4. 事件:事件用于在合约中触发和记录特定的操作。可以使用关键字`event`来声明事件,并定义事件的参数。例如:`event MyEvent(address indexed _from, uint _value);` 5. 修饰器:修饰器用于修改函数的行为或者检查函数的前置条件。可以使用关键字`modifier`来声明修饰器,并在函数定义时使用修饰器。例如:`modifier onlyOwner() { ... }` 6. 构造函数:构造函数在合约创建时执行,并用于初始化合约的状态变量。构造函数与合约同名,并且没有返回类型。例如:`constructor() { ... }` 7. 继承:Solidity支持合约之间的继承关系,可以使用关键字`is`来实现继承。例如:`contract MyContract is BaseContract { ... }` 8. 异常处理:Solidity提供了异常处理机制,可以使用关键字`try`和`catch`来捕获和处理异常。例如:`try { ... } catch { ... }` 以上是Solidity基本语法结构,通过这些基本元素可以编写出功能丰富的智能合约。如果你还有其他问题,请继续提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值