En interne, string::operator==()
utilise string::compare()
. Veuillez vous référer à: CPlusPlus -string::operator==()
J'ai écrit une petite application pour comparer les performances, et apparemment, si vous compilez et exécutez votre code sur l'environnement de débogage, il string::compare()
est légèrement plus rapide que string::operator==()
. Cependant, si vous compilez et exécutez votre code dans l'environnement Release, les deux sont à peu près les mêmes.
Pour info, j'ai exécuté 1 000 000 d'itérations afin de parvenir à une telle conclusion.
Afin de prouver pourquoi dans l'environnement de débogage la chaîne :: compare est plus rapide, je suis allé à l'assembly et voici le code:
DEBUG BUILD
string :: operator == ()
if (str1 == str2)
00D42A34 lea eax,[str2]
00D42A37 push eax
00D42A38 lea ecx,[str1]
00D42A3B push ecx
00D42A3C call std::operator==<char,std::char_traits<char>,std::allocator<char> > (0D23EECh)
00D42A41 add esp,8
00D42A44 movzx edx,al
00D42A47 test edx,edx
00D42A49 je Algorithm::PerformanceTest::stringComparison_usingEqualOperator1+0C4h (0D42A54h)
string :: compare ()
if (str1.compare(str2) == 0)
00D424D4 lea eax,[str2]
00D424D7 push eax
00D424D8 lea ecx,[str1]
00D424DB call std::basic_string<char,std::char_traits<char>,std::allocator<char> >::compare (0D23582h)
00D424E0 test eax,eax
00D424E2 jne Algorithm::PerformanceTest::stringComparison_usingCompare1+0BDh (0D424EDh)
Vous pouvez voir que dans string :: operator == (), il doit effectuer des opérations supplémentaires (ajouter esp, 8 et movzx edx, al)
RELEASE BUILD
string :: operator == ()
if (str1 == str2)
008533F0 cmp dword ptr [ebp-14h],10h
008533F4 lea eax,[str2]
008533F7 push dword ptr [ebp-18h]
008533FA cmovae eax,dword ptr [str2]
008533FE push eax
008533FF push dword ptr [ebp-30h]
00853402 push ecx
00853403 lea ecx,[str1]
00853406 call std::basic_string<char,std::char_traits<char>,std::allocator<char> >::compare (0853B80h)
string :: compare ()
if (str1.compare(str2) == 0)
00853830 cmp dword ptr [ebp-14h],10h
00853834 lea eax,[str2]
00853837 push dword ptr [ebp-18h]
0085383A cmovae eax,dword ptr [str2]
0085383E push eax
0085383F push dword ptr [ebp-30h]
00853842 push ecx
00853843 lea ecx,[str1]
00853846 call std::basic_string<char,std::char_traits<char>,std::allocator<char> >::compare (0853B80h)
Les deux codes d'assemblage sont très similaires car le compilateur effectue l'optimisation.
Enfin, à mon avis, le gain de performances est négligeable, donc je laisse vraiment le soin au développeur de décider lequel est le préféré car les deux atteignent le même résultat (surtout quand il s'agit de la version build).