草庐IT

delegated-properties

全部标签

c# - 从一个委托(delegate)转换为另一个委托(delegate)。伪 Actor

我们正在使用IoC并使用它公开我们的日志记录。我们正在使用Common.Logging并且我已经为Common.Logging.FormatMessageHandler编写了一个匹配的委托(delegate),但我不知道如何从我们的委托(delegate)版本转换为Common.Loggingapi所期望的。这个问题看起来很相似,但我不明白如何从我实现的类型转换为我想调用的已知类型。Dynamicallycastingonetypeofdelegatetoanother这是我的委托(delegate)签名:publicdelegatestringFormatMessageHandler

c# - 比较委托(delegate) Action<T>

请随意质疑我的理智。我需要确定一个Action对比Action是原始实例。我拥有的是一个带有类变量的类protectedActionMessageCallback=null;当我的abstractclassMessage是通过抽象方法创建的,我强制“他们”初始化MessageCallBack。此MessageCallback被添加到IList>.此列表中定义的每个操作都可以不同。现在,我想要做的是从列表中删除一个特定的操作,但我尝试比较它时失败了。以下是我最后一次尝试设置的示例:publicvoidUnsubscribe(ActionmessageCallback){varmessag

c# - ASP.NET 用户控件 : Page_Load fires before property is set

这让我发疯。我有一个非常简单的用户控件:publicint?ImageId{set;get;}protectedvoidPage_Load(objectsender,EventArgse){...dosomethingwithImageId...}然后我将此控件放在UpdatePanel中带有ListView的页面上:'ID="cipPreview"runat="server"/>问题是Page_Load在ASP.NET设置ImageId之前触发。在调试器的帮助下,我发现由于某种原因,MyControl中的ImageId已设置,但它仅在Page_Load完成处理后才会发生。怎么了?

c# - 为什么不同的传委托(delegate)方式在性能上会有如此大的差异?

我试图比较在C#中将委托(delegate)传递给函数的三种不同方式——通过lambda、通过委托(delegate)和通过直接引用。真正让我吃惊的是直接引用方法(即ComputeStringFunctionViaFunc(object[i].ToString))比其他方法慢六倍。有谁知道这是为什么吗?完整代码如下:usingSystem;usingSystem.Collections.Generic;usingSystem.Linq;usingSystem.Text;usingSystem.Runtime.CompilerServices;namespaceFunctionInvoc

c# - Settings.Default.<property> 始终返回默认值而不是持久存储(XML 文件)中的值

我最近用C#(.Net2.0)编写了一个DLL,其中包含一个需要IP地址的类。我的一位同事更改了类以从“.dll.config”(XML)文件中检索IP——这显然是由他创建的“应用程序设置”文件(Settings1.settings)自动生成的。这样做的好处是允许最终用户随意更改XML/config文件中的IP地址。不幸的是,当我从树中checkout他的代码并尝试编译(或使用)这个新代码时,任何调用这个DLL的应用程序只获得默认值,而不是文件中的值。调用配置文件的构造函数如下所示:publicclassform:System.Windows.Forms.Form{publicform

c# - 异步方法和异步委托(delegate)

C#3.0简述说异步方法和异步委托(delegate)看起来很相似,但行为却大不相同.这是书中关于两者的说法。异步方法很少或从不阻塞任何线程。Begin方法可能不会立即返回给调用者。商定的协议(protocol),不支持C#语言。异步委托(delegate)可以阻止任何时间长度BeginInvoke立即返回给调用者。内置编译器支持。书上还说,异步方法的目的是让很多任务在很少的线程上运行;异步委托(delegate)的目的是与调用者并行执行任务。当我通过反射器查看System.IO.Stream类中的BeginRead()方法时,它使用委托(delegate)并调用BeginInvoke

c# - 它有什么区别 - 使用 Task.Run 运行 'async' Action 委托(delegate)(与默认 Action 委托(delegate)相比)?

我正在努力了解async/await并认为我确实了解有关用法的一些事情。但仍然不太清楚在下面的场景中实际好处是什么。查看Task.Run用法。第一种方法使用普通委托(delegate)并使用Thread.Sleep,但第二种方法使用“异步”委托(delegate)和Task.Delay。我的问题是:这对这个方法有什么影响(或没有影响)?该方法本身是一个异步方法。该代码正在创建一个单独的线程(通过Task.Run),并且该线程除了执行该委托(delegate)之外别无他法。因此,即使它在Task.Delay上产生等待,在这种情况下有什么用,因为线程无论如何都是一个孤立的线程,不用于任何其

c# - 如何接受任何委托(delegate)作为参数

我有兴趣编写一个方法,该方法可以接受另一个方法作为参数,但不想被锁定到特定的签名中-因为我不关心这个。我只对方法在调用时是否抛出异常感兴趣。.NETFramework中是否有允许我接受任何委托(delegate)作为参数的结构?例如,以下所有调用都应该有效(无需使用重载!):DoesItThrowException(doSomething(arg));DoesItThrowException(doSomethingElse(arg1,arg2,arg3,arg4,arg5));DoesItThrowException(doNothing()); 最佳答案

c# - .Net 4 : How to reference a dynamic object with property named "return"

我正在从公共(public)api检索json并使用JsonFx将其转换为动态对象。JsonFx.Json.JsonReaderreader=newJsonFx.Json.JsonReader();dynamicresponse=reader.Read(jsonAsString);json包含一个名为return的属性。例如{"result":"success","return":{"high":{"value":"3.85001","value_int":"385001","display":"3.85001\u00a0\u20ac","currency":"EUR"}}JsonFx

c# - EF lambda : The Include path expression must refer to a navigation property

这个问题在这里已经有了答案:EF:Includewithwhereclause[duplicate](5个答案)关闭5年前。这是我的表达:Coursecourse=db.Courses.Include(i=>i.Modules.Where(m=>m.IsDeleted==false).Select(s=>s.Chapters.Where(c=>c.IsDeleted==false))).Include(i=>i.Lab).Single(x=>x.Id==id);我知道原因是模块部分的Where(m=>m.IsDeleted==false),但为什么会导致错误?更重要的是,我该如何修复它