草庐IT

编译时

全部标签

c# - C# 编译器和 C++/CLI 编译器的输出之间的差异

我有一个WPF应用程序,它在大型数据集之间进行大量匹配,目前它使用C#和LINQ来匹配POCO并在网格中显示。随着包含的数据集数量和数据量的增加,我被要求查看性能问题。我今晚测试的假设之一是,如果我们将一些代码转换为C++CLI,是否会有实质性差异。为此,我编写了一个简单的测试来创建一个List有5,000,000个项目,然后做一些简单的匹配。基本的对象结构是:publicclassCsClassWithProps{publicCsClassWithProps(){CreateDate=DateTime.Now;}publiclongId{get;set;}publicstringNa

c# - 您能否使用 Mono/LLVM 生成比使用 Microsoft 的 C# 编译器更快的 .NET 应用程序?

MonowithLLVM项目能够使用LLVM编译器后端,它有一些非常强大的优化来编译C#.NET项目,这使得它在计算密集型应用程序中的运行速度提高了大约20%。MonoisnowabletouseLLVMasabackendforcodegenerationinadditiontoMono'sbuilt-inJITcompiler.ThisallowsMonotobenefitfromallofthecompileroptimizationsdoneinLLVM.ForexampletheSciMarkscoregoesfrom482to610.那么是否可以将现有的C#.NET项目定位

c# - 为什么 C# 编译器重载解析算法将具有相同签名的静态成员和实例成员视为相等?

让我们有两个签名相同的成员,但一个是静态的而另一个不是:classFoo{publicvoidTest(){Console.WriteLine("instance");}publicstaticvoidTest(){Console.WriteLine("static");}}但是这样的代码生成会带来编译错误:Type'Foo'alreadydefinesamembercalled'Test'withthesameparametertypes但为什么呢?让我们编译成功,然后:Foo.Test()应该输出“static”newFoo().Test();应该输出“instance”不能调用静

c# - 反编译源中不寻常的 C# 运算符...?

我刚刚使用DotPeek反编译了一些第3方源代码以调试问题。输出代码包含一些不寻常的运算符,AFAIK不是有效的C#,所以我想知道它们是什么意思...摘录看起来像(包括Dotpeek评论,因为它们可能是相关的);protectedinternalvoidDoReceive(refbyte[]Buffer,intMaxSize,outintWritten){Written=0;...//ISSUE:explicitreferenceoperation//ISSUE:variableofareferencetypeint&local=@Written;intnum=SomeMethod()

c# - 为什么编译器不允许在 catch block 中使用 await

假设我有一个异步方法:publicasyncTaskDo(){awaitTask.Delay(1000);}另一种方法是尝试在catchblock中调用Do方法publicasyncTaskDoMore(){try{}catch(Exception){awaitDo();//compilederror.}}但是这样一来,编译器就不允许在catch中使用await了,有没有什么原因导致我们不能那样使用它? 最佳答案 更新这将在C#6中得到支持。事实证明,这并非根本不可能,并且该团队想出了如何做到这一点而又不会在实现过程中陷入困境:)原

c# - 带有 C# 项目的 Visual Studio 12 Professional 中的编译问题

该项目在VisualStudio2010中运行良好,我们升级到VisualStudio2012;但是,现在它无法编译。我们收到以下错误:Error2Taskcouldnotfind"AL.exe"usingtheSdkToolsPath""ortheregistrykey"HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MicrosoftSDKs\Windows\v8.0A\WinSDK-NetFx40Tools-x86".MakesuretheSdkToolsPathissetandthetoolexistsinthecorrectprocessorspe

C# 编译器错误 : "cannot have instance field initializers in structs"

我需要有关结构的建议。我有两段代码。第一部分如下:namespaceProject.GlobalVariables{classIOCard{structInputCard{publicstringCardNo;publicintBaseAddress;publicintLowerAddress;publicintUpperAddress;publicint[]WriteBitNo=newint[16];publicint[]ReadBitNo=newint[16];}staticInputCard[]InputCards=newInputCard[5];publicstaticstri

c# - 编译转换 : The type 'Object' is defined in an assembly that is not referenced

我正在对一个asp.NetMVC5网络应用程序进行一些更改,我在其中使用了typelite从C#类创建.ts定义(非常方便)。出于某种原因,现在我在执行T4时遇到了这个错误:Compilingtransformation:Thetype'Object'isdefinedinanassemblythatisnotreferenced.Youmustaddareferencetoassembly'mscorlib,Version=2.0.5.0,Culture=neutral,PublicKeyToken=7cec85d7bea7798e,Retargetable=Yes'.和这个警告:C

c# - 使用 Intellisense 和编译时检查提取属性名称以进行反射

好的。所以我有一些代码将winForm上的某些控件映射到对象中的某些属性,以便在数据发生某些事情时对控件执行某些事情。一切都很好,工作正常。不是问题。问题是,为了将项目添加到映射,我调用了一个如下所示的函数:this.AddMapping(this.myControl,myObject,"myObjectPropertyName");我遇到的问题是,在编译时很难区分上面一行和下面一行之间的区别:this.AddMapping(this.myControl,myObject,"myObjectPropretyName");因为最后一个参数是一个字符串,所以没有编译时检查或任何类似的东西来

c# - 如何根据编译符号有条件地引用 DLL?

VisualStudio2013。我有一个外部DLL,我在csproj文件中像这样引用它:Path\To\Dll\NameOfDll.dll我希望此引用在编译器符号存在时起作用,而在该编译器符号不存在时不起作用。(为了解决下面的第一条评论,假设编译器符号称为Fred。)这个问题[ConditionalReference]让我觉得我可以将一个名为Condition的属性添加到上面显示的Reference元素,但我无法计算出赋予该属性什么值来实现我想要的效果。我很高兴能够在VSUI中执行此操作,但我会采用任何方法。 最佳答案 条件编译符