草庐IT

temp_double

全部标签

c# - 整数与 double 算术性能?

我正在编写一个C#类来使用整数执行2D可分离卷积,以获得比双对应更好的性能。问题是我没有获得真正的性能提升。这是X过滤器代码(它对int和double情况都有效):foreach(pixel){intvalue=0;for(intk=0;k在整数情况下,“value”、“InputImage”和“tempImage”是“int”、“Image”和“Image”类型。在双大小写“value”中,“InputImage”和“tempImage”是“double”、“Image”和“Image”类型。(filterValues在每种情况下都是int[])(图像类是外部dll的一部分。它应该类

c# - 为什么静态分析会忽略 double <= 和 >= 要求?

我有一个使用.NET代码契约的非常简单的类:publicclassContractSquareRoot{//////MakesyourlifemucheasierbycallingMath.Sqrtforyou.Ain'tthatpeachy.//////Thevaluetocalculatethesquarerootfrom.Nonegatives!///Thesquarerootofthegivenvalue.Obviouslyalways>0.publicdoubleCalculateSquareRoot(doublevalue){Contract.Requires(0());d

c# - 像这样将 double 与 0 进行比较是错误的 : doubleVariable==0?

这样做可以吗?doubledoubleVariable=0.0;if(doubleVariable==0){...}或者此代码会遇到潜在的舍入问题? 最佳答案 不,如果您只与0进行比较,这是完全合法的,因为比较的右侧将自动转换为double。另一方面,如果你在哪里与==0.10000001进行比较,它将产生所有舍入误差你最好还是在这里阅读关于floatto0比较的讨论:Isitsafetocheckfloatingpointvaluesforequalityto0?此外,此讨论还提供了有关float奇怪精度问题的信息:Whyther

c# - DirectoryExists ("c:temp\\foo") 当目录不存在时返回真!

好吧,我被一些看起来有点奇怪的东西咬住了。我意识到我没有正确格式化路径名是我的错误,但我希望以下测试返回false,尤其是因为该文件夹不存在。DirectoryExists("C:temp\\foo")但实际上,即使目录不存在,它也会返回true!代码应该是DirectoryExists("C:\\temp\\foo")有人可以向我解释为什么我从第一个版本中得到误报吗?我希望它可能返回false或抛出异常,但不会返回true。 最佳答案 此API运行正常,但在您第一次遇到此行为时通常会出现错误。省略卷号后的\具有特殊语义。它将用传递

c# - Double.Parse 没有给出正确的结果

我在两个应用程序中尝试这个;一个控制台应用程序和一个网络应用程序。在控制台应用程序中,当我尝试Double.Parse("0.5")它给出0.5或Double.Parse(".5")给出0.5但是在Web应用程序中Double.Parse("0.5")给出5.0而Double.Parse(".5")给出异常Inputstringwasnotinacorrectformat.谁能告诉我如何解决网络应用程序中的问题? 最佳答案 您应该提供文化信息,否则它会使用来自当前运行线程的文化信息。试试这个:CultureInfocultureIn

c# - 为什么 IsNan 是 Double 类的静态方法而不是实例属性?

问题在标题里,为什么:returndouble.IsNaN(0.6d)&&double.IsNaN(x);代替return(0.6d).IsNaN&&x.IsNaN;我问是因为在实现具有与NaN相同含义的特殊值的自定义结构时,我倾向于选择第二种。此外,属性的性能通常更好,因为它避免了复制堆栈上的结构来调用IsNaN静态方法(而且由于我的属性不是虚拟的,所以没有自动装箱的风险)。诚然,这对于内置类型来说并不是真正的问题,因为JIT可以轻松地对其进行优化。我现在最好的猜测是,由于您不能在double类中同时拥有同名的属性和静态方法,因此他们更喜欢受java启发的语法。(事实上​​,您可以同

c# - 如何找到列表 <double> 的模式?

我有一个列表:Listfinal=newList();final.Add(1);final.Add(2);final.Add(3);我可以使用什么样的方法来找到这个列表的模式?此外,如果有两种模式,该函数将返回两者中较小的一个。 最佳答案 int?modeValue=final.GroupBy(x=>x).OrderByDescending(x=>x.Count()).ThenBy(x=>x.Key).Select(x=>(int?)x.Key).FirstOrDefault();它所需要的只是一些组合的LINQ操作。您也可以用查询

c# - 调试/ Release模式下的浮点/ double

C#/.NET浮点运算在Debug模式和Release模式之间的精度是否不同? 最佳答案 它们确实可以不同。根据CLRECMA规范:Storagelocationsforfloating-pointnumbers(statics,arrayelements,andfieldsofclasses)areoffixedsize.Thesupportedstoragesizesarefloat32andfloat64.Everywhereelse(ontheevaluationstack,asarguments,asreturntypes

c# - .NET “double” 算法是否独立于平台/体系结构?

如果我在Windows(x86和x64)下的.NET上运行涉及System.Double的复杂计算,然后在Mono(Linux、Unix等)上运行,绝对有保证以在所有情况下得到完全相同的结果,或者规范是否允许在计算中有一些回旋余地? 最佳答案 来自MSDNInaddition,thelossofprecisionthatresultsfromarithmetic,assignment,andparsingoperationswithDoublevaluesmaydifferbyplatform.Forexample,theresul

c# - 要比较 double 和十进制,我应该将 double 转换为十进制还是将十进制转换为 double ?

我需要比较两个值。一个值是price这代表某物的当前价格等等decimal因为您实际上可以按照这个价格买卖东西。另一个值是estimatedPrice这是数学计算的结果,所以double因为它只是estimation你实际上不能通过这个esitmatedPrice做任何“操作”现在我想买如果price.那么我应该将price转换为double还是将estimatedPrice转换为decimal?我知道在转换后我会得到“略微不同”的数字,但似乎我没有其他选择。 最佳答案 这取决于数据。十进制具有更高的精度;double的范围更大。如