J'aime utiliser les Enums quand c'est possible mais j'ai eu une situation où je devais calculer des millions de décalages de fichiers pour différents types de fichiers que j'avais définis dans un enum et j'ai dû exécuter une instruction switch des dizaines de millions de fois pour calculer le décalage sur la base du type d'enum. J'ai effectué le test suivant :
import java.util.Random;
classe publique switchTest { public enum MyEnum { Valeur1, Valeur2, Valeur3, Valeur4, Valeur5 } ;
public static void main(String[] args)
{
final String s1 = "Value1";
final String s2 = "Value2";
final String s3 = "Value3";
final String s4 = "Value4";
final String s5 = "Value5";
String[] strings = new String[]
{
s1, s2, s3, s4, s5
};
Random r = new Random();
long l = 0;
long t1 = System.currentTimeMillis();
for(int i = 0; i < 10_000_000; i++)
{
String s = strings[r.nextInt(5)];
switch(s)
{
case s1:
// make sure the compiler can't optimize the switch out of existence by making the work of each case it does different
l = r.nextInt(5);
break;
case s2:
l = r.nextInt(10);
break;
case s3:
l = r.nextInt(15);
break;
case s4:
l = r.nextInt(20);
break;
case s5:
l = r.nextInt(25);
break;
}
}
long t2 = System.currentTimeMillis();
for(int i = 0; i < 10_000_000; i++)
{
MyEnum e = MyEnum.values()[r.nextInt(5)];
switch(e)
{
case Value1:
// make sure the compiler can't optimize the switch out of existence by making the work of each case it does different
l = r.nextInt(5);
break;
case Value2:
l = r.nextInt(10);
break;
case Value3:
l = r.nextInt(15);
break;
case Value4:
l = r.nextInt(20);
break;
case Value5:
l = r.nextInt(25);
break;
}
}
long t3 = System.currentTimeMillis();
for(int i = 0; i < 10_000_000; i++)
{
int xx = r.nextInt(5);
switch(xx)
{
case 1:
// make sure the compiler can't optimize the switch out of existence by making the work of each case it does different
l = r.nextInt(5);
break;
case 2:
l = r.nextInt(10);
break;
case 3:
l = r.nextInt(15);
break;
case 4:
l = r.nextInt(20);
break;
case 5:
l = r.nextInt(25);
break;
}
}
long t4 = System.currentTimeMillis();
System.out.println("strings:" + (t2 - t1));
System.out.println("enums :" + (t3 - t2));
System.out.println("ints :" + (t4 - t3));
}
}
et j'ai obtenu les résultats suivants :
cordes:442
enums :455
ints :362
J'ai donc décidé que les enums étaient suffisamment efficaces pour moi. Lorsque j'ai réduit le nombre de boucles de 10M à 1M, les chaînes et les enums prenaient environ deux fois plus de temps que les int, ce qui indique qu'il y avait un certain surcoût à utiliser les chaînes et les enums pour la première fois par rapport aux ints.