[#CALENDRIER DE L'AVENT 5/25]
25 jours pour apprendre à développer des Smart Contracts en #Solidity 🔥
Jour 5 / 25 :
Comprendre le constructeur et les fonctions, notamment leurs différents types !
🧵
Le tweet précédent
🔽
Nous avons vu ce que sont les imports et les variables en Solidity !
Nous avons aussi pu créer, déployer, tester des contrats.
Tout ceci nous a permis d’utiliser deux choses très importantes que nous n’avons pas pris le temps de développer :
Le constructeur et les fonctions !
Le constructeur, dans un contrat, est facilement identifiable.
En effet, son nommage est toujours “constructor()” lorsqu’il est présent.
Le constructeur est optionnel.
Pour résumer, il correspond à la fonction appelée lors de la création du contrat sur la blockchain.
Il est tout à fait possible de passer des arguments à ce constructeur, comme un prix en Ether, ou une adresse, etc.
Dans l’exemple, on initialise la variable “owner” avec “msg.sender”.
La variable “msg.sender” est tout simplement l’adresse de la personne qui crée le contrat.
Il faut retenir que le constructeur est appelé à la construction (logique ?) du contrat, et ne sera plus jamais appelé
Voilà pour les grandes lignes du constructeur et ce qu’il y a à savoir pour aujourd’hui, voici un lien si vous voulez approfondir :
tutorialspoint.com/solidity/solid…
Passons aux fonctions !
C’est un sujet super vaste, nous allons le survoler aujourd’hui, mais pas de panique si vous ne comprenez pas tout, avec tout ce que nous allons réaliser dans les jours qui viennent, vous aurez largement de quoi apprendre !
Une fonction est une tâche qui va se réaliser lorsqu’on l’appelle.
Vous pouvez lui passer des paramètres au besoin !
En Solidity, les fonctions ont la particularité d’avoir une visibilité, vous devez la définir, cela va impacter la manière dont vous allez pouvoir l’utiliser !
Il existe 4 types de visibilité (comme pour les variables) :
• external
• public
• internal
• private
Voici un résumé de qui fait quoi !
🔽
En plus de la visibilité, vous pouvez définir plus précisément votre fonction.
Une fonction de type “view” permet de retourner une information sans engendrer de modifications sur l’état de la blockchain.
Ces fonctions ne consomment donc pas de gaz si elles sont appelées de l’extérieur (mais elles en consomment si c’est une autre fonction qui l’appelle).
Il existe aussi une alternative à “view” qui est le type “pure”.
C’est une fonction qui ne manipule rien de stocké sur la blockchain.
La vue d’avant multiplie deux variables stockées sur le contrat, celle-ci multiplie directement des chiffres dans la fonction.
Il existe aussi la possibilité de rajouter un marqueur sur une fonction lorsqu’elle doit manipuler des Ethers (ou la monnaie de la blockchain sur laquelle vous développez).
Nous verrons ça très bientôt !
Pour rappel, définir une variable avec l’identifieur “public” créera automatiquement une fonction pour récupérer sa valeur.
Les fonctions vont nous permettre de fractionner la logique du contrat en plusieurs parts modifiables (le mint, la vérification de whitelist, etc..).
Votre exercice pour aujourd’hui est aussi simple que crucial, lire la documentation de Solidity sur les fonctions :
docs.soliditylang.org/fr/latest/cont…
Elle est top et claire, vous en tirerez pas mal d’informations !
Maintenant que nous avons vu une belle vue d’ensemble des principaux points clefs d’un smart contract, nous allons pouvoir passer à un exercice pratique “simple” dès demain.
Ensuite, nous attaquerons le gros TP !
Si l'initiative vous plait, vous pouvez me soutenir avec un j'aime et un retweet sur le tweet principal.
N'hésitez pas à vous abonner pour ne pas rater les jours qui arrivent 🔥
Passez une bonne journée, à demain !👋
Share this Scrolly Tale with your friends.
A Scrolly Tale is a new way to read Twitter threads with a more visually immersive experience.
Discover more beautiful Scrolly Tales like this.
