草庐IT

run_list

全部标签

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

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

c# - For 循环导致 Task.Run 或 Task.Start 溢出

遇到问题,希望有人能帮我解决。我尝试在循环中启动4个任务,但我收到ArgumentOutOfRangeException:for(inti=0;i.Run(()=>GetData(i,plcPool[i]));}循环因为i=4而溢出如果我在没有循环的情况下启动任务,它们会毫无问题地运行:tasks[0]=Task.Run(()=>GetData(0,plcPool[0]));tasks[1]=Task.Run(()=>GetData(1,plcPool[1]));tasks[2]=Task.Run(()=>GetData(2,plcPool[2]));tasks[3]=Task.Run

c# - 在 c# 中设置/扩展 List<T> 长度

给定一个List在c#中有没有办法扩展它(在其能力范围内)并将新元素设置为null?我想要类似memset的东西.我不是在这里寻找糖,我想要快速代码。我知道在C中,操作可以在每个条目1-3个asm操作中完成。我找到的最佳解决方案是this:list.AddRange(Enumerable.Repeat(null,count-list.Count));但是这是c#3.0(首选我当前的代码使用:while(list.Count所以这是时间成本的起点。motivationforthis是我需要设置第n个元素,即使它在旧计数之后。 最佳答案

c# - 检查两个 List<T> 是否相等的最快方法

我有两个列表ListA和ListB两者都有1000条记录。Emp是Employee类的一个对象。下面是我的Employee类publicclassEmployee{intID=0;stringName=String.Empty;stringDept=String.Empty;stringAddress=String.Empty;intAge=0;stringEmail=String.Empty;}我想验证两个列表是否相等。Emp对象可以按不同的顺序放置。此外,可能有多个Emp对象在两个列表中具有完全相同的信息。我也必须验证这些。我尝试对列表进行排序并使用SequenceEqual进行比

c# - 等待新任务 <T>( ... ) : Task does not run?

问题的延续here:在上述问题中,我有以下函数返回一个任务类型的对象(用于增量测试目的):privatestaticTaskGetInstance(){returnnewTask((Func>)(async()=>{awaitSimpleMessage.ShowAsync("TEST");returnnewobject();}));}当我调用awaitGetInstance();时,该函数被调用(并且我假设任务已返回,因为没有抛出异常)但任务就在那里。我只能猜测我做错了。我不希望此函数返回一个已经在运行的任务(即IMPERATIVE).如何异步运行此函数返回的任务?

c# - 为什么单击树抛出 'System.Windows.Documents.Run' 不是 Visual 或 Visual3D 的 InvalidOperationException?

有时右键单击treeviewitem会导致未处理的InvalidOperationException。在后面的代码中,我选择右键单击的行:staticTreeViewItemVisualUpwardSearch(DependencyObjectsource){while(source!=null&&!(sourceisTreeViewItem))source=VisualTreeHelper.GetParent(source);returnsourceasTreeViewItem;}privatevoidOnPreviewMouseRightButtonDown(objectsende

c# - List.ForEach 在技术上是 LINQ 的一部分吗?

目前对我来说,LINQ只是一个松散的、无定形的概念云,通常与数据访问有关,但也与lambda表达式、委托(delegate)、匿名函数和扩展方法结合,它是关于字符串和集合操作的,所以我想把它固定下来。当我写下面的代码时,我能说我在“使用LINQ”吗?Listwords=newList(){"one","two","three"};words.ForEach(word=>Console.WriteLine(word.ToUpper()));例如“ForEach”方法被广泛称为“LINQ方法”,但它的家在System.Collections.Generic.List而不是System.Li

c# - 当 T 未知时,如何使用反射执行 List<object>.Cast<T>

我已经尝试了好几个小时了,这就是我所能做到的了varcastItems=typeof(Enumerable).GetMethod("Cast").MakeGenericMethod(newType[]{targetType}).Invoke(null,newobject[]{items});这让我回来了System.Linq.Enumerable+d__aa`1[MyObjectType]而我需要(对于我的ViewData)作为通用列表,即System.Collections.Generic.List`1[MyObjectType]任何指针都会很棒 最佳答案

c# - 将 List.FindAll() 与 lambda 一起使用的 VB.NET 语法是什么?

在C#中,我一直在通用列表中执行FindAll,如下所示:Listtlist=list.FindAll(p=>p.parid==titem.catid);两个问题,这是执行此类操作的合适方式吗?我如何将其转换为VB.Net 最佳答案 首先,是的,这是执行此操作的适当方法,其次:DimtlistAsList(Ofgroup.category)_=list.FindAll(Function(p)p.parid=titem.catid) 关于c#-将List.FindAll()与lambda一

c# - C# List<char[]> 是否分配在连续内存中?

如果我声明一个char数组列表,它们是分配在连续的内存中,还是.NET创建一个链接列表?如果它不是连续的,有没有办法声明一个连续的char数组列表?char数组的大小是预先知道的并且是固定的(它们的大小都相同)。 最佳答案 是的,但不是您想要的方式。List保证它的元素是连续存储的。数组是引用类型,因此引用连续存储为List保证。但是,数组本身是单独分配的,它们的存储位置与列表无关。它只关心它的元素,即引用。如果您需要,那么您应该只使用一个大数组并维护边界数据。编辑:根据您的评论:Theinnerarraysarealways9ch