Maison >Java >javaDidacticiel >Comprendre en profondeur les résultats de l'opération et les principes de fonctionnement de ''i=i++;' en Java
Tout d'abord, voici le code :
public class Demo{ public static void main(String []args){ int i=12; i=i++; System.out.println(i); } }
Vous pouvez imaginer à quel point ce code est important. peut répondre 13 , mais ce n'est pas le cas, comme le montre la figure suivante :
Dans la figure ci-dessus, je l'ai d'abord exécuté et vous pouvez voir le résultat. je ne correspond pas à ce que la plupart des gens ont deviné. La sortie est 13, mais il semble que cette opération d'auto-incrémentation ne soit pas effectuée, mais pourquoi ?
Il y a donc l'opération ultérieure de décompilation en bytecode. Nous utilisons l'instruction javap pour décompiler et nous pouvons clairement voir ce qui se passe. Certains étudiants ne comprennent pas les instructions JVM. Je suis ici. Vulgarisons d'abord les instructions JVM impliquées dans le code de cet article
(Le code d'instruction clé ici est après la méthode principale, donc seules les instructions suivantes sont expliquées. Celles qui précèdent ; il est automatiquement construit par la machine virtuelle. Le code d'instruction de la méthode de construction par défaut)
1.bipush : Pousse la valeur constante sur un octet (-128~127) en haut de la pile.
2.istore : poussez le type int en haut de la pile. La valeur est stockée dans la variable locale spécifiée
3.iload : poussez la variable locale de type int spécifiée en haut de la pile
4.iinc : Cette instruction est utilisée pour effectuer des opérations d'auto-incrémentation et de décrémentation sur des variables locales (locales). Le premier paramètre de cette instruction est le numéro de la variable locale, et le deuxième paramètre est le nombre d'auto-incréments et décréments
5.getstatic obtient le domaine statique de la classe spécifiée et pousse sa valeur en haut du pile (après avoir atteint cette position, statique est appelé L'opération d'impression d'objet ne sera pas décrite en détail. Les étudiants intéressés peuvent en apprendre davantage sur le lien ci-joint à la fin de cet article)
Après avoir connu un quelques instructions de base, analysons la signification des instructions clés dans l'image ci-dessus :
bipush 12 Ici, on pousse 12 vers le haut de la pile et on stocke 12 dans la pile. valeur int
istore_1 Voici un saut de 12 à la deuxième (remarque : la première variable locale devrait être celle-ci) la variable locale est i=12
iload_1 Voici la valeur de la deuxième variable locale (i) poussée sur la pile A ce moment, le haut de la pile est 12
iinc 1,1 Naturellement, i=. i+1, c'est-à-dire i++. À ce moment, i=13
istore_1 Ici, la valeur supérieure de la pile est placée dans la variable locale i. se voit attribuer la valeur 12
, donc quand il est finalement imprimé, j'ai 12.
Une collection d'instructions JVM compilées par un gars du CSDN, ce qui est très pratique pour les requêtes et l'apprentissage
Articles connexes :
La différence entre ++i et i++
Vidéos associées :
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!