Bien que
PULL et SAX soient tous deux basés sur l'événement, la différence la plus importante entre les deux devrait être :
SAX peut être considéré comme "PUSH", par opposition à PULL. Parce que Parser transmettra les données à la fonction de rappel pour traitement lorsqu'elle rencontre une source d'événement spécifique. En ce sens, les données sont "poussées" vers l'utilisateur, tandis que la méthode PULL est utilisée lorsqu'elle rencontre un. événement spécifique. Lorsque les utilisateurs obtiennent ce qui les intéresse auprès de Parser, ils ont l'impression que les données sont "extraites".
Une autre différence est : pendant le processus d'analyse PULL (dans la boucle while ), vous pouvez quitter la boucle mais dans le processus SAX, une fois l'analyse commencée, compléter l’analyse.
De plus, une petite extension :
Il existe actuellement deux principes principaux d'analyse et de génération. L'un consiste à faire correspondre les noms de classe, les attributs noms et autres informations par réflexion, et l'autre. est d'utiliser directement le bytecode de jvm pour fonctionner, l'efficacité de ces deux méthodes va de soi. Naturellement, le bytecode binaire est plus efficace.
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!