ความเป็นปึกแผ่น - การถ่ายทอดทางพันธุกรรม

การสืบทอดเป็นวิธีการขยายการทำงานของสัญญา Solidity รองรับการสืบทอดทั้งแบบเดี่ยวและแบบหลายรายการ ต่อไปนี้เป็นไฮไลต์สำคัญ

  • สัญญาที่ได้รับสามารถเข้าถึงสมาชิกที่ไม่ใช่ส่วนตัวทั้งหมดรวมถึงวิธีการภายในและตัวแปรของรัฐ แต่ไม่อนุญาตให้ใช้สิ่งนี้

  • อนุญาตให้ใช้การแทนที่ฟังก์ชันได้หากลายเซ็นฟังก์ชันยังคงเหมือนเดิม ในกรณีที่พารามิเตอร์เอาต์พุตแตกต่างกันการคอมไพล์จะล้มเหลว

  • เราสามารถเรียกฟังก์ชันของ super contract โดยใช้ super keyword หรือใช้ชื่อ super contract

  • ในกรณีของการสืบทอดหลายรายการการเรียกใช้ฟังก์ชันโดยใช้ super จะให้ความสำคัญกับสัญญาที่ได้รับส่วนใหญ่

ตัวอย่าง

pragma solidity ^0.5.0;

contract C {
   //private state variable
   uint private data;
   
   //public state variable
   uint public info;

   //constructor
   constructor() public {
      info = 10;
   }
   //private function
   function increment(uint a) private pure returns(uint) { return a + 1; }
   
   //public function
   function updateData(uint a) public { data = a; }
   function getData() public view returns(uint) { return data; }
   function compute(uint a, uint b) internal pure returns (uint) { return a + b; }
}
//Derived Contract
contract E is C {
   uint private result;
   C private c;
   constructor() public {
      c = new C();
   }  
   function getComputedResult() public {      
      result = compute(3, 5); 
   }
   function getResult() public view returns(uint) { return result; }
   function getData() public view returns(uint) { return c.info(); }
}

รันโปรแกรมข้างต้นโดยใช้ขั้นตอนที่ให้ไว้ในบทSolidity First Application เรียกใช้วิธีการต่างๆของสัญญา สำหรับ E.getComputedResult () ตามด้วย E.getResult () แสดง -

เอาต์พุต

0: uint256: 8