Marktkapitalisierung: $2.8337T 0.60%
Volumen (24h): $136.9463B -23.72%
Angst- und Gier-Index:

28 - Furcht

  • Marktkapitalisierung: $2.8337T 0.60%
  • Volumen (24h): $136.9463B -23.72%
  • Angst- und Gier-Index:
  • Marktkapitalisierung: $2.8337T 0.60%
Kryptos
Themen
Cryptospedia
Nachricht
Cryptostopics
Videos
Top Cryptospedia

Sprache auswählen

Sprache auswählen

Währung wählen

Kryptos
Themen
Cryptospedia
Nachricht
Cryptostopics
Videos

Was ist eine Ansichtsfunktion und eine reine Funktion in Solidity und welche Auswirkungen haben sie auf das Gas?

View and pure functions in Solidity don’t modify state, enabling free, off-chain execution—ideal for reads and calculations without gas costs.

Nov 12, 2025 at 06:20 pm

Ansichtsfunktionen in Solidität verstehen

1. Eine Ansichtsfunktion in Solidity ist ein Funktionstyp, der verspricht, den Zustand der Blockchain nicht zu verändern. Es kann aus den Speichervariablen des Vertrags lesen, diese jedoch nicht ändern, keine Ereignisse ausgeben oder Funktionen aufrufen, die den Status ändern.

  1. Da diese Funktionen ihren Status nicht ändern, können sie lokal auf einem Ethereum-Knoten ausgeführt werden, ohne eine Transaktion an das Netzwerk zu senden. Dies bedeutet, dass Benutzer bei externen Anrufen keine Gasgebühren zahlen müssen.
  2. Das Schlüsselwort view muss explizit in der Funktionssignatur deklariert werden. Wenn es weggelassen wird und die Funktion versucht, den Status zu ändern, gibt der Compiler einen Fehler aus.
  3. Beispiele hierfür sind das Abrufen des Guthabens eines Benutzers, das Überprüfen von Berechtigungen in ERC-20-Tokens oder das Lesen von im Vertrag gespeicherten Konfigurationsparametern.
  4. Obwohl Ansichtsfunktionen für externe Aufrufer kostenlos sind, verbrauchen sie dennoch Rechenressourcen auf Knoten. Daher kann eine übermäßig komplexe Logik innerhalb einer Ansichtsfunktion bei einigen Anbietern zu Zeitüberschreitungen oder Ablehnungen führen.

Erforschung reiner Funktionen in Solidität

1. Eine reine Funktion geht einen Schritt weiter als eine Ansichtsfunktion, indem sie verspricht, keine Zustandsvariablen zu lesen oder zu schreiben. Es arbeitet ausschließlich mit den ihm übergebenen Eingabeparametern.

  1. Diese Funktionen werden typischerweise für mathematische Berechnungen, Kodierungs-/Dekodierungsvorgänge oder logische Prüfungen verwendet, die nicht von gespeicherten Daten abhängen.
  2. Das Schlüsselwort pure erzwingt diese Einschränkung zur Kompilierungszeit. Der Versuch, auch nur auf eine einzelne Statusvariable zuzugreifen, führt zu einem Kompilierungsfehler.
  3. Genau wie Ansichtsfunktionen fallen auch für reine Funktionen keine Gaskosten an, wenn sie extern aufgerufen werden, da sie keine Transaktion erfordern. Sie führen Off-Chain mit lokalen Knotenressourcen aus.
  4. Ein Beispiel wäre eine Funktion, die Zinseszinsen basierend auf Eingabeargumenten berechnet oder eine kryptografische Signatur validiert, ohne auf die Vertragsspeicherung zu verweisen.

Gasimplikationen nicht modifizierender Funktionen

1. Wenn eine Smart-Contract-Funktion als view oder pure markiert ist, generieren externe Aufrufe keine Transaktionen. Dadurch wird dem Anrufer kein Benzin in Rechnung gestellt.

  1. Wenn jedoch intern eine Ansicht oder eine reine Funktion von einer anderen Funktion innerhalb einer Transaktion aufgerufen wird, verbraucht deren Ausführung immer noch Gas. Die EVM muss jede Operation verarbeiten, unabhängig davon, ob Zustandsänderungen auftreten.
  2. Komplexe Berechnungen innerhalb solcher Funktionen – wie das Durchlaufen großer Arrays oder das Ausführen mehrerer arithmetischer Operationen – erhöhen die Gaskosten, wenn sie intern aufgerufen werden.
  3. Entwickler optimieren die Leistung häufig, indem sie die Berechnung in Ansichts-/reinen Funktionen minimieren, insbesondere wenn diese wahrscheinlich während Transaktionen zur Zustandsänderung aufgerufen werden.
  4. Die falsche Kennzeichnung einer Funktion als „Ansicht“ oder „rein“, wenn sie tatsächlich den Status ändert, führt zu Laufzeitausnahmen oder Bereitstellungsfehlern, wodurch möglicherweise Entwicklungszeit und Testnet-Gas verschwendet werden.

Häufige Fragen zu Ansichten und reinen Funktionen

F: Kann eine Ansichtsfunktion eine reine Funktion aufrufen? A: Ja, eine Ansichtsfunktion kann sicher eine reine Funktion aufrufen. Da reine Funktionen den Status nicht lesen oder ändern, sind sie vollständig mit den Einschränkungen von Ansichtsfunktionen kompatibel.

F: Was passiert, wenn ich versuche, eine Zustandsvariable innerhalb einer reinen Funktion zu ändern? A: Der Solidity-Compiler erzeugt einen Fehler. Reinen Funktionen ist es strengstens untersagt, auf Zustandsvariablen zuzugreifen, sei es zum Lesen oder Schreiben.

F: Verwenden View- und Pure-Funktionen Gas, wenn sie von web3.js oder ethers.js aufgerufen werden? A: Nein, der Aufruf dieser Funktionen über JavaScript-Bibliotheken erfordert keine Transaktion und verursacht daher keine Gaskosten. Die Ausführung erfolgt lokal auf dem verbundenen Ethereum-Knoten.

F: Gibt es einen Leistungsunterschied zwischen Ansicht und reinen Funktionen? A: Aus Sicht der Gaskosten und der Ausführungsgeschwindigkeit gibt es bei einem externen Aufruf keinen inhärenten Unterschied. Beide werden lokal ohne Statusänderungen ausgeführt. Intern hängt die Leistung eher von der Rechenkomplexität als vom verwendeten Modifikator ab.

Haftungsausschluss:info@kdj.com

Die bereitgestellten Informationen stellen keine Handelsberatung dar. kdj.com übernimmt keine Verantwortung für Investitionen, die auf der Grundlage der in diesem Artikel bereitgestellten Informationen getätigt werden. Kryptowährungen sind sehr volatil und es wird dringend empfohlen, nach gründlicher Recherche mit Vorsicht zu investieren!

Wenn Sie glauben, dass der auf dieser Website verwendete Inhalt Ihr Urheberrecht verletzt, kontaktieren Sie uns bitte umgehend (info@kdj.com) und wir werden ihn umgehend löschen.

Verwandtes Wissen

Wie führe ich eine kettenübergreifende Nachricht mit einem LayerZero-Vertrag aus?

Wie führe ich eine kettenübergreifende Nachricht mit einem LayerZero-Vertrag aus?

Jan 18,2026 at 01:19pm

Grundlegendes zur LayerZero-Architektur 1. LayerZero fungiert als leichtes, erlaubnisloses Interoperabilitätsprotokoll, das die Kommunikation zwischen...

Wie implementiert man EIP-712 für die sichere Signaturüberprüfung?

Wie implementiert man EIP-712 für die sichere Signaturüberprüfung?

Jan 20,2026 at 10:20pm

EIP-712-Übersicht und Hauptzweck 1. EIP-712 definiert einen Standard für typisiertes strukturiertes Daten-Hashing und Signieren in Ethereum-Anwendunge...

Wie kann ich mich für Airdrops qualifizieren, indem ich mit neuen Verträgen interagiere?

Wie kann ich mich für Airdrops qualifizieren, indem ich mit neuen Verträgen interagiere?

Jan 24,2026 at 09:00pm

Anforderungen an die Vertragsinteraktion verstehen 1. Die meisten Airdrop-Kampagnen erfordern eine direkte Interaktion mit Smart Contracts, die auf un...

Wie überwacht man einen Smart Contract auf Sicherheitswarnungen?

Wie überwacht man einen Smart Contract auf Sicherheitswarnungen?

Jan 21,2026 at 07:59am

On-Chain-Überwachungstools 1. Blockchain-Explorer wie Etherscan und Blockscout ermöglichen die Echtzeitprüfung von Vertragsbytecode, Transaktionsproto...

Wie kann ich einen Vertrag für automatisierte Zahlungen abschließen und finanzieren?

Wie kann ich einen Vertrag für automatisierte Zahlungen abschließen und finanzieren?

Jan 26,2026 at 08:59am

Grundlegendes zur Bereitstellung intelligenter Verträge 1. Entwickler müssen eine kompatible Blockchain-Plattform wie Ethereum, Polygon oder Arbitrum ...

Wie verwende ich OpenZeppelin-Verträge, um sichere dApps zu erstellen?

Wie verwende ich OpenZeppelin-Verträge, um sichere dApps zu erstellen?

Jan 18,2026 at 11:19am

Grundlegendes zu den OpenZeppelin-Vertragsgrundlagen 1. OpenZeppelin Contracts ist eine Bibliothek wiederverwendbarer, von der Community geprüfter Sma...

Wie führe ich eine kettenübergreifende Nachricht mit einem LayerZero-Vertrag aus?

Wie führe ich eine kettenübergreifende Nachricht mit einem LayerZero-Vertrag aus?

Jan 18,2026 at 01:19pm

Grundlegendes zur LayerZero-Architektur 1. LayerZero fungiert als leichtes, erlaubnisloses Interoperabilitätsprotokoll, das die Kommunikation zwischen...

Wie implementiert man EIP-712 für die sichere Signaturüberprüfung?

Wie implementiert man EIP-712 für die sichere Signaturüberprüfung?

Jan 20,2026 at 10:20pm

EIP-712-Übersicht und Hauptzweck 1. EIP-712 definiert einen Standard für typisiertes strukturiertes Daten-Hashing und Signieren in Ethereum-Anwendunge...

Wie kann ich mich für Airdrops qualifizieren, indem ich mit neuen Verträgen interagiere?

Wie kann ich mich für Airdrops qualifizieren, indem ich mit neuen Verträgen interagiere?

Jan 24,2026 at 09:00pm

Anforderungen an die Vertragsinteraktion verstehen 1. Die meisten Airdrop-Kampagnen erfordern eine direkte Interaktion mit Smart Contracts, die auf un...

Wie überwacht man einen Smart Contract auf Sicherheitswarnungen?

Wie überwacht man einen Smart Contract auf Sicherheitswarnungen?

Jan 21,2026 at 07:59am

On-Chain-Überwachungstools 1. Blockchain-Explorer wie Etherscan und Blockscout ermöglichen die Echtzeitprüfung von Vertragsbytecode, Transaktionsproto...

Wie kann ich einen Vertrag für automatisierte Zahlungen abschließen und finanzieren?

Wie kann ich einen Vertrag für automatisierte Zahlungen abschließen und finanzieren?

Jan 26,2026 at 08:59am

Grundlegendes zur Bereitstellung intelligenter Verträge 1. Entwickler müssen eine kompatible Blockchain-Plattform wie Ethereum, Polygon oder Arbitrum ...

Wie verwende ich OpenZeppelin-Verträge, um sichere dApps zu erstellen?

Wie verwende ich OpenZeppelin-Verträge, um sichere dApps zu erstellen?

Jan 18,2026 at 11:19am

Grundlegendes zu den OpenZeppelin-Vertragsgrundlagen 1. OpenZeppelin Contracts ist eine Bibliothek wiederverwendbarer, von der Community geprüfter Sma...

Alle Artikel ansehen

User not found or password invalid

Your input is correct