jjzjj

c# - 迭代器 block 在 IL 中生成 try-fault

在尝试使用迭代器block后,我注意到生成的IL代码不是我期望的那样。生成try-faultblock而不是try-finallyblock,这是我从未见过的。我注意到编译器不允许我在“手写”C#中使用fault关键字。两者有区别吗?C#代码:staticIEnumerableReadAllLines(stringfileName){using(varfile=System.IO.File.OpenText(fileName)){strings;while((s=file.ReadLine())!=null){yieldreturns;}}}MSIL代码:.methodprivateh

c# - 动态生成的 IL 中的值类型转换

UpdateOverayearlater,andIfinallyrealizedthecauseofthisbehavior.Essentially,anobjectcan'tbeunboxedtoadifferenttypethanitwasboxedas(evenifthattypecastsorconvertstothedestinationtype),andifyoudon'tknowthecorrecttypeyouhavetodiscoveritsomehow.Theassignmentmaybeperfectlyvalid,butitisnotfeasibleforthi

c# - 为什么局部函数生成的 IL 不同于匿名方法和 Lambda 表达式?

为什么C#7编译器将局部函数转换为其父函数所在的同一类中的方法。而对于匿名方法(和Lambda表达式),编译器会为每个父函数生成一个嵌套类,它将包含所有匿名方法作为实例方法?例如,C#代码(匿名方法):internalclassAnonymousMethod_Example{publicvoidMyFunc(string[]args){varx=5;Actionact=delegate(){Console.WriteLine(x);};act();}}将生成类似于以下内容的IL代码(匿名方法):.classprivateautoansibeforefieldinitAnonymousM

c# - 为什么 IL.Emit 方法要添加额外的 nop 指令?

我有这段代码发出一些IL指令,这些指令在null对象上调用string.IndexOf:MethodBuildermethodBuilder=typeBuilder.DefineMethod("Foo",MethodAttributes.Public,typeof(void),Array.Empty());varmethodInfo=typeof(string).GetMethod("IndexOf",new[]{typeof(char)});ILGeneratorilGenerator=methodBuilder.GetILGenerator();ilGenerator.Emit(O

c# - 为什么 C# 编译器会产生方法调用以在 IL 中调用 BaseClass 方法

假设我们在C#中有以下示例代码:classBaseClass{publicvirtualvoidHelloWorld(){Console.WriteLine("HelloTarik");}}classDerivedClass:BaseClass{publicoverridevoidHelloWorld(){base.HelloWorld();}}classProgram{staticvoidMain(string[]args){DerivedClassderived=newDerivedClass();derived.HelloWorld();}}当我输入以下代码时:.methodpr

c# - 使用 MethodBuilder 生成动态 IL 时是否可以跳过可见性检查?

当使用DynamicMethod生成IL时,如果您为DynamicMethodconstructor中的restrictedSkipVisibility参数提供“true”,则可以调用方法和访问将无法访问的字段我宁愿将动态IL发送到动态程序集中,这样我就可以在构建时将生成的IL保存到程序集中。如果我使用此方法,则必须使用MethodBuilder而不是DynamicMethod。但是,我需要能够跳过可见性检查,以便在运行动态代码时不会出现MethodAccessException。有没有办法做到这一点,如果可以的话,怎么做? 最佳答案

c# - JIT 编译器的 IL 优化

我正在开发一个发出IL代码的编译器。重要的是,生成的IL由Mono和Microsoft.NETJIT编译器JIT为尽可能最快的机器代码。我的问题是:优化以下模式是否有意义:'stloc.0;ldloc.0;ret'=>'ret''ldc.i4.0;conv.r8'=>'ldc.r8.0'等等,或者JIT是否足够聪明来处理这些?是否有包含Microsoft/MonoJIT编译器执行的优化列表的规范?是否有任何关于优化IL的实用建议/最佳实践的好读物,以便JIT编译器可以反过来生成最佳机器代码(性能方面)? 最佳答案 您描述的两种模式是

c# - 当我使用 is 运算符时,为什么 IL 代码中只有空检查?

我想知道运算符是如何在C#中实现的。我写了一个简单的测试程序(没什么特别的,只是为了演示目的):classBase{publicvoidDisplay(){Console.WriteLine("Base");}}classDerived:Base{}classProgram{staticvoidMain(string[]args){vard=newDerived();if(disBase){varb=(Base)d;d.Display();}}}查看生成的IL代码:.methodprivatehidebysigstaticvoidMain(string[]args)cilmanaged

c# - 为什么 lambda 比 IL 注入(inject)动态方法快?

我刚刚构建了动态方法-见下文(感谢其他SO用户)。看起来Func创建为动态方法,IL注入(inject)比lambda慢2倍。有人知道为什么吗?(编辑:这是在VS2010中作为版本x64构建的。请从控制台而不是从VisualStudioF5内部运行它。)classProgram{staticvoidMain(string[]args){varmul1=IL_EmbedConst(5);varres=mul1(4);Console.WriteLine(res);varmul2=EmbedConstFunc(5);res=mul2(4);Console.WriteLine(res);dou

c# - 为什么在将 C# 代码编译为 IL 时会创建 .ctor()?

使用这个简单的C#代码,我运行cschello.cs;ildasm/out=hello.txthello.exe.classHello{publicstaticvoidMain(){System.Console.WriteLine("hi");}}这是ildasm的IL代码。.classprivateautoansibeforefieldinitHelloextends[mscorlib]System.Object{.methodpublichidebysigstaticvoidMain()cilmanaged{.entrypoint//Codesize13(0xd).maxstack