おはよう、午後または夜のシフト、分割手段/アセンブリの違いに
は、デバッグのアセンブリコードを見ていた「抑止JIT最適化(...)」でビルドオプションがオフになって、私は次のように奇妙なことに気づいています行動(bitCount
がulong
ある):
int BitQuotient = (int)(bitCount/32);
00000110 push dword ptr [ebp+0Ch]
00000113 push dword ptr [ebp+8]
00000116 push 0
00000118 push 20h
0000011a call 738EF4D5
0000011f mov dword ptr [ebp-44h],eax
int BitQuotient = (int)(bitCount >> 5);
00000110 mov eax,dword ptr [ebp+8]
00000113 mov edx,dword ptr [ebp+0Ch]
00000116 shrd eax,edx,5
0000011a shr edx,5
0000011d mov dword ptr [ebp-44h],eax
とは対照的に、なぜアセンブリにおけるそのような違いがありますか?コンパイラは、32による除算が5で右へのシフトと同じで、コードを置き換えることを検出してはいけませんか?また、最初のコードではcall
命令は何ですか?私はオペレータ/
が非ネイティブのulong
に適用されていることに関係していると思われますが、それはコンパイラがこの種の演算子をインライン化しないことを意味しますか?
編集:int BitRemainder = (int)(bitCount & 31)
とは対照的に、がint BitRemainder = (int)(bitCount % 32)
を見てください:
00000120 mov eax,dword ptr [ebp+8]
0000mov edx,dword ptr [ebp+0Ch]
00000126 mov ecx,20h
0000012b cmp edx,ecx
0000012d jb 00000139
0000012f mov ebx,eax
00000131 mov eax,edx
00000133 xor edx,edx
00000135 div eax,ecx
00000137 mov eax,ebx
00000139 div eax,ecx
0000013b mov eax,edx
0000013d xor edx,edx
0000013f mov dword ptr [ebp-48h],eax
と
00000120 mov eax,dword ptr [ebp+8]
0000and eax,1Fh
00000126 mov dword ptr [ebp-48h],eax
ありがとうございました。
bitCountのデータタイプは? – jswolf19
申し訳ありません... bitCountは 'ulong'です。 – Miguel
ああ、私は話を始めようとしていました。あなたはそれを追加しました! –