Capitalisation boursière: $3.2155T -3.82%
Volume(24h): $233.3428B 6.36%
Indice de peur et de cupidité:

22 - Peur extrême

  • Capitalisation boursière: $3.2155T -3.82%
  • Volume(24h): $233.3428B 6.36%
  • Indice de peur et de cupidité:
  • Capitalisation boursière: $3.2155T -3.82%
Cryptos
Les sujets
Cryptospedia
Nouvelles
Cryptosopique
Vidéos
Top Cryptospedia

Choisir la langue

Choisir la langue

Sélectionnez la devise

Cryptos
Les sujets
Cryptospedia
Nouvelles
Cryptosopique
Vidéos

Quelle est la différence entre une fonction payable et une fonction non payable dans Solidity ?

In Solidity, only functions marked `payable` can receive Ether, preventing accidental or malicious fund transfers and ensuring secure contract design.

Nov 14, 2025 at 01:59 pm

Comprendre les modificateurs de fonction dans Solidity

Dans Solidity, les fonctions des contrats intelligents peuvent se voir attribuer des modificateurs spécifiques qui dictent la manière dont elles interagissent avec Ether. Ces modificateurs jouent un rôle crucial pour déterminer si une fonction peut recevoir des fonds lors de son exécution. La distinction entre les fonctions payantes et non payables réside dans leur capacité à accepter l'Ether dans le cadre d'une transaction.

Fonctions payantes : acceptation des transferts d'éther

1. Une fonction payable est explicitement marquée du modificateur payable , lui permettant de recevoir de l'Ether lorsqu'elle est appelée.

  1. Lorsqu'un utilisateur envoie de l'Ether avec une transaction qui invoque une fonction payable, les fonds sont transférés sur le solde du contrat.
  2. Sans le modificateur payable, tenter d’envoyer de l’Ether à une fonction entraîne un échec de transaction.
  3. Les fonctions payantes sont essentielles pour des fonctionnalités telles que le financement participatif, les dons ou tout mécanisme par lequel les utilisateurs contribuent directement aux fonds via des appels de fonction.
  4. Dans une fonction payante, les développeurs peuvent accéder au montant envoyé en utilisant msg.value , qui contient le nombre de wei reçus.

Fonctions non payantes : rejet de l'éther entrant

1. Par défaut, les fonctions dans Solidity ne sont pas payantes, sauf indication contraire.

  1. Si une transaction tente d'envoyer de l'Ether vers une fonction non payante, l'intégralité de la transaction est annulée pour éviter une perte accidentelle de fonds.
  2. Ce comportement protège à la fois les utilisateurs et la logique du contrat contre les transferts Ether involontaires.
  3. Les fonctions non payantes conviennent aux opérations qui modifient uniquement l'état ou lisent des données sans nécessiter d'apport financier.
  4. Même si une fonction n'attend pas Ether, l'appeler avec msg.value > 0 provoquera une exception d'exécution si elle n'est pas marquée comme payable.

Implications pratiques dans la conception de contrats intelligents

1. Étiqueter à tort une fonction comme non payante alors qu'elle devrait accepter des fonds peut interrompre les fonctionnalités de base, telles que les achats de jetons ou les mécanismes de jalonnement.

  1. À l’inverse, marquer les fonctions inutiles comme payantes augmente la surface d’attaque, surtout s’il manque une validation appropriée autour de msg.value .
  2. Les développeurs doivent auditer soigneusement toutes les fonctions externes pour garantir une gestion correcte des flux Ether.
  3. Des outils tels que des analyseurs statiques et des cadres de test aident à détecter une utilisation incorrecte du modificateur payable avant le déploiement.
  4. Dans les contrats complexes, la distinction entre les fonctions de réception de fonds et de services publics améliore la clarté et la sécurité du code.

Foire aux questions

Un constructeur peut-il être payable ? Oui, un constructeur peut être marqué comme payable. Cela permet au contrat d'accepter Ether pendant le déploiement. Si la transaction de déploiement comprend un transfert de valeur, le constructeur doit être payable pour éviter un retour en arrière.

Que se passe-t-il si j'appelle une fonction non payante avec Ether ? La transaction sera automatiquement annulée et aucun changement d'état ne se produira. Ethereum applique cette règle au niveau EVM pour empêcher les transferts accidentels d'Ether vers des fonctions non conçues pour les gérer.

Existe-t-il un moyen de rendre toutes les fonctions d'un contrat payables par défaut ? Non, chaque fonction doit être déclarée individuellement comme payante. Il n'y a pas de paramètre global pour que chaque fonction accepte Ether. Cette conception garantit une gestion intentionnelle et sécurisée de la réception des fonds.

Les fonctions de secours peuvent-elles recevoir de l'Ether si elles ne sont pas payables ? Non, même les fonctions de secours doivent être marquées comme payantes pour accepter Ether. Une fonction de secours non payante rejettera tout Ether entrant envoyé au contrat sans spécifier d'appel de fonction.

Clause de non-responsabilité:info@kdj.com

Les informations fournies ne constituent pas des conseils commerciaux. kdj.com n’assume aucune responsabilité pour les investissements effectués sur la base des informations fournies dans cet article. Les crypto-monnaies sont très volatiles et il est fortement recommandé d’investir avec prudence après une recherche approfondie!

Si vous pensez que le contenu utilisé sur ce site Web porte atteinte à vos droits d’auteur, veuillez nous contacter immédiatement (info@kdj.com) et nous le supprimerons dans les plus brefs délais.

Connaissances connexes

Qu’est-ce qu’une attaque par déni de service (DoS) dans un contrat intelligent et quelles sont ses formes courantes ?

Qu’est-ce qu’une attaque par déni de service (DoS) dans un contrat intelligent et quelles sont ses formes courantes ?

Nov 10,2025 at 05:20am

Comprendre le déni de service dans les contrats intelligents 1. Une attaque par déni de service (DoS) dans le contexte des contrats intelligents fait ...

À quoi sert un nom occasionnel cryptographique dans la signature de transactions ?

À quoi sert un nom occasionnel cryptographique dans la signature de transactions ?

Nov 11,2025 at 05:59am

Comprendre les noms occasionnels cryptographiques dans les transactions blockchain 1. Un nom occasionnel cryptographique est un nombre aléatoire ou ps...

Comment fonctionne l’héritage dans les contrats intelligents Solidity ?

Comment fonctionne l’héritage dans les contrats intelligents Solidity ?

Nov 11,2025 at 10:40pm

Héritage dans la solidité : créer des contrats intelligents modulaires 1. L'héritage dans Solidity permet à un contrat d'adopter les propriété...

Quelle est la différence entre un compte externe (EOA) et un compte contractuel ?

Quelle est la différence entre un compte externe (EOA) et un compte contractuel ?

Nov 13,2025 at 04:00am

Comprendre les comptes externes (EOA) 1. Un compte externe est contrôlé directement par une clé privée, ce qui signifie que seul le titulaire de cette...

Qu'est-ce que la norme de redevances NFT ERC-2981 et comment fonctionne-t-elle ?

Qu'est-ce que la norme de redevances NFT ERC-2981 et comment fonctionne-t-elle ?

Nov 13,2025 at 05:39am

Comprendre la norme de redevances NFT ERC-2981 1. La norme ERC-2981 est une proposition de demande de commentaires Ethereum qui introduit un mécanisme...

Qu’est-ce qu’une attaque sandwich dans DeFi et comment exploite-t-elle les transactions ?

Qu’est-ce qu’une attaque sandwich dans DeFi et comment exploite-t-elle les transactions ?

Nov 15,2025 at 06:39pm

Comprendre les attaques sandwich dans la finance décentralisée 1. Une attaque sandwich est une forme de manipulation en amont et en aval couramment ob...

Qu’est-ce qu’une attaque par déni de service (DoS) dans un contrat intelligent et quelles sont ses formes courantes ?

Qu’est-ce qu’une attaque par déni de service (DoS) dans un contrat intelligent et quelles sont ses formes courantes ?

Nov 10,2025 at 05:20am

Comprendre le déni de service dans les contrats intelligents 1. Une attaque par déni de service (DoS) dans le contexte des contrats intelligents fait ...

À quoi sert un nom occasionnel cryptographique dans la signature de transactions ?

À quoi sert un nom occasionnel cryptographique dans la signature de transactions ?

Nov 11,2025 at 05:59am

Comprendre les noms occasionnels cryptographiques dans les transactions blockchain 1. Un nom occasionnel cryptographique est un nombre aléatoire ou ps...

Comment fonctionne l’héritage dans les contrats intelligents Solidity ?

Comment fonctionne l’héritage dans les contrats intelligents Solidity ?

Nov 11,2025 at 10:40pm

Héritage dans la solidité : créer des contrats intelligents modulaires 1. L'héritage dans Solidity permet à un contrat d'adopter les propriété...

Quelle est la différence entre un compte externe (EOA) et un compte contractuel ?

Quelle est la différence entre un compte externe (EOA) et un compte contractuel ?

Nov 13,2025 at 04:00am

Comprendre les comptes externes (EOA) 1. Un compte externe est contrôlé directement par une clé privée, ce qui signifie que seul le titulaire de cette...

Qu'est-ce que la norme de redevances NFT ERC-2981 et comment fonctionne-t-elle ?

Qu'est-ce que la norme de redevances NFT ERC-2981 et comment fonctionne-t-elle ?

Nov 13,2025 at 05:39am

Comprendre la norme de redevances NFT ERC-2981 1. La norme ERC-2981 est une proposition de demande de commentaires Ethereum qui introduit un mécanisme...

Qu’est-ce qu’une attaque sandwich dans DeFi et comment exploite-t-elle les transactions ?

Qu’est-ce qu’une attaque sandwich dans DeFi et comment exploite-t-elle les transactions ?

Nov 15,2025 at 06:39pm

Comprendre les attaques sandwich dans la finance décentralisée 1. Une attaque sandwich est une forme de manipulation en amont et en aval couramment ob...

Voir tous les articles

User not found or password invalid

Your input is correct