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

Bài 10: Tự học solidity cơ bản. Hàm băm Keccak256 và Typecasting - ép kiểu dữ liệu trong ngôn ngữ Solidity

Keccak256 & Typecasting

Hàm băm và ép kiểu dữ liệu trong ngôn ngữ Solidity. 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.

Summary for English Visiter//6e91ec6b618bb462a4a6ee5aa2cb0e9cf30f7a052bb467b0ba58b8748c00d2e5
keccak256(abi.encodePacked("aaaab"));
//b1f078126895a1424524de5321b339ab00408010b7cf0e6ed451514981e58aa9
keccak256(abi.encodePacked("aaaac"));int8 a = 5;
uint b = 6;
uint8 c = a * uint8(b);Thank you!

Hàm băm Keccak256

Nhiệm vụ bài học này là chúng ta viết một hàm _generateRandomDna trả về một uint ngẫu nhiên. Làm thế nào chúng ta có thể thực hiện điều này?

Ethereum có tích hợp hàm băm keccak256, đây là một phiên bản của SHA3. Một hàm băm về cơ bản ánh xạ đầu vào thành một số thập lục phân 256 bit ngẫu nhiên. Một thay đổi nhỏ trong đầu vào sẽ gây ra sự thay đổi lớn trong hàm băm.

Nó hữu ích cho nhiều mục đích trong Ethereum, nhưng hiện tại trong bài học này chúng ta sẽ sử dụng nó để tạo chuỗi số ngẫu nhiên.

Rất quan trọng bạn phải ghi nhớ: Keccak256 có một tham số duy nhất kiểu byte. Điều này có nghĩa là chúng ta phải "đóng gói" tham số thành byte trước khi gọi keccak256:

Ví dụ:

//6e91ec6b618bb462a4a6ee5aa2cb0e9cf30f7a052bb467b0ba58b8748c00d2e5
keccak256(abi.encodePacked("aaaab"));
//b1f078126895a1424524de5321b339ab00408010b7cf0e6ed451514981e58aa9
keccak256(abi.encodePacked("aaaac"));

Như bạn thấy, các giá trị trả về hoàn toàn khác nhau mặc dù chỉ thay đổi 1 ký tự trong đầu vào.

Lưu ý: Việc tạo số ngẫu nhiên an toàn trong blockchain là một vấn đề rất khó khăn. Phương pháp của chúng tôi ở đây là không an toàn, nhưng vì trong phạm vi bài học này như thê là đủ :)

Typecasting - ép kiểu 

Đôi khi bạn cần chuyển đổi giữa các kiểu dữ liệu. Lấy ví dụ sau:

int8 a = 5;
uint b = 6;
// nhu nay se gay ra loi:
uint8 c = a * b;
// muon thong loi thi phai ep kieu nhu nay:
uint8 c = a * uint8(b);

Trong phần trên, a * b trả về một uint, nhưng chúng ta đang cố gắng lưu trữ nó dưới dạng uint8, điều này có thể gây ra các vấn đề tiềm ẩn. Bằng cách truyền nó dưới dạng uint8, nó sẽ hoạt động và trình biên dịch sẽ không gặp lỗi.

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

Thực hành viết hàm tạo số ngẫu nhiên sử dụng hàm băm keccak256 và ép kiểu dữ liệu về uint. Code vào trong file  hocweb3.sol.
Sau khi DEPLOY hãy chạy thử các hàm public, và xem kết quả.

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Ố 11

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

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

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...

Tung Tung Sahur Game

Tung Sahur - Game Trí Tuệ Hay Nhất iOS - Tải miễn phí - Không quảng cáo Tải an toàn từ App Store https://apps.apple.com/app/tung-tung-sahur-game/id6677010948 ▶ Chỉ 1% phá đảo được Tung Tung Sahur Game. Bạn có nằm trong số đó? ▶ 99 người thất bại, chỉ 1 người tới đích! Chơi ngay nào! ▶ Tung Tung Sahur: Dễ chơi, khó đua top BXH. Tải an toàn từ App Store https://apps.apple.com/app/tung-tung-sahur-game/id6677010948 ▶ Chỉ 1% phá đảo được Tung Tung Sahur Game. Bạn có nằm trong số đó? ▶ Xây hay rơi – từng tấm ván đều có giá trị. ▶ Sống lại tuổi thơ trong thử thách phản xạ sinh tồn cực chất. ▷ Tung Tung Tung Sahur Game đã trở lại trong một tựa game platformer phong cách retro đầy kịch tính — một hành trình sinh tồn hoang dã với phản xạ chuẩn xác và hỗn loạn xây cầu nghẹt thở. ▷ Hãy dẫn dắt người gỗ dũng cảm vượt qua vực thẳm chết người — từng tấm ván một. ▷ Đồng hành cùng chú chim thông minh – kẻ nhìn thấy điều bạn không thể, và cứu bạn khi tất cả tưởng như đã kết thúc. ▷ Đối đầu với Bombardin...

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 Đầu tiên: Bạn hãy tải game  Xếp Hình Cổ Điển  này trên App Store như một ví dụ sử dụng code Solidity vào làm thực tế. Các ví dụ trong các bài học sau này cũng hay lấy trong các đoạn code game này. Link App Store game  Xếp Hình Cổ Điển https://apps.apple.com/vn/app/id1223275422 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ề ...


“instagram”“youtube” “twitter”