对于一些计算,我需要使用浮点数,但是我有一个byte[]可以使用,所以我首先要做的是:
Array.Copy(byteArray, floatArray, byteArray.Length);这很有效,我在floats.but上做了一些计算,现在我需要把它转换回byteArray。我不能使用下面的代码,它崩溃了,没有给出具体的错误信息。
float[] DiffernetfloatArray= new float[ byteArray];
Array.Copy(DiffernetfloatArray, byteArray, DiffernetfloatArray.Length);一开始我认为它的大小不是很好,但是我正在使用的浮点数组,我只是为了测试而增加了500的大小,仍然给了我同样的错误
有人知道我怎么解决这个问题吗?最好用C#回答
发布于 2012-12-13 23:43:49
使用linq更简单:
var byteArray = floatArray.Select(f => Convert.ToByte(f)).ToArray();
var floatArray = byteArray.Select(b => (float)Convert.ToDouble(b)).ToArray();发布于 2012-12-13 23:44:23
有一种更简单的方法:
System.BitConverter.GetBytes(float)MSDN
发布于 2012-12-13 23:41:53
字节可以转换为浮点型,因为它适合类型,但另一种方式不能通过隐式转换完成-浮点型可能太大而无法放入字节,因此Array.Copy在这种情况下永远不会工作。
https://stackoverflow.com/questions/13863264
复制相似问题