CONNEXION
  • RetourJeux
    • Sorties
    • Hit Parade
    • Les + populaires
    • Les + attendus
    • Soluces
    • Tous les Jeux
    • Gaming
  • RetourActu Gaming
    • News
    • Astuces
    • Tests
    • Previews
    • Toute l'actu gaming
  • RetourBons plans
    • Bons plans
    • Bons plans Smartphone
    • Bons plans Hardware
    • Bons plans Image et Son
    • Bons plans Amazon
    • Bons plans Cdiscount
    • Bons plans Decathlon
    • Bons plans Fnac
    • Tous les Bons plans
  • RetourJVTech
    • Actus High-Tech
    • Intelligence Artificielle
    • Smartphones
    • Mobilité urbaine
    • Hardware
    • Image et son
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTech
  • RetourCulture
    • Actus Culture
    • Culture
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch 2
    • Xbox Series
    • Switch
    • Pokemon pocket
    • FC 25 Ultimate Team
    • League of Legends
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • Switch 2
  • PS4
  • One
  • Switch
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Liste des sujets

[Java] Polymorphisme et Surcharge

Tumensmaisbon
Tumensmaisbon
Niveau 2
21 décembre 2017 à 06:58:06

https://scontent-cdg2-1.xx.fbcdn.net/v/t34.0-12/25589628_10211675795225500_1712473632_n.png?oh=15d6e6c8f024caa97f42a329880c97f4&oe=5A3E1C41

Pourquoi est-ce que la dernière ligne affiche "AA" ?

whiteapplex
whiteapplex
Niveau 18
21 décembre 2017 à 09:05:06

ab est un A (un B transformé en A)
f(A a) de A accepte les B qui sont des A.
ab.f(bb) => A::f(bb) => A::f(B) ? (je connais pas de f(B) dans mon contexte A) => A::f(A) => AA

En fait, dans le contexte de ab (contexte de A), on ne connait pas de fonction qui a une signature f(B b), donc on prend celle qui fonctionne par l'héritage quand même A::f(A a).
Si jamais tu enlèves l'argument de f(), il connaitrait B::f() puisqu'elle écraserait A::f(). Et idem si tu créais B::f(A), il ferait appel à B::f(A) et pas à A::f(A), et idem si tu fais A::f(B) et B::f(B), il irait chercher B::f(B).
C'est mon interpréation

Message édité le 21 décembre 2017 à 09:06:15 par whiteapplex
arsh222
arsh222
Niveau 10
22 décembre 2017 à 03:17:26

ab a été déclaré comme un A, donc le compilateur va chercher dans les fonctions de A.

Parmi ces fonctions, la première accepte un argument de type B (parce que B est un sous-type de A), mais la seconde non (parce que B n’est pas un sous-type de C) ; c’est donc la première qui est utilisée

Sous forums
  • Aide à l'achat Mac
  • Création de Jeux
  • Linux
  • Création de sites web
  • Programmation
  • Internet
  • Steam Deck
  • Macintosh
  • Hardware
La vidéo du moment