草庐IT

c# - 为什么 float.parse 返回错误值?

我有一个问题。当我将像“0.005”这样的字符串解析为float或double时,它在我的电脑上运行良好,但当我将我的程序安装到我的客户端电脑时,它返回5。(我的电脑和我的客户端电脑都使用Windows7x64).这是我的例子publicfloatgetFloat(){floatmn=float.Parse("0.005");doublemn2=Convert.ToDouble("0.005");returnmn;} 最佳答案 这可能是系统文化设置的问题。试试这个:float.Parse("0.005",CultureInfo.In

c# - float 中的E是什么?

什么是E+3?这里到底发生了什么?我们可以在其他数据类型中使用这种方法,还是只能在float中使用它?staticvoidMain(string[]args){doublew=1.7E+3;Console.WriteLine(w);}输出:1700 最佳答案 EnotationMostcalculatorsandmanycomputerprogramspresentverylargeandverysmallresultsinscientificnotation.Becausesuperscriptedexponentslike107

c# - 为什么 C# 中的浮点运算不精确?

为什么下面的程序会打印它打印的内容?classProgram{staticvoidMain(string[]args){floatf1=0.09f*100f;floatf2=0.09f*99.999999f;Console.WriteLine(f1>f2);}}输出是false 最佳答案 float只有那么多位数的精度。如果您看到f1==f2,那是因为任何差异都需要比32位float所能表示的更高的精度。我推荐阅读WhatEveryComputerScientistShouldReadAboutFloatingPoint

c# - 存在从 'float' 和 'float' 以及从 'float' 到 'float' 的隐式转换

这可能是我一段时间以来收到的最好的错误消息,我很好奇出了什么问题。原代码floatcurrElbowAngle=LeftArm?Elbow.transform.localRotation.eulerAngles.y:360f-Elbow.transform.localRotation.eulerAngles.y我正在使用Unity3d和C#;LeftArm是一个bool类型,根据documentationElbow.transform.localRotation.eulerAngles.y返回一个float值。这段代码给我错误:Thereexistsbothimplicitconver

c# - float 的乘法性能不一致

在.NET中测试float的性能时,我偶然发现了一个奇怪的情况:对于某些值,乘法似乎比正常情况慢得多。这是测试用例:usingSystem;usingSystem.Diagnostics;namespaceNumericPerfTestCSharp{classProgram{staticvoidMain(){Benchmark(()=>float32Multiply(0.1f),"\nfloat32Multiply(0.1f)");Benchmark(()=>float32Multiply(0.9f),"\nfloat32Multiply(0.9f)");Benchmark(()=>f

c# - 从 int 转换为 float 的问题

有一个我无法理解的奇怪行为。同意float是近似值,因此即使显然返回没有小数的数字的操作也可以近似为带小数的数字。我这样做:intnum=(int)(195.95F*100);因为这是一个浮点运算,所以我得到19594而不是19595..但这是正确的。让我困惑的是,如果我这样做floatflo=195.95F*100;intnum=(int)flo;我得到了19595的正确结果。知道为什么会这样吗? 最佳答案 我想看看这是不是编译器在做数学运算,但即使你强制它,它的行为也是这样的:staticvoidMain(){inti=(int

c# - 调整图像的亮度对比度和 Gamma

在.NET中调整图像的亮度对比度和Gamma值的简单方法是什么我会自己发布答案以供稍后查找。 最佳答案 c#andgdi+haveasimplewaytocontrolthecolorsthataredrawn.It’sbasicallyaColorMatrix.It’sa5×5matrixthatisappliedtoeachcolorifitisset.Adjustingbrightnessisjustperformingatranslateonthecolordata,andcontrastisperformingascale

C# float.Parse 字符串

我是C#新手,需要从文件中读取float值(x,y,z)。看起来像:0-0.01-0.0020.000833333333333-0.01-0.002如果我正在尝试floatnumber=float.Parse("0,54");//itworkswell,butfloatnumber=float.Parse("0.54");//gainsexepction.我从每一行读取值的代码(可能有问题):intbegin=0;intend=0;for(inti=0;i有人可以帮忙吗? 最佳答案 float.Parse(string)method

c# - 为什么在将字符串转换为 float 时会出现 FormatException?

当我尝试将字符串转换为float时:Console.WriteLine(float.Parse("6.59"));它抛出一个异常:UnhandledException:System.FormatException:Inputstringwasnotinacorrectformat.atSystem.Number.ParseSingle(Stringvalue,NumberStylesoptions,NumberFormatInfonumfmt)当我这样尝试时:Console.WriteLine(Convert.ToSingle("6.59"));它抛出相同的异常:UnhandledEx

c# - 如何在 C# 中模仿 Number.intBitsToFloat()?

我一直在疯狂地尝试读取使用Java程序编写的二进制文件(我正在将Java库移植到C#并希望保持与Java版本的兼容性)。Java库组件的作者选择使用float和乘法来确定一段数据的开始/结束偏移量。不幸的是,它在.NET中的工作方式与在Java中的工作方式有所不同。在Java中,该库使用Float.intBitsToFloat(someInt),其中someInt的值为1080001175。intsomeInt=1080001175;floatresult=Float.intBitsToFloat(someInt);//result(asviewedinEclipse):3.49234