Nesta seção, discutiremos o processo de escrever um contrato inteligente básico usando Solidity. Abordaremos componentes essenciais como variáveis, funções e modificadores. Em seguida, passaremos por um exemplo de implementação de um contrato de token simples.
Variáveis, funções e modificadores
Exemplo1: Implementando um contrato de token simples
Vamos criar um contrato de token simples usando Solidity. Este contrato permitirá aos usuários transferir tokens entre contas e verificar o saldo do token de qualquer conta.
pragma solidity ^0.8.0;contrato SimpleToken { // Declare variáveis de estado endereço público do proprietário; mapeando(endereço => uint256) saldos públicos; // Inicializa o contrato de token constructor(uint256 ofertaInicial) { owner = msg.sender; saldos[proprietário] = ofertaInicial; } // Função para transferir tokens função transfer(address para, uint256 quantidade) público { require(saldos[msg.sender] >= quantidade, "Saldo insuficiente"); saldos[msg.sender] -= quantidade; saldos[para] += quantidade; } // Função para verificar o saldo do token de uma conta função balanceOf(endereço da conta) público visualização retorna (uint256) { return saldos[conta]; }}
Neste contrato, temos:
proprietário
esaldos
para armazenar o endereço do proprietário do contrato e os saldos de token de todos os endereços, respectivamente.construtor
função que define o fornecimento inicial de tokens e os atribui ao proprietário do contrato.transferir
função que permite aos usuários transferir tokens para outras contas. Ele usa o exigir
declaração para garantir que o remetente tenha tokens suficientes para transferir.saldoDe
função que retorna o saldo do token de uma conta especificada.Exemplo 2: Implementando um sistema de votação simples
pragma solidity ^0.8.0;contrato SistemaDeVotacao { mapeando (bytes32 => uint256) public votesReceived; bytes32[] public candidateList; constructor(bytes32[] memory candidateNames) { candidateList = candidateNames; } function votarNoCandidato(bytes32 candidato) public { require(candidatoValido(candidato), "Candidato inválido."); votesReceived[candidato] += 1; } function totalDeVotosPara(bytes32 candidato) public view returns (uint256) { require(candidatoValido(candidato), "Candidato inválido."); return votesReceived[candidato]; } function candidatoValido(bytes32 candidato) public view returns (bool) { for (uint256 i = 0; i < candidateList.length; i++) { if (candidateList[i] == candidato) { return true; } } return false; }}
Neste exemplo, o Sistema de Votação
contrato permite que os usuários votem em um dos vários candidatos chamando ovotarNoCandidato
função. O contrato mantém o controle do número de votos recebidos para cada candidato usando um votos recebidos
mapeamento, onde a chave é o nome do candidato e o valor é o número de votos. lista de candidatos
variável armazena a lista de candidatos válidos. O totalVotesFor
a função pode ser chamada para verificar o número de votos que um candidato específico recebeu e o candidato válido
A função verifica se um candidato é válido. Este é um exemplo simples de como o Solidity pode ser usado para construir aplicações descentralizadas com lógica complexa.
Destaques
Variáveis, funções e modificadores são componentes essenciais nos contratos inteligentes Solidity.
Solidity possui dois tipos de variáveis: variáveis de estado e variáveis locais.
As funções são usadas para realizar tarefas e podem ter parâmetros de entrada e valores de retorno.
Os modificadores são usados para modificar o comportamento de uma função e melhorar a legibilidade e a gerenciabilidade do código.
O contrato SimpleToken permite aos usuários transferir tokens e verificar saldos de tokens.
O contrato SimpleToken demonstra o uso de variáveis de estado, uma função construtora e funções como transferir e balanceOf.
O contrato VotingSystem permite que os usuários votem em candidatos e acompanhem a contagem de votos.
O contrato VotingSystem demonstra o uso de mapeamentos, arrays e funções como voteForCandidate, totalVotesFor e validCandidate.
Nesta seção, discutiremos o processo de escrever um contrato inteligente básico usando Solidity. Abordaremos componentes essenciais como variáveis, funções e modificadores. Em seguida, passaremos por um exemplo de implementação de um contrato de token simples.
Variáveis, funções e modificadores
Exemplo1: Implementando um contrato de token simples
Vamos criar um contrato de token simples usando Solidity. Este contrato permitirá aos usuários transferir tokens entre contas e verificar o saldo do token de qualquer conta.
pragma solidity ^0.8.0;contrato SimpleToken { // Declare variáveis de estado endereço público do proprietário; mapeando(endereço => uint256) saldos públicos; // Inicializa o contrato de token constructor(uint256 ofertaInicial) { owner = msg.sender; saldos[proprietário] = ofertaInicial; } // Função para transferir tokens função transfer(address para, uint256 quantidade) público { require(saldos[msg.sender] >= quantidade, "Saldo insuficiente"); saldos[msg.sender] -= quantidade; saldos[para] += quantidade; } // Função para verificar o saldo do token de uma conta função balanceOf(endereço da conta) público visualização retorna (uint256) { return saldos[conta]; }}
Neste contrato, temos:
proprietário
esaldos
para armazenar o endereço do proprietário do contrato e os saldos de token de todos os endereços, respectivamente.construtor
função que define o fornecimento inicial de tokens e os atribui ao proprietário do contrato.transferir
função que permite aos usuários transferir tokens para outras contas. Ele usa o exigir
declaração para garantir que o remetente tenha tokens suficientes para transferir.saldoDe
função que retorna o saldo do token de uma conta especificada.Exemplo 2: Implementando um sistema de votação simples
pragma solidity ^0.8.0;contrato SistemaDeVotacao { mapeando (bytes32 => uint256) public votesReceived; bytes32[] public candidateList; constructor(bytes32[] memory candidateNames) { candidateList = candidateNames; } function votarNoCandidato(bytes32 candidato) public { require(candidatoValido(candidato), "Candidato inválido."); votesReceived[candidato] += 1; } function totalDeVotosPara(bytes32 candidato) public view returns (uint256) { require(candidatoValido(candidato), "Candidato inválido."); return votesReceived[candidato]; } function candidatoValido(bytes32 candidato) public view returns (bool) { for (uint256 i = 0; i < candidateList.length; i++) { if (candidateList[i] == candidato) { return true; } } return false; }}
Neste exemplo, o Sistema de Votação
contrato permite que os usuários votem em um dos vários candidatos chamando ovotarNoCandidato
função. O contrato mantém o controle do número de votos recebidos para cada candidato usando um votos recebidos
mapeamento, onde a chave é o nome do candidato e o valor é o número de votos. lista de candidatos
variável armazena a lista de candidatos válidos. O totalVotesFor
a função pode ser chamada para verificar o número de votos que um candidato específico recebeu e o candidato válido
A função verifica se um candidato é válido. Este é um exemplo simples de como o Solidity pode ser usado para construir aplicações descentralizadas com lógica complexa.
Destaques
Variáveis, funções e modificadores são componentes essenciais nos contratos inteligentes Solidity.
Solidity possui dois tipos de variáveis: variáveis de estado e variáveis locais.
As funções são usadas para realizar tarefas e podem ter parâmetros de entrada e valores de retorno.
Os modificadores são usados para modificar o comportamento de uma função e melhorar a legibilidade e a gerenciabilidade do código.
O contrato SimpleToken permite aos usuários transferir tokens e verificar saldos de tokens.
O contrato SimpleToken demonstra o uso de variáveis de estado, uma função construtora e funções como transferir e balanceOf.
O contrato VotingSystem permite que os usuários votem em candidatos e acompanhem a contagem de votos.
O contrato VotingSystem demonstra o uso de mapeamentos, arrays e funções como voteForCandidate, totalVotesFor e validCandidate.