草庐IT

XX_IL_OLM_COMP_ELEMENT_OBJ

全部标签

c# - "Could not find endpoint element with name..."

抱歉问题陈述太长了...我花了两天时间进行调试并做了很多笔记...我有一个WCF数据服务和另一个试图通过TCP和/或HTTP作为客户端连接到它的进程。我有一个非常简单的测试客户端应用程序,似乎连接正常,但更复杂的生产应用程序无法连接(TCP或HTTP)。在这两个客户端项目中,我让VisualStudio2008使用“添加服务引用”生成app.config,并让它从数据服务中提取元数据。这是工作的简单测试客户端的代码:usingClient.MyDataService;namespaceClient{classProgram{staticvoidMain(string[]args){My

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# - `fixed` 与 GCHandle.Alloc(obj,GCHandleType.Pinned)

我试图找出用fixed关键字定义的固定指针是如何工作的。我的想法是在内部GCHandle.Alloc(object,GCHandleType.Pinned)用于此目的。但是当我查看为以下C#代码生成的IL时:unsafestaticvoidf1(){vararr=newMyObject[10];fixed(MyObject*aptr=&arr[0]){Console.WriteLine(*aptr);}}我找不到任何GCHandle的踪迹。我看到该方法中使用固定指针的唯一提示是以下IL声明:.localsinit([0]valuetypeTestPointerPinning.MyObj

c# - Visual Studio 2013 创建 Web API 项目时出错 : The element <#text> beneath element <Project> is unrecognized

我的VisualStudio安装有问题。为了重现它,我创建了一个新的空白解决方案,然后:添加新项目..ASP.NET网络应用程序网络应用程序接口(interface)创建项目VisualStudio无法创建它,我收到此消息:Theelementbeneathelementisunrecognized.有什么解决办法吗? 最佳答案 如果csproj包含无效的XML,您将得到这样的错误。我不小心删除了时遇到了这个错误在csproj文件中并留下-->: 关于c#-VisualStudio201

c# - 在没有标准 (Obj sender, EventArgs args) 签名的情况下创建事件处理程序委托(delegate)有多错误?

我了解使用标准MS事件处理程序委托(delegate)签名的好处,因为它允许您轻松扩展通过事件传递的信息,而不会破坏任何基于旧委托(delegate)签名的旧关系。我想知道在实践中人们多久遵守一次这条规则?假设我有一个像这样的简单事件publiceventNameChangedHandlerNameChanged;publicdelegatevoidNameChangedHandler(Objectsender,stringoldName,stringnewName);这是一个简单的事件,我几乎肯定我需要从NameChanged事件中知道的唯一参数是名称更改的对象、旧名称和新名称。那么

c# - 在 SelectSingleNode : Retrieving individual element from XML if it's present 中使用 XPath

我的XML看起来像:onetwothree.....maybemoreItemshere.一些单独的Item可能存在也可能不存在。假设我想检索元素两个如果它存在。我尝试了以下XPath(在C#中)。XMLNodenode=myXMLdoc.SelectSingleNode("/itemSet[Item='two']")---如果Itemtwo存在,则它只返回第一个元素one。也许这个查询只是指向itemSet中的第一个元素,如果它在某个地方有一个值为2的Item作为子元素。这种解释正确吗?所以我尝试了:XMLNodenode=myXMLdoc.SelectSingleNode("/it

C#/WPF : Binding Combobox ItemSource in Datagrid to element outside of the DataContext

我想做以下事情:publicListPreLoadedUserList{get;set;}publicListSomeDataRowList{get;set;}publicclassUsers{publicintAge{get;set;}publicstringName{get;set;}}publicclassSomeDataRowList{publicintUserAge{get;set;}现在我的(WPF工具包)DataGrid看起来像这样:现在我的问题是,PreLoadedUserList在ItemSource(SomeDataRowList)之外,我不知道如何绑定(bind)

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