1 resultado para Parallel programming (computer science)

em Université de Montréal


Relevância:

100.00% 100.00%

Publicador:

Resumo:

Les langages de programmation typés dynamiquement tels que JavaScript et Python repoussent la vérification de typage jusquâau moment de lâexécution. Afin dâoptimiser la performance de ces langages, les implémentations de machines virtuelles pour langages dynamiques doivent tenter dâéliminer les tests de typage dynamiques redondants. Cela se fait habituellement en utilisant une analyse dâinférence de types. Cependant, les analyses de ce genre sont souvent coûteuses et impliquent des compromis entre le temps de compilation et la précision des résultats obtenus. Ceci a conduit à la conception dâarchitectures de VM de plus en plus complexes. Nous proposons le versionnement paresseux de blocs de base, une technique de compilation à la volée simple qui élimine efficacement les tests de typage dynamiques redondants sur les chemins dâexécution critiques. Cette nouvelle approche génère paresseusement des versions spécialisées des blocs de base tout en propageant de lâinformation de typage contextualisée. Notre technique ne nécessite pas lâutilisation dâanalyses de programme coûteuses, nâest pas contrainte par les limitations de précision des analyses dâinférence de types traditionnelles et évite la complexité des techniques dâoptimisation spéculatives. Trois extensions sont apportées au versionnement de blocs de base afin de lui donner des capacités dâoptimisation interprocédurale. Une première extension lui donne la possibilité de joindre des informations de typage aux propriétés des objets et aux variables globales. Puis, la spécialisation de points dâentrée lui permet de passer de lâinformation de typage des fonctions appellantes aux fonctions appellées. Finalement, la spécialisation des continuations dâappels permet de transmettre le type des valeurs de retour des fonctions appellées aux appellants sans coût dynamique. Nous démontrons empiriquement que ces extensions permettent au versionnement de blocs de base dâéliminer plus de tests de typage dynamiques que toute analyse dâinférence de typage statique.