Smart-Contract-Sprachen
Letzte Aktualisierung der Seite: 26. Februar 2026
Ein großartiger Aspekt von Ethereum ist, dass Smart Contracts mit relativ entwicklerfreundlichen Sprachen programmiert werden können. Wenn Sie Erfahrung mit Python oder einer anderen Programmiersprache mit geschweiften Klammern (opens in a new tab) haben, werden Sie eine Sprache mit vertrauter Syntax finden.
Die beiden aktivsten und am besten gepflegten Sprachen sind:
- Solidity
- Vyper
Die Remix IDE bietet eine umfassende Entwicklungsumgebung zum Erstellen und Testen von Verträgen in Solidity und Vyper. Probieren Sie die browserbasierte Remix IDE aus (opens in a new tab), um mit dem Programmieren zu beginnen.
Erfahrenere Entwickler möchten vielleicht auch Yul verwenden, eine Zwischensprache für die Ethereum Virtual Machine, oder Yul+, eine Erweiterung von Yul.
Wenn Sie neugierig sind und dabei helfen möchten, neue Sprachen zu testen, die sich noch in der intensiven Entwicklung befinden, können Sie mit Fe experimentieren, einer aufstrebenden Smart-Contract-Sprache, die noch in den Kinderschuhen steckt.
Voraussetzungen
Vorkenntnisse in Programmiersprachen, insbesondere in JavaScript oder Python, können Ihnen helfen, die Unterschiede zwischen Smart-Contract-Sprachen zu verstehen. Wir empfehlen Ihnen außerdem, Smart Contracts als Konzept zu verstehen, bevor Sie sich zu tief in die Sprachvergleiche einarbeiten. Einführung in Smart Contracts.
Solidity
- Objektorientierte Hochsprache zur Implementierung von Smart Contracts.
- Sprache mit geschweiften Klammern, die am stärksten von C++ beeinflusst wurde.
- Statisch typisiert (der Typ einer Variablen ist zur Kompilierzeit bekannt).
- Unterstützt:
- Vererbung (Sie können andere Verträge erweitern).
- Bibliotheken (Sie können wiederverwendbaren Code erstellen, den Sie aus verschiedenen Verträgen aufrufen können – wie statische Funktionen in einer statischen Klasse in anderen objektorientierten Programmiersprachen).
- Komplexe benutzerdefinierte Typen.
Wichtige Links
- Dokumentation (opens in a new tab)
- Solidity-Sprachportal (opens in a new tab)
- Solidity by Example (opens in a new tab)
- GitHub (opens in a new tab)
- Solidity Gitter-Chatroom (opens in a new tab) überbrückt zum Solidity Matrix-Chatroom (opens in a new tab)
- Spickzettel (Cheat Sheet) (opens in a new tab)
- Solidity-Blog (opens in a new tab)
- Solidity auf Twitter (opens in a new tab)
Beispielvertrag
1// SPDX-License-Identifier: GPL-3.02pragma solidity >= 0.7.0;34contract Coin {5 // Das Schlüsselwort "public" macht Variablen6 // von anderen Verträgen aus zugänglich7 address public minter;8 mapping (address => uint) public balances;910 // Ereignisse ermöglichen es Clients, auf bestimmte11 // von Ihnen deklarierte Vertragsänderungen zu reagieren12 event Sent(address from, address to, uint amount);1314 // Konstruktor-Code wird nur ausgeführt, wenn der Vertrag15 // erstellt wird16 constructor() {17 minter = msg.sender;18 }1920 // Sendet eine Menge neu erstellter Coins an eine Adresse21 // Kann nur vom Vertragsersteller aufgerufen werden22 function mint(address receiver, uint amount) public {23 require(msg.sender == minter);24 require(amount < 1e60);25 balances[receiver] += amount;26 }2728 // Sendet eine Menge existierender Coins29 // von einem beliebigen Aufrufer an eine Adresse30 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}Alle anzeigenDieses Beispiel soll Ihnen ein Gefühl dafür geben, wie die Syntax von Solidity-Verträgen aussieht. Für eine detailliertere Beschreibung der Funktionen und Variablen siehe die Dokumentation (opens in a new tab).
Vyper
- Pythonische Programmiersprache
- Strenge Typisierung
- Kleiner und verständlicher Compiler-Code
- Effiziente Bytecode-Generierung
- Hat absichtlich weniger Funktionen als Solidity mit dem Ziel, Verträge sicherer und einfacher zu prüfen (auditieren) zu machen. Vyper unterstützt Folgendes nicht:
- Modifikatoren (Modifiers)
- Vererbung
- Inline-Assembly
- Funktionsüberladung
- Operatorüberladung
- Rekursive Aufrufe
- Endlosschleifen
- Binäre Festkommazahlen
Für weitere Informationen lesen Sie die Grundprinzipien von Vyper (opens in a new tab).
Wichtige Links
- Dokumentation (opens in a new tab)
- Vyper by Example (opens in a new tab)
- Mehr Vyper by Example (opens in a new tab)
- GitHub (opens in a new tab)
- Vyper-Community Discord-Chat (opens in a new tab)
- Spickzettel (Cheat Sheet) (opens in a new tab)
- Frameworks und Tools zur Smart-Contract-Entwicklung für Vyper
- VyperPunk – lernen Sie, Vyper Smart Contracts zu sichern und zu hacken (opens in a new tab)
- Vyper Hub für die Entwicklung (opens in a new tab)
- Vyper Greatest Hits Smart-Contract-Beispiele (opens in a new tab)
- Awesome Vyper – kuratierte Ressourcen (opens in a new tab)
Beispiel
1# Offene Auktion23# Auktionsparameter4# Begünstigter erhält Geld vom Höchstbietenden5beneficiary: public(address)6auctionStart: public(uint256)7auctionEnd: public(uint256)89# Aktueller Status der Auktion10highestBidder: public(address)11highestBid: public(uint256)1213# Wird am Ende auf true gesetzt, verbietet jegliche Änderung14ended: public(bool)1516# Rückerstattete Gebote nachverfolgen, damit wir dem Auszahlungsmuster folgen können17pendingReturns: public(HashMap[address, uint256])1819# Erstelle eine einfache Auktion mit `_bidding_time`20# Sekunden Bietzeit im Namen der21# Begünstigten-Adresse `_beneficiary`.22@external23def __init__(_beneficiary: address, _bidding_time: uint256):24 self.beneficiary = _beneficiary25 self.auctionStart = block.timestamp26 self.auctionEnd = self.auctionStart + _bidding_time2728# Biete bei der Auktion mit dem gesendeten Wert29# zusammen mit dieser Transaktion.30# Der Wert wird nur zurückerstattet, wenn die31# Auktion nicht gewonnen wird.32@external33@payable34def bid():35 # Prüfe, ob die Bietzeit abgelaufen ist.36 assert block.timestamp < self.auctionEnd37 # Prüfe, ob das Gebot hoch genug ist38 assert msg.value > self.highestBid39 # Verfolge die Rückerstattung für den vorherigen Höchstbietenden40 self.pendingReturns[self.highestBidder] += self.highestBid41 # Verfolge neues Höchstgebot42 self.highestBidder = msg.sender43 self.highestBid = msg.value4445# Ein zuvor zurückerstattetes Gebot abheben. Das Auszahlungsmuster wird46# hier verwendet, um ein Sicherheitsproblem zu vermeiden. Wenn Rückerstattungen direkt47# als Teil von bid() gesendet würden, könnte ein bösartiger Biet-Vertrag48# diese Rückerstattungen blockieren und somit das Eingehen neuer, höherer Gebote verhindern.49@external50def withdraw():51 pending_amount: uint256 = self.pendingReturns[msg.sender]52 self.pendingReturns[msg.sender] = 053 send(msg.sender, pending_amount)5455# Beende die Auktion und sende das Höchstgebot56# an den Begünstigten.57@external58def endAuction():59 # Es ist eine gute Richtlinie, Funktionen, die mit60 # anderen Verträgen interagieren (d.h. sie rufen Funktionen auf oder senden Ether),61 # in drei Phasen zu strukturieren:62 # 1. Bedingungen prüfen63 # 2. Aktionen ausführen (möglicherweise Bedingungen ändern)64 # 3. Interaktion mit anderen Verträgen65 # Wenn diese Phasen vermischt werden, könnte der andere Vertrag66 # in den aktuellen Vertrag zurückrufen und den Zustand ändern oder bewirken,67 # dass Effekte (Ether-Auszahlung) mehrfach ausgeführt werden.68 # Wenn intern aufgerufene Funktionen Interaktionen mit externen69 # Verträgen beinhalten, müssen sie ebenfalls als Interaktion mit70 # externen Verträgen betrachtet werden.7172 # 1. Bedingungen73 # Prüfe, ob die Endzeit der Auktion erreicht wurde74 assert block.timestamp >= self.auctionEnd75 # Prüfe, ob diese Funktion bereits aufgerufen wurde76 assert not self.ended7778 # 2. Effekte79 self.ended = True8081 # 3. Interaktion82 send(self.beneficiary, self.highestBid)Alle anzeigenDieses Beispiel soll Ihnen ein Gefühl dafür geben, wie die Syntax von Vyper-Verträgen aussieht. Für eine detailliertere Beschreibung der Funktionen und Variablen siehe die Dokumentation (opens in a new tab).
Yul und Yul+
Wenn Sie neu bei Ethereum sind und noch nicht mit Smart-Contract-Sprachen programmiert haben, empfehlen wir Ihnen, mit Solidity oder Vyper zu beginnen. Beschäftigen Sie sich erst mit Yul oder Yul+, wenn Sie mit den Best Practices für die Sicherheit von Smart Contracts und den Besonderheiten der Arbeit mit der EVM vertraut sind.
Yul
- Zwischensprache für Ethereum.
- Unterstützt die EVM und Ewasm (opens in a new tab), eine Ethereum-spezifische WebAssembly, und ist als nutzbarer gemeinsamer Nenner beider Plattformen konzipiert.
- Gutes Ziel für High-Level-Optimierungsstufen, von denen sowohl EVM- als auch Ewasm-Plattformen gleichermaßen profitieren können.
Yul+
- Eine Low-Level-, hocheffiziente Erweiterung von Yul.
- Ursprünglich für einen Optimistic Rollup-Vertrag entwickelt.
- Yul+ kann als experimenteller Upgrade-Vorschlag für Yul betrachtet werden, der neue Funktionen hinzufügt.
Wichtige Links
- Yul-Dokumentation (opens in a new tab)
- Yul+-Dokumentation (opens in a new tab)
- Yul+-Einführungsbeitrag (opens in a new tab)
Beispielvertrag
Das folgende einfache Beispiel implementiert eine Potenzfunktion. Es kann mit solc --strict-assembly --bin input.yul kompiliert werden. Das Beispiel sollte in der Datei input.yul gespeichert werden.
1{2 function power(base, exponent) -> result3 {4 switch exponent5 case 0 { result := 1 }6 case 1 { result := base }7 default8 {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}Alle anzeigenWenn Sie bereits viel Erfahrung mit Smart Contracts haben, finden Sie hier (opens in a new tab) eine vollständige ERC20-Implementierung in Yul.
Fe
- Statisch typisierte Sprache für die Ethereum Virtual Machine (EVM).
- Inspiriert von Python und Rust.
- Zielt darauf ab, leicht erlernbar zu sein – auch für Entwickler, die neu im Ethereum-Ökosystem sind.
- Die Entwicklung von Fe befindet sich noch in einem frühen Stadium, die Sprache hatte ihre Alpha-Veröffentlichung im Januar 2021.
Wichtige Links
- GitHub (opens in a new tab)
- Fe-Ankündigung (opens in a new tab)
- Fe 2021 Roadmap (opens in a new tab)
- Fe Discord-Chat (opens in a new tab)
- Fe auf Twitter (opens in a new tab)
Beispielvertrag
Das Folgende ist ein einfacher Vertrag, der in Fe implementiert ist.
1type BookMsg = bytes[100]23contract GuestBook:4 pub guest_book: map<address, BookMsg>56 event Signed:7 book_msg: BookMsg89 pub def sign(book_msg: BookMsg):10 self.guest_book[msg.sender] = book_msg1112 emit Signed(book_msg=book_msg)1314 pub def get_msg(addr: address) -> BookMsg:15 return self.guest_book[addr].to_mem()16Alle anzeigenWie man sich entscheidet
Wie bei jeder anderen Programmiersprache geht es meistens darum, das richtige Werkzeug für die richtige Aufgabe zu wählen, sowie um persönliche Vorlieben.
Hier sind ein paar Dinge, die Sie beachten sollten, wenn Sie noch keine der Sprachen ausprobiert haben:
Was ist großartig an Solidity?
- Wenn Sie Anfänger sind, gibt es viele Tutorials und Lernwerkzeuge. Mehr dazu finden Sie im Abschnitt Lernen durch Programmieren.
- Gute Entwickler-Tools verfügbar.
- Solidity hat eine große Entwickler-Community, was bedeutet, dass Sie höchstwahrscheinlich recht schnell Antworten auf Ihre Fragen finden werden.
Was ist großartig an Vyper?
- Großartiger Einstieg für Python-Entwickler, die Smart Contracts schreiben möchten.
- Vyper hat eine geringere Anzahl von Funktionen, was es ideal für das schnelle Prototyping von Ideen macht.
- Vyper zielt darauf ab, leicht zu prüfen (auditieren) und maximal menschenlesbar zu sein.
Was ist großartig an Yul und Yul+?
- Vereinfachte und funktionale Low-Level-Sprache.
- Ermöglicht es, viel näher an die rohe EVM heranzukommen, was helfen kann, den Gasverbrauch Ihrer Verträge zu optimieren.
Sprachvergleiche
Für Vergleiche der grundlegenden Syntax, des Vertragslebenszyklus, der Schnittstellen, Operatoren, Datenstrukturen, Funktionen, des Kontrollflusses und mehr, schauen Sie sich diesen Spickzettel von Auditless (opens in a new tab) an.