Marktkapitalisierung: $3.4612T -2.97%
Volumen (24h): $176.5595B 0.89%
Angst- und Gier-Index:

31 - Furcht

  • Marktkapitalisierung: $3.4612T -2.97%
  • Volumen (24h): $176.5595B 0.89%
  • Angst- und Gier-Index:
  • Marktkapitalisierung: $3.4612T -2.97%
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

Was ist ein Denial-of-Service-Angriff (DoS) in einem Smart Contract und was sind seine häufigsten Formen?

Was ist ein Denial-of-Service-Angriff (DoS) in einem Smart Contract und was sind seine häufigsten Formen?

Nov 10,2025 at 05:20am

Denial of Service in Smart Contracts verstehen 1. Ein Denial-of-Service-Angriff (DoS) im Zusammenhang mit Smart Contracts bezieht sich auf ein Szenari...

Wofür wird eine kryptografische Nonce beim Signieren von Transaktionen verwendet?

Wofür wird eine kryptografische Nonce beim Signieren von Transaktionen verwendet?

Nov 11,2025 at 05:59am

Kryptografische Nonces in Blockchain-Transaktionen verstehen 1. Eine kryptografische Nonce ist eine Zufalls- oder Pseudozufallszahl, die nur einmal im...

Wie funktioniert die Vererbung in Solidity-Smart-Verträgen?

Wie funktioniert die Vererbung in Solidity-Smart-Verträgen?

Nov 11,2025 at 10:40pm

Vererbung in Solidität: Aufbau modularer Smart Contracts 1. Durch die Vererbung in Solidity kann ein Vertrag die Eigenschaften und Funktionen eines an...

Was ist der Unterschied zwischen einem Externally Owned Account (EOA) und einem Vertragskonto?

Was ist der Unterschied zwischen einem Externally Owned Account (EOA) und einem Vertragskonto?

Nov 13,2025 at 04:00am

Erläuterungen zu Externally Owned Accounts (EOA) 1. Ein extern geführtes Konto wird direkt durch einen privaten Schlüssel kontrolliert, was bedeutet, ...

Was ist der NFT-Lizenzstandard ERC-2981 und wie funktioniert er?

Was ist der NFT-Lizenzstandard ERC-2981 und wie funktioniert er?

Nov 13,2025 at 05:39am

Den NFT-Lizenzstandard ERC-2981 verstehen 1. Der ERC-2981-Standard ist ein vorgeschlagener Ethereum-Request for Comment, der einen Lizenzgebührenmecha...

Was ist ein Minimal-Proxy-Vertrag (EIP-1167) und wie spart er bei der Bereitstellung Gas?

Was ist ein Minimal-Proxy-Vertrag (EIP-1167) und wie spart er bei der Bereitstellung Gas?

Nov 12,2025 at 11:39am

Was ist ein Minimal-Proxy-Vertrag (EIP-1167)? 1. Ein Minimal-Proxy-Vertrag, standardisiert im Ethereum Improvement Proposal (EIP) 1167, ist ein einfac...

Was ist ein Denial-of-Service-Angriff (DoS) in einem Smart Contract und was sind seine häufigsten Formen?

Was ist ein Denial-of-Service-Angriff (DoS) in einem Smart Contract und was sind seine häufigsten Formen?

Nov 10,2025 at 05:20am

Denial of Service in Smart Contracts verstehen 1. Ein Denial-of-Service-Angriff (DoS) im Zusammenhang mit Smart Contracts bezieht sich auf ein Szenari...

Wofür wird eine kryptografische Nonce beim Signieren von Transaktionen verwendet?

Wofür wird eine kryptografische Nonce beim Signieren von Transaktionen verwendet?

Nov 11,2025 at 05:59am

Kryptografische Nonces in Blockchain-Transaktionen verstehen 1. Eine kryptografische Nonce ist eine Zufalls- oder Pseudozufallszahl, die nur einmal im...

Wie funktioniert die Vererbung in Solidity-Smart-Verträgen?

Wie funktioniert die Vererbung in Solidity-Smart-Verträgen?

Nov 11,2025 at 10:40pm

Vererbung in Solidität: Aufbau modularer Smart Contracts 1. Durch die Vererbung in Solidity kann ein Vertrag die Eigenschaften und Funktionen eines an...

Was ist der Unterschied zwischen einem Externally Owned Account (EOA) und einem Vertragskonto?

Was ist der Unterschied zwischen einem Externally Owned Account (EOA) und einem Vertragskonto?

Nov 13,2025 at 04:00am

Erläuterungen zu Externally Owned Accounts (EOA) 1. Ein extern geführtes Konto wird direkt durch einen privaten Schlüssel kontrolliert, was bedeutet, ...

Was ist der NFT-Lizenzstandard ERC-2981 und wie funktioniert er?

Was ist der NFT-Lizenzstandard ERC-2981 und wie funktioniert er?

Nov 13,2025 at 05:39am

Den NFT-Lizenzstandard ERC-2981 verstehen 1. Der ERC-2981-Standard ist ein vorgeschlagener Ethereum-Request for Comment, der einen Lizenzgebührenmecha...

Was ist ein Minimal-Proxy-Vertrag (EIP-1167) und wie spart er bei der Bereitstellung Gas?

Was ist ein Minimal-Proxy-Vertrag (EIP-1167) und wie spart er bei der Bereitstellung Gas?

Nov 12,2025 at 11:39am

Was ist ein Minimal-Proxy-Vertrag (EIP-1167)? 1. Ein Minimal-Proxy-Vertrag, standardisiert im Ethereum Improvement Proposal (EIP) 1167, ist ein einfac...

Alle Artikel ansehen

User not found or password invalid

Your input is correct