முக்கிய உள்ளடக்கத்திற்குச் செல்லவும்
Change page

ஸ்மார்ட் ஒப்பந்த மொழிகள்

பக்கம் கடைசியாகப் புதுப்பிக்கப்பட்டது: 26 பிப்ரவரி, 2026

Ethereum பற்றிய ஒரு சிறந்த அம்சம் என்னவென்றால், ஸ்மார்ட் ஒப்பந்தங்களை ஒப்பீட்டளவில் டெவலப்பர்களுக்கு எளிதான மொழிகளைப் பயன்படுத்தி நிரலாக்கம் செய்யலாம். உங்களுக்கு Python அல்லது ஏதேனும் சுருள்-அடைப்புக்குறி மொழியில் (curly-bracket language) (opens in a new tab) அனுபவம் இருந்தால், உங்களுக்குப் பரிச்சயமான தொடரியல் (syntax) கொண்ட ஒரு மொழியை நீங்கள் கண்டறியலாம்.

மிகவும் சுறுசுறுப்பான மற்றும் பராமரிக்கப்படும் இரண்டு மொழிகள்:

  • Solidity
  • Vyper

Solidity மற்றும் Vyper ஆகிய இரண்டிலும் ஒப்பந்தங்களை உருவாக்குவதற்கும் சோதிப்பதற்கும் Remix IDE ஒரு விரிவான மேம்பாட்டு சூழலை வழங்குகிறது. குறியீட்டை எழுதத் தொடங்க உலாவியில் உள்ள Remix IDE-ஐ முயற்சிக்கவும் (opens in a new tab).

அதிக அனுபவம் வாய்ந்த டெவலப்பர்கள் Ethereum Virtual Machine-க்கான இடைநிலை மொழியான Yul அல்லது Yul-இன் நீட்டிப்பான Yul+-ஐப் பயன்படுத்த விரும்பலாம்.

நீங்கள் ஆர்வமாக இருந்து, இன்னும் தீவிர மேம்பாட்டில் உள்ள புதிய மொழிகளைச் சோதிக்க உதவ விரும்பினால், தற்போது ஆரம்ப கட்டத்தில் உள்ள வளர்ந்து வரும் ஸ்மார்ட் ஒப்பந்த மொழியான Fe-ஐ நீங்கள் பரிசோதிக்கலாம்.

முன்நிபந்தனைகள்

நிரலாக்க மொழிகள், குறிப்பாக JavaScript அல்லது Python பற்றிய முன் அறிவு, ஸ்மார்ட் ஒப்பந்த மொழிகளில் உள்ள வேறுபாடுகளைப் புரிந்துகொள்ள உங்களுக்கு உதவும். மொழி ஒப்பீடுகளைப் பற்றி ஆழமாக ஆராய்வதற்கு முன், ஸ்மார்ட் ஒப்பந்தங்களை ஒரு கருத்தாகப் புரிந்துகொள்ளுமாறு நாங்கள் பரிந்துரைக்கிறோம். ஸ்மார்ட் ஒப்பந்தங்கள் அறிமுகம்.

Solidity

  • ஸ்மார்ட் ஒப்பந்தங்களைச் செயல்படுத்துவதற்கான பொருள் சார்ந்த (Object-oriented), உயர்நிலை மொழி.
  • C++ ஆல் மிகவும் ஆழமாக ஈர்க்கப்பட்ட சுருள்-அடைப்புக்குறி மொழி.
  • நிலையான தட்டச்சு (statically typed) செய்யப்பட்டது (ஒரு மாறியின் வகை தொகுக்கும் நேரத்தில் (compile time) அறியப்படுகிறது).
  • ஆதரிப்பவை:
    • மரபுரிமை (Inheritance) (நீங்கள் பிற ஒப்பந்தங்களை நீட்டிக்கலாம்).
    • நூலகங்கள் (Libraries) (வெவ்வேறு ஒப்பந்தங்களிலிருந்து நீங்கள் அழைக்கக்கூடிய மறுபயன்பாட்டு குறியீட்டை உருவாக்கலாம் - பிற பொருள் சார்ந்த நிரலாக்க மொழிகளில் உள்ள நிலையான வகுப்பில் உள்ள நிலையான செயல்பாடுகளைப் போல).
    • சிக்கலான பயனர் வரையறுக்கப்பட்ட வகைகள் (Complex user-defined types).

எடுத்துக்காட்டு ஒப்பந்தம்

1// SPDX-License-Identifier: GPL-3.0
2pragma solidity >= 0.7.0;
3
4contract Coin {
5 // "public" என்ற திறவுச்சொல் மாறிகளை
6 // மற்ற ஒப்பந்தங்களில் இருந்து அணுகக்கூடியதாக மாற்றுகிறது
7 address public minter;
8 mapping (address => uint) public balances;
9
10 // நிகழ்வுகள் (Events) வாடிக்கையாளர்களை குறிப்பிட்ட
11 // நீங்கள் அறிவிக்கும் ஒப்பந்த மாற்றங்களுக்கு எதிர்வினையாற்ற அனுமதிக்கின்றன
12 event Sent(address from, address to, uint amount);
13
14 // கட்டமைப்பாளர் (Constructor) குறியீடு ஒப்பந்தம்
15 // உருவாக்கப்படும் போது மட்டுமே இயங்கும்
16 constructor() {
17 minter = msg.sender;
18 }
19
20 // புதிதாக உருவாக்கப்பட்ட நாணயங்களின் ஒரு தொகையை ஒரு முகவரிக்கு அனுப்புகிறது
21 // ஒப்பந்தத்தை உருவாக்கியவரால் மட்டுமே அழைக்கப்பட முடியும்
22 function mint(address receiver, uint amount) public {
23 require(msg.sender == minter);
24 require(amount < 1e60);
25 balances[receiver] += amount;
26 }
27
28 // ஏற்கனவே உள்ள நாணயங்களின் ஒரு தொகையை
29 // எந்தவொரு அழைப்பாளரிடமிருந்தும் ஒரு முகவரிக்கு அனுப்புகிறது
30 function send(address receiver, uint amount) public {
31 require(amount <= balances[msg.sender], "Insufficient balance.");
32 balances[msg.sender] -= amount;
33 balances[receiver] += amount;
34 emit Sent(msg.sender, receiver, amount);
35 }
36}
அனைத்தையும் காட்டு

இந்த எடுத்துக்காட்டு Solidity ஒப்பந்தத் தொடரியல் எப்படி இருக்கும் என்பதைப் பற்றிய புரிதலை உங்களுக்கு வழங்கும். செயல்பாடுகள் மற்றும் மாறிகள் பற்றிய விரிவான விளக்கத்திற்கு, ஆவணங்களைப் பார்க்கவும் (opens in a new tab).

Vyper

  • பைத்தானிக் (Pythonic) நிரலாக்க மொழி
  • வலுவான தட்டச்சு (Strong typing)
  • சிறிய மற்றும் புரிந்துகொள்ளக்கூடிய கம்பைலர் குறியீடு
  • திறமையான பைட் குறியீடு (bytecode) உருவாக்கம்
  • ஒப்பந்தங்களை மிகவும் பாதுகாப்பானதாகவும் தணிக்கை செய்ய எளிதானதாகவும் மாற்றும் நோக்கத்துடன் Solidity-ஐ விட வேண்டுமென்றே குறைவான அம்சங்களைக் கொண்டுள்ளது. Vyper இவற்றை ஆதரிக்காது:
    • மாற்றிகள் (Modifiers)
    • மரபுரிமை (Inheritance)
    • இன்லைன் அசெம்பிளி (Inline assembly)
    • செயல்பாடு ஓவர்லோடிங் (Function overloading)
    • ஆபரேட்டர் ஓவர்லோடிங் (Operator overloading)
    • சுழல்நிலை அழைப்பு (Recursive calling)
    • முடிவிலி நீள சுழல்கள் (Infinite-length loops)
    • பைனரி நிலையான புள்ளிகள் (Binary fixed points)

மேலும் தகவலுக்கு, Vyper-இன் பகுத்தறிவைப் படிக்கவும் (opens in a new tab).

எடுத்துக்காட்டு

1# திறந்த ஏலம்
2
3# ஏலத்தின் அளவுருக்கள்
4# பயனாளி அதிக ஏலம் கேட்பவரிடமிருந்து பணத்தைப் பெறுகிறார்
5beneficiary: public(address)
6auctionStart: public(uint256)
7auctionEnd: public(uint256)
8
9# ஏலத்தின் தற்போதைய நிலை
10highestBidder: public(address)
11highestBid: public(uint256)
12
13# முடிவில் true என அமைக்கப்படும், எந்த மாற்றத்தையும் அனுமதிக்காது
14ended: public(bool)
15
16# திரும்பப் பெறும் முறையைப் பின்பற்ற, திரும்பப் பெறப்பட்ட ஏலங்களைக் கண்காணிக்கவும்
17pendingReturns: public(HashMap[address, uint256])
18
19# `_bidding_time` உடன் ஒரு எளிய ஏலத்தை உருவாக்கவும்
20# வினாடிகள் ஏல நேரத்தைக் கொண்டு
21# பயனாளி முகவரி `_beneficiary` சார்பாக.
22@external
23def __init__(_beneficiary: address, _bidding_time: uint256):
24 self.beneficiary = _beneficiary
25 self.auctionStart = block.timestamp
26 self.auctionEnd = self.auctionStart + _bidding_time
27
28# அனுப்பப்பட்ட மதிப்புடன் ஏலத்தில் ஏலம் கேட்கவும்
29# இந்த பரிவர்த்தனையுடன் சேர்த்து.
30# இந்த நிபந்தனையில் மட்டுமே மதிப்பு திரும்ப வழங்கப்படும், அதாவது
31# ஏலத்தில் வெற்றி பெறவில்லை என்றால்.
32@external
33@payable
34def bid():
35 # ஏலக் காலம் முடிந்துவிட்டதா என சரிபார்க்கவும்.
36 assert block.timestamp < self.auctionEnd
37 # ஏலத் தொகை போதுமான அளவு அதிகமாக உள்ளதா என சரிபார்க்கவும்
38 assert msg.value > self.highestBid
39 # முந்தைய அதிக ஏலதாரருக்கான பணத்தைத் திரும்பப் பெறுவதைக் கண்காணிக்கவும்
40 self.pendingReturns[self.highestBidder] += self.highestBid
41 # புதிய அதிக ஏலத்தைக் கண்காணிக்கவும்
42 self.highestBidder = msg.sender
43 self.highestBid = msg.value
44
45# முன்பு திரும்பப் பெறப்பட்ட ஏலத்தை திரும்பப் பெறவும். திரும்பப் பெறும் முறை
46# ஒரு பாதுகாப்பு சிக்கலைத் தவிர்க்க இங்கு பயன்படுத்தப்படுகிறது. பணத்தைத் திரும்பப் பெறுதல் நேரடியாக
47# bid() இன் ஒரு பகுதியாக அனுப்பப்பட்டால், ஒரு தீங்கிழைக்கும் ஏல ஒப்பந்தம்
48# அந்த பணத்தைத் திரும்பப் பெறுவதைத் தடுக்கலாம், இதனால் புதிய அதிக ஏலங்கள் வருவதைத் தடுக்கலாம்.
49@external
50def withdraw():
51 pending_amount: uint256 = self.pendingReturns[msg.sender]
52 self.pendingReturns[msg.sender] = 0
53 send(msg.sender, pending_amount)
54
55# ஏலத்தை முடித்து, அதிகபட்ச ஏலத் தொகையை
56# பயனாளிக்கு அனுப்பவும்.
57@external
58def endAuction():
59 # தொடர்பு கொள்ளும் செயல்பாடுகளை கட்டமைப்பது ஒரு நல்ல வழிகாட்டுதலாகும்
60 # மற்ற ஒப்பந்தங்களுடன் (அதாவது, அவை செயல்பாடுகளை அழைக்கின்றன அல்லது ஈதரை அனுப்புகின்றன)
61 # மூன்று கட்டங்களாக:
62 # 1. நிபந்தனைகளை சரிபார்த்தல்
63 # 2. செயல்களைச் செய்தல் (நிபந்தனைகளை மாற்றக்கூடும்)
64 # 3. மற்ற ஒப்பந்தங்களுடன் தொடர்பு கொள்ளுதல்
65 # இந்த கட்டங்கள் கலக்கப்பட்டால், மற்ற ஒப்பந்தம் அழைக்கலாம்
66 # தற்போதைய ஒப்பந்தத்திற்குள் மீண்டும் வந்து நிலையை மாற்றலாம் அல்லது
67 # விளைவுகளை (ஈதர் செலுத்துதல்) பல முறை செய்ய காரணமாகலாம்.
68 # உள்நாட்டில் அழைக்கப்படும் செயல்பாடுகள் வெளிப்புற
69 # ஒப்பந்தங்களுடன் தொடர்புகொண்டால், அவையும்
70 # வெளிப்புற ஒப்பந்தங்களுடனான தொடர்புகளாகவே கருதப்பட வேண்டும்.
71
72 # 1. நிபந்தனைகள்
73 # ஏல முடிவு நேரம் எட்டப்பட்டுள்ளதா என சரிபார்க்கவும்
74 assert block.timestamp >= self.auctionEnd
75 # இந்த செயல்பாடு ஏற்கனவே அழைக்கப்பட்டுள்ளதா என சரிபார்க்கவும்
76 assert not self.ended
77
78 # 2. விளைவுகள்
79 self.ended = True
80
81 # 3. தொடர்பு
82 send(self.beneficiary, self.highestBid)
அனைத்தையும் காட்டு

இந்த எடுத்துக்காட்டு Vyper ஒப்பந்தத் தொடரியல் எப்படி இருக்கும் என்பதைப் பற்றிய புரிதலை உங்களுக்கு வழங்கும். செயல்பாடுகள் மற்றும் மாறிகள் பற்றிய விரிவான விளக்கத்திற்கு, ஆவணங்களைப் பார்க்கவும் (opens in a new tab).

Yul மற்றும் Yul+

நீங்கள் Ethereum-க்கு புதியவராக இருந்து, ஸ்மார்ட் ஒப்பந்த மொழிகளில் இதுவரை எந்தக் குறியீட்டையும் எழுதவில்லை என்றால், Solidity அல்லது Vyper-உடன் தொடங்குமாறு பரிந்துரைக்கிறோம். ஸ்மார்ட் ஒப்பந்தப் பாதுகாப்புச் சிறந்த நடைமுறைகள் மற்றும் EVM-உடன் பணிபுரியும் விவரங்கள் உங்களுக்குப் பரிச்சயமான பிறகு மட்டுமே Yul அல்லது Yul+-ஐப் பார்க்கவும்.

Yul

  • Ethereum-க்கான இடைநிலை மொழி.
  • EVM மற்றும் Ethereum சுவையிலான WebAssembly-ஆன Ewasm (opens in a new tab)-ஐ ஆதரிக்கிறது, மேலும் இது இரு தளங்களுக்கும் பயன்படுத்தக்கூடிய பொதுவான வகுப்பியாக வடிவமைக்கப்பட்டுள்ளது.
  • EVM மற்றும் Ewasm தளங்கள் இரண்டிற்கும் சமமாகப் பயனளிக்கக்கூடிய உயர்மட்ட மேம்படுத்தல் நிலைகளுக்கான நல்ல இலக்கு.

Yul+

  • Yul-க்கான குறைந்த-நிலை, மிகவும் திறமையான நீட்டிப்பு.
  • ஆரம்பத்தில் ஒரு ஆப்டிமிஸ்டிக் ரோலப் (optimistic rollup) ஒப்பந்தத்திற்காக வடிவமைக்கப்பட்டது.
  • Yul+-ஐ Yul-க்கான ஒரு பரிசோதனை மேம்படுத்தல் முன்மொழிவாகக் கருதலாம், இது அதில் புதிய அம்சங்களைச் சேர்க்கிறது.

எடுத்துக்காட்டு ஒப்பந்தம்

பின்வரும் எளிய எடுத்துக்காட்டு ஒரு பவர் (power) செயல்பாட்டைச் செயல்படுத்துகிறது. இதை solc --strict-assembly --bin input.yul ஐப் பயன்படுத்தித் தொகுக்கலாம். இந்த எடுத்துக்காட்டு input.yul கோப்பில் சேமிக்கப்பட வேண்டும்.

1{
2 function power(base, exponent) -> result
3 {
4 switch exponent
5 case 0 { result := 1 }
6 case 1 { result := base }
7 default
8 {
9 result := power(mul(base, base), div(exponent, 2))
10 if mod(exponent, 2) { result := mul(base, result) }
11 }
12 }
13 let res := power(calldataload(0), calldataload(32))
14 mstore(0, res)
15 return(0, 32)
16}
அனைத்தையும் காட்டு

நீங்கள் ஏற்கனவே ஸ்மார்ட் ஒப்பந்தங்களில் நல்ல அனுபவம் பெற்றிருந்தால், Yul-இல் முழுமையான ERC20 செயலாக்கத்தை இங்கே (opens in a new tab) காணலாம்.

Fe

  • Ethereum Virtual Machine (EVM)-க்கான நிலையான தட்டச்சு செய்யப்பட்ட மொழி.
  • Python மற்றும் Rust-ஆல் ஈர்க்கப்பட்டது.
  • Ethereum சுற்றுச்சூழல் அமைப்புக்குப் புதிய டெவலப்பர்களுக்கும் கூட -- கற்றுக்கொள்ள எளிதாக இருக்க வேண்டும் என்பதை நோக்கமாகக் கொண்டுள்ளது.
  • Fe மேம்பாடு இன்னும் ஆரம்ப கட்டத்தில் உள்ளது, இந்த மொழி ஜனவரி 2021 இல் அதன் ஆல்பா வெளியீட்டைக் கொண்டிருந்தது.

எடுத்துக்காட்டு ஒப்பந்தம்

பின்வருவது Fe-இல் செயல்படுத்தப்பட்ட ஒரு எளிய ஒப்பந்தமாகும்.

1type BookMsg = bytes[100]
2
3contract GuestBook:
4 pub guest_book: map<address, BookMsg>
5
6 event Signed:
7 book_msg: BookMsg
8
9 pub def sign(book_msg: BookMsg):
10 self.guest_book[msg.sender] = book_msg
11
12 emit Signed(book_msg=book_msg)
13
14 pub def get_msg(addr: address) -> BookMsg:
15 return self.guest_book[addr].to_mem()
16
அனைத்தையும் காட்டு

எப்படித் தேர்ந்தெடுப்பது

வேறு எந்த நிரலாக்க மொழியையும் போலவே, இது பெரும்பாலும் சரியான வேலைக்குச் சரியான கருவியைத் தேர்ந்தெடுப்பது மற்றும் தனிப்பட்ட விருப்பங்களைப் பொறுத்தது.

நீங்கள் இதுவரை எந்த மொழியையும் முயற்சிக்கவில்லை என்றால் கருத்தில் கொள்ள வேண்டிய சில விஷயங்கள் இங்கே:

Solidity-இன் சிறப்பம்சங்கள் என்ன?

  • நீங்கள் ஒரு தொடக்கக்காரராக இருந்தால், பல பயிற்சிகள் மற்றும் கற்றல் கருவிகள் உள்ளன. குறியீட்டு முறை மூலம் கற்றுக்கொள்ளுங்கள் பிரிவில் அதைப் பற்றி மேலும் பார்க்கவும்.
  • நல்ல டெவலப்பர் கருவிகள் கிடைக்கின்றன.
  • Solidity ஒரு பெரிய டெவலப்பர் சமூகத்தைக் கொண்டுள்ளது, அதாவது உங்கள் கேள்விகளுக்கான பதில்களை நீங்கள் மிக விரைவாகக் கண்டறியலாம்.

Vyper-இன் சிறப்பம்சங்கள் என்ன?

  • ஸ்மார்ட் ஒப்பந்தங்களை எழுத விரும்பும் Python டெவலப்பர்கள் தொடங்குவதற்கு இது ஒரு சிறந்த வழியாகும்.
  • Vyper குறைந்த எண்ணிக்கையிலான அம்சங்களைக் கொண்டுள்ளது, இது யோசனைகளை விரைவாக முன்மாதிரி (prototyping) செய்வதற்குச் சிறந்ததாக அமைகிறது.
  • Vyper தணிக்கை செய்ய எளிதானதாகவும் அதிகபட்சமாக மனிதர்கள் படிக்கக்கூடியதாகவும் இருக்க வேண்டும் என்பதை நோக்கமாகக் கொண்டுள்ளது.

Yul மற்றும் Yul+-இன் சிறப்பம்சங்கள் என்ன?

  • எளிமையான மற்றும் செயல்பாட்டு குறைந்த-நிலை மொழி.
  • மூல EVM-க்கு மிக நெருக்கமாகச் செல்ல அனுமதிக்கிறது, இது உங்கள் ஒப்பந்தங்களின் எரிவாயு (gas) பயன்பாட்டை மேம்படுத்த உதவும்.

மொழி ஒப்பீடுகள்

அடிப்படைத் தொடரியல், ஒப்பந்த வாழ்க்கைச் சுழற்சி, இடைமுகங்கள், ஆபரேட்டர்கள், தரவு கட்டமைப்புகள், செயல்பாடுகள், கட்டுப்பாட்டு ஓட்டம் மற்றும் பலவற்றின் ஒப்பீடுகளுக்கு, Auditless-இன் இந்தச் சீட் ஷீட்டைப் (cheatsheet) (opens in a new tab) பார்க்கவும்.

மேலும் படிக்க

இந்தக் கட்டுரை பயனுள்ளதாக இருந்ததா?