« Pourquoi mon .net exe si énorme » outil d'analyse?
-
26-10-2019 - |
Question
Y at-il un outil qui peut expliquer la taille d'un assemblage .NET (fichier exécutable ou DLL)?
Dans les temps anciens, il y avait une extension IDE qui préciserait l'espace utilisé par un projet.
Il faut montrer les grandes code fichiers:
et données Ressources :
Y at-il une telle chose pour le monde .NET?
Je pensais vraiment que le passage à .NET, et ne plus avoir à construire l'ensemble VCL dans l'exécutable, que les tailles exécutables rétréciraient.
Bonus lecture
La solution
Le SDK norme a pris ILDASM (IL désassembleur), avait l'option "Statistiques" dans le menu Affichage, qui rompit comme ceci:
File size : 3072
PE header size : 512 (456 used) (16.67%)
PE additional info : 167 ( 5.44%)
Num.of PE sections : 2
CLR header size : 72 ( 2.34%)
CLR meta-data size : 1572 (51.17%)
CLR additional info : 0 ( 0.00%)
CLR method headers : 15 ( 0.49%)
Managed code : 77 ( 2.51%)
Data : 512 (16.67%)
Unaccounted : 145 ( 4.72%)
Num.of PE sections : 2
.text - 2048
.reloc - 512
CLR meta-data size : 1572
Module - 1 (10 bytes)
TypeDef - 4 (56 bytes) 0 interfaces, 0 explicit layout
TypeRef - 15 (90 bytes)
MethodDef - 4 (56 bytes) 0 abstract, 0 native, 4 bodies
FieldDef - 2 (12 bytes) 0 constant
MemberRef - 15 (90 bytes)
ParamDef - 4 (24 bytes)
CustomAttribute- 13 (78 bytes)
StandAloneSig - 1 (2 bytes)
Assembly - 1 (22 bytes)
AssemblyRef - 1 (20 bytes)
Strings - 571 bytes
Blobs - 336 bytes
UserStrings - 8 bytes
Guids - 16 bytes
Uncategorized - 181 bytes
CLR method headers : 15
Num.of method bodies - 4
Num.of fat headers - 1
Num.of tiny headers - 3
Managed code : 77
Ave method size - 19
Cela devrait fournir un bon point de départ.
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow