草庐IT

im2double

全部标签

c# - 为什么编译器决定 2.3 是 double 而不是十进制?

为什么编译器认为2.3是double的,所以这段代码无法编译:decimalx;x=2.3;//Compilationerror-cannotconvertdoubletodecimal.x=(decimal)2.3//O.k.为什么编译器不这样认为:他要取小数,他给我一个可以是小数的值,所以是小数!为什么这不会出现编译错误:shortx;x=23;//O.K.谁说23不是整数? 最佳答案 这里有很多问题。让我们把它们分解成小问题。Whyistheliteral2.3oftypedoubleratherthandecimal?历史原

c# - 获取 double[,] 矩形数组的 double[] 行数组

假设你有一个像这样的数组:double[,]rectArray=newdouble[10,3];现在您希望第四行作为3个元素的double[]数组而无需执行以下操作:double[]fourthRow=newdouble[]{rectArray[3,0],rectArray[3,1],rectArray[3,2]};有可能吗?甚至使用Marshal.Something方法?谢谢! 最佳答案 您可以使用Buffer.BlockCopy方法:constintd1=10;constintd2=3;constintdoubleSize=8;

c# - 为什么System.Timers.Timer.Interval 的数据类型是double?

这是一个有点学术性的问题,因为我正在努力思考Microsoft使用double作为Interval属性的数据类型背后的想法!首先来自MDSNInterval是Elapsed事件之间的时间,以毫秒为单位;我会将其解释为离散数字,那么为什么要使用double呢?肯定int或long更有意义!?Interval可以支持5.768585(5.768585毫秒)这样的值吗?尤其是当人们认为System.Timers.Timer的精度远不及亚毫秒时...Mostaccuratetimerin.NET?对我来说似乎有点愚蠢..也许我错过了什么! 最佳答案

c# - 对其中包含 NaN 的 Double 数组进行排序

这更像是一个“你能解释一下吗”类型的问题,而不是其他任何问题。我在工作中遇到一个问题,我们在表格中使用NaN值,但是当表格被排序时,它以一种非常奇怪的方式出现。我认为NaN搞砸了一些东西,所以我编写了一个测试应用程序来查看这是否属实。这就是我所做的。staticvoidMain(string[]args){double[]someArray={4.0,2.0,double.NaN,1.0,5.0,3.0,double.NaN,10.0,9.0,8.0};foreach(doubledbinsomeArray){Console.WriteLine(db);}Array.Sort(some

c# - 如何使用 NUnit 中的指定容差比较 double ?

我目前正在为属于我的产品的DLL开发一个C#P/invoke包装器。我没有使用C#的经验,这是我完成的第一个重要的C#编码。我敏锐地意识到,我对这门语言的要点和习语缺乏很多了解。我的问题涉及我正在使用NUnit编写的单元测试。我需要比较double[]变量的值。如果我使用Assert.AreEqual(...)来执行此操作,则会比较这些值是否完全相等。但是,我想比较一个公差。有AreEqual()重载标量实数值,允许delta参数。但是,我一直无法找到数组的等效项。我错过了一些明显的东西吗?目前我已经用下面的代码解决了这个问题:classAssert:NUnit.Framework.A

c# - 为什么 List<double> 显式转换为 IEnumerable<object> 会抛出异常?

根据这个MSDNreferenceIEnumerable是协变的,这可以将对象列表隐式转换为可枚举对象:IEnumerablestrings=newList();IEnumerableobjects=strings;在我自己的代码中,我写了一行代码,当列表的项目类型是Point类时,它可以完美运行(Point是一个简单的类,具有三个双x、y、z属性):varobjects=(IEnumerable)dataModel.Value;//herepropertyValueisalistthatcouldbeofanytype.但是当列表的项类型为double时,上面的代码返回以下异常:Un

c# - 将 nullable double 设置为 null 有什么问题?

这个问题在这里已经有了答案:关闭12年前。PossibleDuplicates:Whycan'tIsetanullableinttonullinaternaryifstatement?Nullabletypesandtheternaryoperator.Whywon'tthiswork?下面有什么问题publicdouble?Progress{get;set;}Progress=null;//worksProgress=1;//worksProgress=(1==2)?0.0:null;//failsTypeofconditionalexpressioncannotbedetermin

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上找到一个类似的问题: