jjzjj

double_bits

全部标签

c# - 将具有指数表示法的数字从字符串转换为 double 或十进制

有没有一种快速的方法可以将指数表示法的数字(例如:“0.5e10”或“-5e20”)转换为十进制或double?更新:我找到了ParseaNumberfromExponentialNotation但这些示例对我不起作用,除非我指定了一种文化。解决方法:doubletest=double.Parse("1.50E-15",CultureInfo.InvariantCulture); 最佳答案 如果您的文化使用.作为小数分隔符,则只需double.Parse("1.50E-15")即可。如果您的文化使用其他东西(例如、),或者您想确保您

c# - 在C#中将350M数字快速加载到double[]数组中

我将在二进制文件中存储350M预先计算的double,并在我的dll启动时将它们加载到内存中。是否有任何内置方法可以并行加载它,或者我应该自己将数据拆分为多个文件并自己处理多个线程?回答评论:我将在足够强大的机器上运行这个dll,很可能只在64位机器上运行。因为对我的号码的所有访问都将通过属性进行,所以我可以将我的号码存储在多个数组中。[更新]谢谢大家的回答!我期待着在不同的盒子上进行大量的基准测试。关于需求:我想加速一个非常慢的计算,所以我打算预计算一个网格,将它加载到内存中,然后进行插值。 最佳答案 好吧,我做了一个小测试,我肯

c# - 格式化具有最小小数位数的 double 类型

我需要格式化double类型,使其具有最少两位小数但不限制最大小数位数:5->"5.00"5.5->"5.50"5.55->"5.55"5.555->"5.555"5.5555->"5.5555"我怎样才能实现它? 最佳答案 您可以对非可选数字使用0格式说明符,对可选数字使用#:n.ToString("0.00###")此示例最多提供五位小数,您可以根据需要添加更多#位置。 关于c#-格式化具有最小小数位数的double类型,我们在StackOverflow上找到一个类似的问题:

c# - 从 double 转换为 int 的最佳(最安全)方法

我很好奇将double转换为整数的最佳方法。运行时安全是我在这里的主要关注点(它不一定是最快的方法,但这是我的次要关注点)。我在下面留下了一些我可以想出的选项。任何人都可以权衡哪种是最佳实践吗?有没有我没有列出的更好的方法来完成这个?doublefoo=1;intbar;//Option1boolparsed=Int32.TryParse(foo.ToString(),outbar);if(parsed){//...}//Option2bar=Convert.ToInt32(foo);//Option3if(fooInt32.MinValue){bar=(Int32)foo;}

c# - 在 C# 中截断 double 值的位数

如何在C#中截断double值的前导数字,我试过Math.Round(doublevalue,2)但没有给出要求的结果。而且我在数学课上没有找到任何其他方法。例如,我的值为12.123456789,我只需要12.12。 最佳答案 编辑:有人指出,这些方法舍入值而不是截断。很难真正截断double值,因为它实际上不是在正确的基数中......但截断decimal值更可行。您应该使用适当的格式字符串,custom或standard,例如stringx=d.ToString("0.00");或stringx=d.ToString("F2"

C# Double.ToString() 性能问题

我有以下方法将double组转换为List:staticDestTest(Sources){Destd=newDest();if(s.A24!=null){double[]dd=s.A24;intcnt=dd.Length;Listlst=newList();for(inti=0;i根据我的基准测试,在循环中执行List.Add()似乎是最快的方法,超过了所有各种LINQ和Convert技巧。这真的很慢。一百万次调用需要2400毫秒(任何CPU,首选64位)。所以我正在尝试各种方法来让它更快。假设我显然无法缓存源或目标列表等。所以无论如何,我在这里偶然发现了一些奇怪的东西......如

c# - .NET 的 Double.ToString 方法中的两次错误

在数学上,考虑这个问题的有理数8725724278030350/2**48哪里**分母中表示求幂,即分母为2到48权力。(分数不是最低的,可以减少2。)这个数字是正好可表示为System.Double.它的十进制扩展是31.0000000000000'49'73799150320701301097869873046875(exact)其中撇号不代表丢失的数字,而仅标记四舍五入为的边界。15分别17数字是要执行的。请注意以下事项:如果此数字四舍五入为15位,结果将为31(后跟13个0s)因为接下来的数字(49...)以4开头(意思是向下舍入)。但是如果数字先四舍五入到17位,然后再四舍五

c# - 将对象转换为 Double 的最快方法?

将对象转换为double的最快方法是什么?我现在正在处理一段代码,上面写着:vard=double.TryParse(o.ToString(),outd);//oistheObject...首先想到的是将其重写为vard=Convert.ToDouble(o);但这实际上会更快吗?编辑:除了运行配置文件(顺便说一下,我向任何开发人员强烈推荐JetBrainsdotTrace),我还运行了Reflector,这帮助我来到使用以下内容(或多或少是代码的相关部分):if(oisIConvertible){d=((IConvertible)o).ToDouble(null);}else{d=0

c# - 为什么 Double.TryParse() 对于包含 double.MaxValue 或 double.MinValue 的字符串返回 false?

我有一个静态方法,它接受一个字符串作为输入,如果该字符串代表一个数字,则返回原始输入字符串。如果字符串不代表数字,则处理输入字符串并返回转换后的字符串。我在写测试用例。我正在尝试验证包含double.MinValue或double.MaxValue的输入字符串是否原样返回。我已经阅读了许多论坛,包括StackOverflow,并提出了以下逻辑:stringdoubleMax=double.MaxValue.ToString();doubled;CultureInfocultureInfo=newCultureInfo("en-US",true);if(Double.TryParse(d

c# - LINQ to SQL 值介于两个 double 值之间

我正在使用LINQtoSQL查询我的数据库,我有一个与此非常相似的查询:varresult=fromdb.MyTable.Where(d=>(double)d.Price>=minValue)我需要where子句有一个d.Proce>=minValue,和d.Price=(类似于T-SQLBETWEEN子句)。我该怎么做? 最佳答案 这个怎么样:varresult=fromdb.MyTable.Where(d=>(double)d.Price>=minValue&&(double)d.Price