草庐IT

Action_send

全部标签

c# - SynchronizationContext.Send 和 SynchronizationContext.Post 有什么区别?

感谢JeremyMiller在FunctionalProgrammingForEveryday.NETDevelopment中的出色工作,我有一个工作命令执行器,它可以做我想做的一切(在线程池上做繁重的工作,将结果或错误发送回同步上下文,甚至将进度发送回同步上下文),但我无法解释为什么使用SynchronizationContext.Send来自线程池和Synchronization.Post从Func传递到执行繁重工作的方法。我已经多次阅读文档,但我无法直觉了解其中的区别。我应该从一个名为Send和一个名为Post的事实中得到什么?我感觉到神奇之处在于Send“启动一个同步请求”和P

c# - 为什么调用不明确? 'Task.Run(Action)' 和 'Task.Run(Func<Task>)'

考虑以下代码:publicvoidCacheData(){Task.Run((Action)CacheExternalData);Task.Run(()=>CacheExternalData());Task.Run(CacheExternalDataTask);Task.Run(CacheExternalData);}publicTaskCacheExternalDataTask(){//LongrunningcodereturnTask.FromResult("Data");}publicvoidCacheExternalData(){//Longrunningcode}为什么Tas

c# - Action(arg) 和 Action.Invoke(arg) 之间的区别

staticvoidMain(){ActionmyAction=SomeMethod;myAction("HelloWorld");myAction.Invoke("HelloWorld");}staticvoidSomeMethod(stringsomeString){Console.WriteLine(someString);}上面的输出是:HelloWorldHelloWorld现在我的问题是这两种调用Action的方式有什么区别(如果有)?一个比另一个好吗?什么时候用哪个?谢谢 最佳答案 所有委托(delegate)类型都有

c# - 无法将 Action<object, EventArgs> 转换为 EventHandler?

我正在连接一个事件以使用需要在触发后自行删除的lambda。我无法通过将lambda内联到+=事件(没有可访问的变量用于删除事件)来做到这一点,所以我设置了一个Action变量并将lambda移到那里。主要错误是它无法转换Action到事件处理程序。我认为lambda表达式可以隐式转换为事件处理程序,为什么这行不通? 最佳答案 Actiona=(o,ea)=>{};EventHandlere=a.Invoke; 关于c#-无法将Action转换为EventHandler?,我们在Stac

c# - 在 ASP.NET MVC 4 C# Code First 中指定 ON DELETE NO ACTION

如何在我的模型设计中指定ONDELETENOACTION外键约束?目前,我有:publicclassStatus{[Required]publicintStatusId{get;set;}[Required][DisplayName("Status")]publicstringName{get;set;}}publicclassRestuarant{publicintRestaurantId{get;set;}[Required]publicstringName{get;set;}[Required][EmailAddress]publicstringEmail{get;set;}[R

C# HttpWebRequest 底层连接被关闭 : An unexpected error occurred on a send

我一直在谷歌搜索并尝试所有我能找到或想到的解决方案。我尝试加载的站点运行的是TLS1.2,我尝试测试的其他几个站点也是如此,以确保它不是TLS1.2问题。其他网站加载正常。byte[]buffer=Encoding.ASCII.GetBytes("mod=www&ssl=1&dest=account_settings.ws"+"&username="+username.Replace("","20%")+"&password="+password.Replace("","20%"));ServicePointManager.MaxServicePointIdleTime=1000;Se

c# - 参数 Action<T1, T2, T3> 其中 T3 可选

我有以下代码:publicstaticMyMethod(){...DosomethingProtectedMethod(param1,param2);...Dosomething}protectedstaticvoidProtectedMethod(IEnumerableparam1,stringparam2,intparam3=1){...Dosomething}注意可选的param3参数。现在由于很多原因,我需要将MyMethod方法的代码提取到它自己的类中,但是我无法用它提取ProtectedMethod,因为所有的类都继承自这个类,我需要保持小的变化,孤立。所以我想我可以在新类

c# - Action 参数命名

使用提供的默认路由,我不得不将我的参数命名为“id”。这对我的很多ControllerActions都很好,但我想在某些地方使用一些更好的变量命名。有没有我可以使用的某种属性,以便我可以在我的Action签名中包含更有意义的变量名称?//DefaultRoute:routes.MapRoute("Default",//Routename"{controller}/{action}/{id}",//URLwithparametersnew{controller="Home",action="Index",id=""}//Parameterdefaults);//ActionSignatu

c# - 当 Action 重载可用时,为异步 lambda 函数显式使用 Func<Task>

阅读this关于C#5的异步/等待的一些陷阱的博客文章。它在Gotcha#4中提到了一些非常深刻的东西,这是我以前没有想到的。简而言之,它涵盖了这样一种情况:您有一个方法有两个重载,一个接受Action。一个需要Func(例如Task.Run)。这个问题的根源在于asyncvoid方法应该只用于事件处理程序,然后帖子继续描述以下场景-当像下面这样的lambda函数可以编译为Func时,编译器会推断出什么?和一个Action:Task.Run(async()=>{awaitTask.Delay(1000);});因为Task.Run有两个Task.Run(Func)的签名和Task.Ru

c# - 有没有一种优雅的方式来重复一个 Action ?

在C#中,使用.NETFramework4,是否有一种优雅的方法可以将相同的操作重复确定的次数?例如,而不是:intrepeat=10;for(inti=0;i我想写这样的东西:ActiontoRepeat=()=>{Console.WriteLine("HelloWorld.");this.DoSomeStuff();};toRepeat.Repeat(10);或:Enumerable.Repeat(10,()=>{Console.WriteLine("HelloWorld.");this.DoSomeStuff();});我知道我可以为第一个示例创建我自己的扩展方法,但是否存在可以