- vừa được xem lúc

Smart contract using Solidity (part 1)

0 0 29

Người đăng: Tùng

Theo Viblo Asia

Introduction

Smart contract: Simply a program that runs on the Ethereum blockchain, has specific address on blockchain, not controlled by a user.

Ethereum virtual machine (EVM): It's the environment to Ethereum accounts and smart contracts live.

Solidity: A high-level programming language, use to develop smart contracts.

Remix: An online IDE allows develop, compile, deploy smart contracts for Ethereum.

Here is a simple example of Smart Contract:

// SPDX-License-Identifier: GPL-3.0
pragma solidity >=0.7.1 <0.9.0; contract Message { string private message; constructor() { message = "hello world1"; } function setMessage(string memory mes) public { message = mes; } function getMessage() view public returns(string memory) { return message; }
}

Smart Contracts life cycle

As shown in the above figure, the smart contract life cycle follows the steps below :

  • A Smart contract is implemented using a high level language such as Solidity.
  • Smart contract is compiled to two results that specifically are: Bytecode (which is a stack-based machine language compiled and executable by the EVM) and an ABI - Application Binary Interface (which is a JSON file that describes the distributed contract and the functions of the smart contract). The ABI is the bridge between Web2 and Web3.
  • After that, the smart contract is deployed. This consists of creating a transaction packing the smart contract bytecode, and sending it to the network. The transaction gets its own contract account which has an address, a balance, a Nonce, and holds the bytecode in the data field.
  • Finally, a Smart contract is invoked. This consists of external calls to the smart contract.

Special note:

  • When a contract is created, the constructor function is executed once and that first call is always triggered by an EOA account (Externally Owned Account).
  • A smart contract is not self-executable. It requires an external call to be executed.
  • Once it is executed, transactions resulting from the execution are transcribed on the blockchain and eventually smart contracts meta data are updated.

Solidity: Variables and Functions

Variables

The following value types:

Type Default value Example
int and uint (all sizes) 0 int number; uint age; // 0
bool false bool flag; // false
string Empty string string name; // “”
bytes1 to bytes32 All bytes set to 0 bytes3 gender; // 0x000000
Static array All items set to default value int[3] numbers; // [0, 0, 0]
Dynamic array Empty array int[] numbers; // []
struct Each element set to default value struct Student { string name;uint age;bool gender;}
address (bytes20) address myAddress; // 0x0000000000000000000000000000000000000000
enum enum status {active, inactive, cancel};
mapping (as hash tables) mapping(address => unit) balances;

The concept of “undefined” or “null” values does not exist in Solidity.

There are three types of variables:

  • State Variables: Variables whose values are permanently stored in a contract storage.
  • Local Variables: Variables whose values are present till function is executing.
  • Global Variables: Special variables exists in the global namespace used to get information about the blockchain.

Syntax:

<type> <access-modifier> <variable-name> ;

Example:

uint public age;

State Variable Scope:

Name Describe
Public Can be accessed internally contract. The compiler automatically creates getter functions for all public state variables.
Internal (default) Can be accessed internally from the current contract. And contract inheriting from it without using this.
Private Can be accessed only internally from the current contract.

Functions

Syntax:

function <function-name>(<parameter-list>) <scope> returns(<return-type-list>) { // block code }

Example:

function getSender() public returns (address) { return msg.sender;
}

Function Scope:

Name Describe
Private Only be called by the main contract itself.
Internal Only be called by the main contract itself. And contract inheriting from it.
External Only be called from a third-party.
Public (default) Externally and internally.

Cryptocurrency example

The following contract implements the simplest form of a cryptocurrency

// SPDX-License-Identifier: GPL-3.0
pragma solidity >=0.7.1 <0.9.0; contract PBCoin { address private owner; mapping(address => uint) balances; event Sent(address from, address to, uint amount); constructor() { owner = msg.sender; balances[owner] = 1000000; } function send(address receiver, uint amount) public { require(amount <= balances[msg.sender]); balances[msg.sender] -= amount; balances[receiver] += amount; emit Sent(msg.sender, receiver, amount); } function getBalance(address receiver) view public returns(uint) { return balances[receiver]; }
}

References

https://docs.soliditylang.org/en/v0.8.16/introduction-to-smart-contracts.html

https://remix.ethereum.org/

Thanks for reading!!

Bình luận

Bài viết tương tự

- vừa được xem lúc

Code Smart Contract bằng Assembly ?

Introduction. Hồi còn học trong ghế nhà trường bộ môn lập trình tốn nhiều não nhất của mình là code assembly. Nôm na thì bất cứ ngôn ngữ bậc cao nào như C , Go, Java,... được sinh ra để người dễ hiểu và dễ code , tuy nhiên chúng đều sẽ được compiled down xuống assembly một ngôn ngữ bậc thấp để máy h

0 0 59

- vừa được xem lúc

Tích hợp Band Protocol để lấy dữ liệu off-chain cho smart contract

Khoan nói về Band Protocol là gì, mình sẽ đi thẳng vào công dụng của nó, có thể đây chính là mảnh ghép mà bạn vẫn luôn tìm kiếm cho Dapp của mình. Band protocol hỗ trợ các contract giao tiếp với dữ liệu từ thế giới bên ngoài như các dữ liệu về thời tiết, thể thao, giá trị cổ phiếu, tỉ giá các đồng n

0 0 68

- vừa được xem lúc

Xây dựng ứng dụng Dapps đầu tiên của bạn

Tutorial này sẽ giúp bạn xây dựng dapp đầu tiên của bạn – một hệ thống theo dõi chủ nuôi trong một tiệm thú cưng! Được dịch từ tutorial của Truffle. .

1 1 742

- vừa được xem lúc

Làm thế nào để một smart contract có thể nhận NFT (Non-Fungible Token)?

Mở đầu. Như chúng ta đã biết, trên các chain chạy evm ngày nay ngoài Native coin (ETH) và Fungible Token (ERC20) thì chúng còn cón Non-Fungible Token (ERC721 và ERC1155).

0 0 138

- vừa được xem lúc

Lập trình smart contract để tạo NFT kết hợp với Chainklink và IPFS

NFTs hay tên tiếng Anh là Non-Fungible Tokens có nghĩa là token duy nhất mà không bất kì token nào khác giống như nó. .

0 0 294

- vừa được xem lúc

Tản mạn về lỗ hổng trong smart contract của Fairmoon Token, các dấu hiệu bất thường và nguy cơ từ crypto

Hôm nay (19/05/2021) là một ngày đen tối đối với cộng đồng crypto khi:. .

0 0 69