ETH Kipu
  • Ethereum Developer Pack
  • Módulo 1
    • Intro a Smart Contracts
      • Fundamentos de Blockchain
        • Antecedentes
        • Bitcoin
        • Qué es Blockchain
        • Conceptos Clave en Blockchain
        • Cómo funciona la Blockchain
        • Tipos de Blockchain
        • Modelos de Consenso
      • El nuevo Internet
        • Web 3
        • Elementos Fundamentales
        • Impacto de Ethereum en Diversos Sectores
      • Wallets
        • Componentes de una wallet
        • Tipos de Wallet
        • Códigos mnemónicos
      • Ethereum 101
        • Smart Contracts
        • Cuentas
          • Tipos de cuentas
          • Contenido de cuentas
        • Transacciones
          • Componentes
          • Ciclo de vida
        • Gas
        • Solidity
        • EVM
          • La máquina de estados
          • Opcodes
          • Cómo funciona la EVM
          • Clientes de ejecución
          • DApps
      • Blockchain Explorer
        • Funciones de un blockchain explorer
        • Beneficios de utilizar un blockchain explorer
      • Remix
        • Características de Remix
        • Workspaces o espacios de trabajo
        • Cargar y compilar un contrato
        • Desplegar en la máquina virtual de Remix (Remix VM)
        • Interactuando con funciones
        • Desplegar en una red pública
      • Crea tu primer Smart Contract
  • Módulo 2
    • Fundamentos de Solidity
      • Hello World
      • Tipos de Datos
      • Funciones
      • Variables
        • Ejercicio 1
      • Operadores
        • Ejercicio 2
      • Constructor
        • Ejercicio 3
      • Convenciones de nomenclatura
      • Tipos de almacenamiento para variables
      • Estructuras de Control
        • Ejercicio 4
      • Modificadores
      • Eventos
        • Ejercicio 5
      • Tipos de Referencia
        • Arrays
          • Ejercicio 6
        • Mappings
          • Ejercicio 7
        • Structs
          • Ejercicio 8
      • Address Payable
      • Cómo reciben Ether los contratos y funciones
      • Transferencias de Ether
      • Conceptos Avanzados
        • Codificación ABI
        • Hashing
        • This
        • Herencia
        • Abstract
        • Interface
        • Llamadas entre contratos
        • EVM
        • ABI
        • Bytecode
        • Opcodes
  • Módulo 3
    • Estándares, Librerías y Patrones
      • Buenas Prácticas de Diseño
      • Patrones de Diseño
      • EIP y ERC
      • ERC-20
      • ERC-721
      • Open Zeppelin
      • Crea un Token ERC-20
      • Almacenamiento Descentralizado: IPFS
      • Crea un Token ERC-721
      • DeFi
  • Módulo 4
    • Toolkit para desarrollo en Ethereum
      • Requisitos para el módulo 4
        • Terminal
        • Git y Github
        • Node.js y npm
        • Visual Studio Code para Solidity
      • Toolkit
        • JSON-RPC
        • Ethers.js
          • Ejercicio
        • Hardhat
          • Despliegue de un contrato en Hardhat
          • Despliegue de un contrato en una red pública
        • Scaffold-ETH
          • Características
          • Cómo instalar Scaffold-ETH
  • Módulo 5
    • Seguridad, Pruebas y Auditoría
      • Pruebas
        • Importancia de realizar pruebas
        • Métodos para probar contratos inteligentes
          • Pruebas automatizadas
          • Pruebas manuales
        • Conceptos importantes en testing
        • Herramientas para testing
        • Testing con Hardhat
        • Recursos adicionales
      • Seguridad
        • Una mentalidad distinta de diseño
        • Principales vulnerabilidades en smart contracts
          • Reentrancy attack (ataque de reentrada)
          • Replay attack (ataque de repetición)
          • Price Oracle Manipulation (Manipulación de Oráculos de Precios)
          • Missing Access Control (Pérdida de Control de Acceso)
          • Reward Manipulation (Manipulación de Recompensas)
          • Failure to Initialize (Falla al Inicializar)
          • Front-running
          • Invariant Breaks (Ruptura de invariantes)
          • Mishandling of ETH (Mal manejo de ETH)
          • Denial of Service (DoS - Denegación de Servicio)
          • Integer overflow and underflow (desbordamiento y subdesbordamiento de enteros)
          • Phishing y Typosquatting
        • Recursos adicionales
      • Auditoría de smart contracts
        • Proceso de Auditoría
        • Herramientas
        • Cómo prepararse para una auditoría
        • El test Rekt
        • Retos
        • Recursos adicionales
  • Contribuye
    • Kipu Explorer
Powered by GitBook
On this page

Was this helpful?

  1. Módulo 2
  2. Fundamentos de Solidity
  3. Tipos de Referencia

Arrays

Son una manera de almacenar datos de un mismo tipo. Pueden ser de dos tipos: estáticos y dinámicos. Los arrays estáticos tienen un tamaño fijo que se define en el momento de su declaración, mientras que los arrays dinámicos pueden cambiar de tamaño durante la ejecución del contrato.

Declaración de Arrays

Para declarar un array, especificas el tipo de los elementos que contendrá, seguido de corchetes []. Si los corchetes están vacíos, el array es dinámico; si contienen un número, es estático y el número indica su tamaño.

pragma solidity ^0.8.0;

contract EjemploArrays {
    // Array estático con espacio para 5 enteros
    uint[5] public arrayEstatico;

    // Array dinámico que puede contener un número arbitrario de enteros
    uint[] public arrayDinamico;
}

Operaciones Básicas

Acceso a Elementos

Puedes acceder a elementos de un array utilizando su índice, empezando por el 0.

uint valor = arrayEstatico[0]; // Accede al primer elemento del array estático

Cambiar Tamaño (Solo Arrays Dinámicos)

Para cambiar el tamaño de un array dinámico, puedes usar la función push() para agregar un nuevo elemento al final del array o pop() para eliminar el último elemento.

arrayDinamico.push(10); // Añade el valor 10 al final del array dinámico
arrayDinamico.pop(); // Elimina el último elemento del array dinámico

Longitud del Array

La propiedad length te permite obtener la longitud de un array, ya sea estático o dinámico.

uint longitud = arrayDinamico.length; // Obtiene la longitud del array dinámico

A continuación un ejemplo de un contrato que inicializa un array con valores enteros utilizando **push()**y que puede también eliminar elementos del array utilizando pop() .

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.13; 

contract ArraysDS { 
		// Se declara un array dinámico de tipo entero 
		int[] numbers; 
		// función para añadir valores a un array  
		function store() public returns (int[] memory){ 
			numbers.push(5);
			numbers.push(10);
			numbers.push(20);
			return  numbers; 
		}  

		//función para retirar el ultimo valor del array
		function deleteLastElement() public returns(int[] memory){
		  numbers.pop(); 
			return numbers;  
		} 
} 

Consideraciones de Uso

  • Costo de Gas: Las operaciones que cambian el tamaño de un array dinámico, como push y pop, incurren en costos de gas que pueden variar según la complejidad de la operación.

  • Arrays Multidimensionales: Solidity también soporta arrays multidimensionales, pero ten en cuenta que el manejo de estos puede aumentar rápidamente los costos de gas debido a la complejidad adicional.

  • Limitaciones en Arrays Estáticos: Aunque los arrays estáticos pueden parecer limitantes, su tamaño fijo puede ser beneficioso para optimizar el uso de gas en ciertos casos, ya que el coste de las operaciones es predecible y no varía.

PreviousTipos de ReferenciaNextEjercicio 6

Last updated 8 months ago

Was this helpful?