Chuyển đến nội dung chính

Tự học Solidity bài 33: For Loops. Sử dụng view và vòng lặp để tối ưu gas trong SOLIDITY

Tự học Solidity bài

For Loops. vòng lặp trong ngôn ngữ lập trình SOLIDITY

Summary for English Visiterfunction getEvens() pure external returns(uint[] memory) {
  uint[] memory evens = new uint[](5);
  uint counter = 0;
  for (uint i = 1; i <= 10; i++) {

    if (i % 2 == 0) {   
      evens[counter] = i;
      counter++;
    }
  }
  return evens;
}//This function will return an array with the contents [2, 4, 6, 8, 10].

Sử dụng view và vòng lặp để tối ưu gas trong SOLIDITY

Quay lại ví dụ những thây ma zombie của chúng ta, chúng ta không thể lưu trữ zombie cho riêng mỗi chủ sở hữu thành một mảng riêng vì như vậy rất tốn gas. Đặc biệt là khi có thao tác chuyển đổi zombie từ chủ sở hữu A sang chủ sở hữu B. Như thế sẽ phát sinh số lượng công việc gồm 3 bước:

1. Chuyển zombie đến mảng zombie của chủ sở hữu mới.  Xóa thây ma khỏi mảng zombie chủ sở hữu cũ. 
2. Di chuyển các thây ma trong bộ sưu tập zombie của chủ sở hữu cũ (để để lấp vào chỗ trống zombie chuyển đi) và sau đó giảm độ dài mảng đi 1.
3. Bước này sẽ cực kỳ tốn phí gas, vì chúng ta phải gán lại vị trí trong mảng cho mọi zombie. Nếu chủ sở hữu có 200 zombie chúng ta sẽ phải gán lại 19 vị trí của zombie mảng. 

Vì thay đổi dữ liệu bộ nhớ storage là một trong những hoạt động tốn phí gas nhất trong Solidity, nên mọi lệnh gọi đến hàm chuyển sở hữu zombie như trên sẽ cực kỳ tốn gas. Và tệ hơn, nó sẽ tốn một lượng gas khác nhau mỗi khi nó được gọi, tùy thuộc vào số lượng zombie chủ sở hữu!

Vậy giải pháp tối ưu (miễn phí gas!!!) để không tốn một một tí gas nào thì chúng ta tổ chức lưu trữ dữ liệu một cách tập trung hơn. Tất cả zombie trong trò chơi được lưu trữ chung trong 1 mảng lớn. Và khi có thay đổi chủ sở hữu chỉ việc gán lại chủ sở hữu cho 2 phần tử trong mảng này. Và khi cần truy vấn tất cả các zombie của một chủ sở hữu thì ta gọi vòng for  duyệt qua mảng zombie chung và nhặt ra zombie của chủ sở hữu đó đưa lên view.

For Loops - vòng lặp

Cú pháp của vòng lặp for trong Solidity tương tự như JavaScript.

Hãy xem một ví dụ mà chúng ta muốn tạo một mảng các số chẵn:

function getEvens() pure external returns(uint[] memory) {
  uint[] memory evens = new uint[](5);
  // Keep track of the index in the new array:
  uint counter = 0;
  // Iterate 1 through 10 with a for loop:
  for (uint i = 1; i <= 10; i++) {
    // If `i` is even...
    if (i % 2 == 0) {
      // Add it to our array
      evens[counter] = i;
      // Increment counter to the next empty index in `evens`:
      counter++;
    }
  }
  return evens;
}
//Hàm này sẽ trả về một mảng có nội dung [2, 4, 6, 8, 10].

Thực hành luôn cho nhớ lâu bạn nhé

Nếu bạn chưa biết cách TẠO FILE, COMPILER và DEPLOY thì hãy xem lại trong bài giới thiệu nhé. Có hướng dẫn chi tiết ở đó.

BÀI TIẾP THEO: BÀI SỐ 34

HỌC TỪ ĐẦU: BÀI SỐ 1

Bài đăng phổ biến từ blog này

Bài giới thiệu: Tự học Solidity. Học lập trình web3. Lập trình Smart Contract các Blockchain

LỜI NÓI ĐẦU Mục đích của blog này để chia sẻ một cách đơn giản nhất để bạn có thể tự học lập trình web3 Solidity bằng tiếng Việt, tự học online ngôn ngữ lập trình Solidity để Code ra một Smart Contract trên blockchain của ETH. Khoá học này dành cho những lập trình viên Việt Nam nhưng không giỏi đọc các tài liệu bằng tiếng Anh. Đặc biệt, những bài học này sẽ không rườm rà các lý thuyết. Vậy nên những khái niệm như Blockchain là gì, Smart Contract là gì thì mời các bạn tự tra cứu Google :) ĐỐI TƯỢNG PHÙ HỢP Trên cơ sở là bạn cũng đã có kiến thức về các ngôn ngữ lập trình khác rồi, giờ có nhu cầu học thêm một ngôn ngữ mới. Bạn cần một website học lập trình web3 Solidity một cách hệ thống từ A đến Z và bài bản. Còn nếu bạn là một người mới tinh như trang giấy trắng về code, chưa biết tí gì về lập trình thì xin hãy quay lại đây sau. Hãy học một khoá lập trình căn bản trước nhé. THỰC HÀNH CODE Ở ĐÂU? Trong khoá tự học lập trình web3 Solidity này, chúng ta sử dụng trình soạn thảo online là

Bài 1: Tài liệu tự học Solidity. Contracts & Pragma. Hợp Đồng và phiên bản Pragma

Contracts và  Pragma Trong khoá học online miễn phí Tự học lập trình web3 - Tự học ngôn ngữ lập trình Solidity Những chú ý trước khi bắt đầu khoá học được trình bày tại  bài giới thiệu khoá học Summary for English Visiter pragma solidity >=0.5.0 <0.6.0; contract HelloWorld { } Thank you! 1. Contract Mã của Solidity được gói gọn trong các hợp đồng Contract. Hợp đồng là khối code cơ bản của các ứng dụng Ethereum - tất cả các biến và hàm đều thuộc một hợp đồng và đây sẽ là điểm khởi đầu của tất cả các dự án.  Một hợp đồng trống có tên HelloWorld sẽ trông như thế này: contract HelloWorld { } 2. Phiên bản Pragma Code solidity phải bắt đầu bằng "version pragma" - một khai báo về phiên bản của trình biên dịch Solidity mà mình sử dụng. Điều này là để ngăn chặn các sự cố với các phiên bản trình biên dịch trong tương lai có thể gây ra lỗi với đoạn code của bạn. Ví dụ muốn biên dịch từ 0.5.0 đến 0.6.0 thì  bạn khai báo trên cùng như sau:  pragma solidity >=0.5.0 <0.6.0;

Tự học ptkt Bitcoin. Kiến thức phân tích kỹ thuật trade coin từ A đến Z. Các trường phái ptkt coin

Tự học  Phân tích kỹ thuật trade coin từ A đến Z Tự học ptkt Bitcoin. Kiến thức phân tích kỹ thuật trade coin từ A đến Z . Các trường phái ptkt coin. 0. Lời nói đầu Phân tích giao dịch trong trade coin, trade chứng khoán... bao gồm 03 loại phân tích chính: Phân tích cơ bản, Phân tích kỹ thuật và Phân tích tâm lý. Như tiêu đề của bài viết này "Phân tích kỹ thuật Trade Coin từ A đến Z". Trong bài viết này tôi dựa trên những kiến thức thực chiến từ 2017 đến nay. Tự Học Trade Coin (Tuhocsolidity.com) sẽ giới thiệu đến bạn những kiến thức và bộ công cụ phân tích cần thiết từ cơ bản đến nâng cao để tự bạn có thể xây dựng cho mình một hệ thống giao dịch dành cho việc Trade Coin, Trade chứng khoán... hiệu quả nhất. Và bây giờ chúng ta bắt đầu tìm hiểu các khái niệm cơ bản trong trade coin từ A đến Z 1. Time Frame là gì? Khung thời gian là gì? Time Frame là khung thời gian thể hiện của biểu đồ giá. Có nhiều khung thời gian được sử dụng, phổ biến là 1 năm, 1 tháng, 1 tuần, 1 ngày, 4