-
bitcoin $95261.237518 USD
-4.11% -
ethereum $3152.227039 USD
-1.62% -
tether $0.999292 USD
-0.03% -
xrp $2.273593 USD
-1.70% -
bnb $924.706716 USD
0.10% -
solana $141.134262 USD
-2.19% -
usd-coin $1.000066 USD
0.03% -
tron $0.294058 USD
0.79% -
dogecoin $0.160834 USD
-1.90% -
cardano $0.506745 USD
-3.96% -
hyperliquid $37.905078 USD
0.01% -
zcash $646.784227 USD
27.14% -
chainlink $14.081700 USD
-2.64% -
bitcoin-cash $484.371031 USD
-5.19% -
unus-sed-leo $9.194167 USD
0.19%
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.
- 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.
- Sans le modificateur payable, tenter d’envoyer de l’Ether à une fonction entraîne un échec de transaction.
- 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.
- 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.
- 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.
- Ce comportement protège à la fois les utilisateurs et la logique du contrat contre les transferts Ether involontaires.
- Les fonctions non payantes conviennent aux opérations qui modifient uniquement l'état ou lisent des données sans nécessiter d'apport financier.
- 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.
- À 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 .
- Les développeurs doivent auditer soigneusement toutes les fonctions externes pour garantir une gestion correcte des flux Ether.
- 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.
- 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.
-
KEEP Échangez maintenant$0.1036
95.94%
-
CROSS Échangez maintenant$0.1523
43.26%
-
TEL Échangez maintenant$0.006091
17.21%
-
XVG Échangez maintenant$0.007507
16.08%
-
ZEC Échangez maintenant$666.43
14.50%
-
LA Échangez maintenant$0.5185
13.53%
- 101e anniversaire d'un vétéran de la Marine : un siècle de service célébré
- 2025-11-16 05:00:02
- Vétérans de New York : créer de la richesse dans la Big Apple avec votre prêt VA
- 2025-11-16 04:50:02
- Les cryptos aujourd’hui : krach du marché ou opportunité croissante ?
- 2025-11-16 04:45:01
- La révolution des enchères DeFi d'Uniswap : une nouvelle ère pour les ventes de jetons ?
- 2025-11-16 04:45:01
- Pièces de confidentialité, crypto et ChatGPT : une perspective 2025
- 2025-11-16 03:40:01
- Poésie, monnaie et royaume : naviguer dans l'authenticité à l'ère de l'IA
- 2025-11-16 03:35:01
Connaissances connexes
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 ?
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 ?
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 ?
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 ?
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 ?
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 ?
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 ?
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 ?
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 ?
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 ?
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 ?
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














