Ниже приведена простая испытательная арматура. Он успешно работает в сборках Debug и не работает в версиях Release (VS2010,.NET4, x64):
[TestFixture]
public sealed class Test
{
[Test]
public void TestChecker()
{
var checker = new Checker();
Assert.That(checker.IsDateTime(DateTime.Now), Is.True);
}
}
public class Checker
{
public bool IsDateTime(object o)
{
return o is DateTime;
}
}
Кажется, что оптимизация кода вызывает некоторый хаос; если я отключу его в сборке Release, он также работает. Это было довольно странно для меня. Ниже я использовал ILDASM, чтобы разобрать 2 версии сборки:
Отладка IL:
.method public hidebysig instance bool IsDateTime(object o) cil managed
{
// Code size 15 (0xf)
.maxstack 2
.locals init (bool V_0)
IL_0000: nop
IL_0001: ldarg.1
IL_0002: isinst [mscorlib]System.DateTime
IL_0007: ldnull
IL_0008: cgt.un
IL_000a: stloc.0
IL_000b: br.s IL_000d
IL_000d: ldloc.0
IL_000e: ret
} // end of method Validator::IsValid
Релиз IL:
.method public hidebysig instance bool IsDateTime(object o) cil managed
{
// Code size 10 (0xa)
.maxstack 8
IL_0000: ldarg.1
IL_0001: isinst [mscorlib]System.DateTime
IL_0006: ldnull
IL_0007: cgt.un
IL_0009: ret
} // end of method Validator::IsValid
Кажется, что магазин и загрузка оптимизированы. Ориентация на ранние версии платформы .NET заставила проблему уйти, но это может быть просто случайностью. Я обнаружил, что это поведение несколько раздражает, может ли кто-нибудь объяснить, почему компилятор будет считать безопасным делать оптимизацию, которая вызывает различное наблюдаемое поведение?
Спасибо заранее.