我有一个应用程序(C#、WPF)可以显示许多财务图表以及来自服务器的实时数据流。在内存中收集的数据可能会变得有点大,我不想在磁盘上保留任何数据。由于历史数据本身不会改变,只会被添加,以某种压缩格式保留该数据(存储在集合对象中)是否有意义?是否有可能,如果可以,有人可以推荐一个好的做法吗?更新关于性能和权衡的一些注意事项:我知道压缩会增加访问数据的延迟,但是,用户只需要对到达的新数据进行快速更新。当访问已经呈现的数据(例如,研究或重新呈现它)时,他不需要快速响应。 最佳答案 压缩和解压缩会使您的应用程序变慢,因此对于性能(速度)而言,
我意识到我总是按照索引(使用常量)返回的顺序读取我的字段。因此,据我所知,我的代码已经与CommandBehavior.SequentialAccess兼容。如果我打开它会有什么好处吗?DataReader已经是只向前的,只读的,这是真正的性能提升吗? 最佳答案 它的主要用途是当您读取非常大的CLOB(nvarchar(max)等)或BLOB(varbinary(max))字段时。在默认用法中,它会先缓冲整行数据,然后再让您靠近它——这可能意味着它必须为任何BLOB/CLOB字段分配一个大缓冲区。使用顺序模式时,不会缓冲行;您可以对
是的,我正在使用分析器(ANTS)。但在微观层面,它不能告诉你如何解决你的问题。我现在正处于微优化阶段。例如,我正在对此进行分析:for(intx=0;xANTS显示y循环线花费了大量时间。我认为这是因为它必须不断调用Heightgetter。所以我创建了一个本地intheight=Height;在循环之前,并使内部循环检查y.这实际上使性能变差了!ANTS现在告诉我x-loop-line有问题。嗯?这应该是微不足道的,它是外循环!最终我有了一个启示——也许使用外循环绑定(bind)的属性和内循环绑定(bind)的本地使得CLR经常在“本地”缓存和“this-pointer”缓存之间跳
我已经看到它出现在代码中的几个地方,从来没有解释,只是在它上面的一个神秘注释(声明和执行包括上下文的概念。它只是运行SqlCommand的标准过程)://SqlCommandcmd=newSqlCommand();//cmd.ExecuteReader();//Readofftheresults//Cancelthecommand.Thisimprovesquerytime.cmd.Cancel();基本上,在完成查询后,它会返回并取消它,声称性能有所提升。我想您可能会在它消失并释放XmlReader时取回一些内存,但通常它无论如何都会超出范围。我以前从来没有为它烦恼过,但它终于出现在
在.NET之前的世界里,我总是假设int比byte快,因为这是处理器的工作方式。现在重要的是使用int的习惯,即使字节可以工作,例如当字节是存储在数据库中的内容时问题:.NET如何从性能/内存的角度处理字节类型和int。更新:感谢您的输入。不幸的是,没有人真正回答这个问题。.NET如何处理字节与整数。如果性能没有差异,那么我喜欢chills42的说法:用于算术的int二进制字节我将继续这样做。 最佳答案 你的.NET之前的假设是错误的——一直有很多计算机系统围绕着它,虽然名义上是“字节可寻址的”,但必须通过读取一个完整的单词来设置一
我有一个包含方法集合的类,我想知道使用方法而不是属性是否有任何性能提升?一些方法相当复杂,但基本上返回一个IEnumerable对象集合,而其他方法则是简单的返回值。Where(x=>x.property=="comparison")Linq查询。示例方法:publicIEnumerableActivePens()=>Pens.Where(x=>x.Status=="Active");属性:publicIEnumerableActivePens=>Pens.Where(x=>x.Status=="Active");将它们标记为属性或方法会更好吗? 最佳答案
我尝试在我的C#4.0Windows应用程序中将datagridview数据导出到excel文件。我们使用了Microsoft.Office.Interop.Exceldll版本12.0.0.0。一切都很好很好。但是当我尝试导出超过1000条datagridview记录时,它花费的时间太长了时间。我怎样才能提高性能。请参阅下面的Excel帮助程序代码。usingSystem;usingSystem.Collections.Generic;usingSystem.Linq;usingSystem.Text;usingSystem.IO;usingMicrosoft.Office.Inte
在下面的方法中,我发送了一个Action枚举,并希望返回一个调用Action的ICommand数组。包装那些Action(relayCommand需要)。问题是,如果我在foreach(甚至是for循环)中执行此操作,我得到的命令总是执行参数中传递的第一个操作。publicstaticICommand[]CreateCommands(IEnumerableactions){Listcommands=newList();Action[]actionArray=actions.ToArray();//works//commands.Add(newRelayCommand(o=>{actio
好吧,我们都知道反射的性能比“新建”一个类实例要低很多倍,而且在很多情况下这很好,具体取决于应用程序的要求。问题:我们如何使用后期绑定(bind)(反射)策略创建高性能.NET类。我有一个现有要求,要求使用反射(CreateInstance)创建类实例,但性能至关重要。在我的情况下,我正在为我们应用程序中的每个传入SMS消息创建实例。在生产期间,这很容易每天超过一百万。我想听听并分享一些关于如何在不直接引用代码中的类的情况下创建.NET类的想法,例如使用反射。我也在想是否有办法以某种方式缓存可以缩短“创建”时间的类工厂 最佳答案 一
问候。为了分析Python代码的性能,下面的代码可以做到吗?importtimeto=time.clock();x=[];foriinrange(0,4):x.append(i*0.1);tend=time.clock();print(tend-to);to=time.clock();y=list(map(lambdax:x*0.1,list(range(0,4))));tend=time.clock();print(tend-to);计时器显示不一致。但是有时候,两个计时器的结果也会显示出不一致的不一致(有时第一个计时器更快,有时是第二个计时器,尽管第一个计时器往往更快)。一些输出:4.63