Чтение онлайн

ЖАНРЫ

Смарт-контракты. Что такое смарт-контракт и как его создать в Solidity. С подробным разбором кода
Шрифт:

string[] public names; // Динамический массив строк

numbers = [10, 20, 30, 40, 50]; // Присвоение значений фиксированному массиву

names.push("Alice"); // Добавление значения в динамический массив

Структуры (struct)

Структуры

позволяют создавать пользовательские типы данных, объединяя различные поля. Это удобно, когда нужно хранить связанные данные в одной переменной.

Пример использования структуры:

struct Person {

string name;

uint256 age;

}

Person public alice;

alice = Person("Alice", 30); // Инициализация структуры

Основные типы данных Solidity позволяют эффективно хранить и обрабатывать информацию в смарт-контрактах. При создании смарт-контрактов важно правильно выбирать тип данных в зависимости от характера данных и требований к работе контракта.

3.4.2 Хранилище данных

В смарт-контрактах управление данными является фундаментальной задачей. Данные могут быть различных типов – от чисел и строк до более сложных структур. Понимание того, как работает хранилище данных, поможет вам создавать эффективные и безопасные смарт-контракты.

Переменные состояния и локальные переменные

Один из ключевых аспектов управления данными – это различие между переменными состояния (state variables) и локальными переменными (local variables).

Переменные состояния хранят данные на блокчейне и сохраняют свои значения между вызовами функций. Они могут быть доступны для всех, кто читает состояние контракта. Эти переменные широко используются для хранения постоянных данных, таких как балансы пользователей, настройки контракта

и другие глобальные параметры.

Локальные переменные, с другой стороны, существуют только внутри функции и исчезают после её выполнения. Они используются для временных вычислений и обработки данных внутри функций. Локальные переменные полезны, когда вам нужно временно хранить промежуточные результаты вычислений или выполнять действия внутри функции, не оставляя следов в состоянии контракта.

Пример использования переменных состояния и локальных переменных

Давайте представим, что у нас есть смарт-контракт для управления простым токеном. Мы хотим хранить общее количество выпущенных токенов и балансы каждого адреса.

contract SimpleToken {

uint256 public totalSupply;

mapping(address => uint256) public balances;

constructor(uint256 initialSupply) {

totalSupply = initialSupply;

balances[msg.sender] = initialSupply;

}

function transfer(address to, uint256 amount) public {

require(balances[msg.sender] >= amount, "Not enough balance");

balances[msg.sender] -= amount;

balances[to] += amount;

}

}

В этом примере:

totalSupply – переменная состояния, хранящая общее количество выпущенных токенов. Она будет доступна для всех, кто хочет проверить общее количество токенов в обращении.

Конец ознакомительного фрагмента.

Поделиться с друзьями: