首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在C#中将双精度数转换为十六进制

在C#中将双精度数转换为十六进制
EN

Stack Overflow用户
提问于 2010-08-26 02:24:47
回答 5查看 19.9K关注 0票数 16

我有这个值:

代码语言:javascript
运行
复制
double headingAngle = 135.34375;

我想将其转换为十六进制,并将十六进制打印到控制台。我已经将字符串和int转换为它们各自的十六进制值,但是双精度值似乎要复杂得多。谁能给我指个方向?

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2010-08-26 21:53:54

嗯,我用谷歌搜索了一两分钟,根据this的说法,这是一个非常有效的解决方案

代码语言:javascript
运行
复制
    double d = 12.09;
    Console.WriteLine("Double value: " + d.ToString());
    byte[] bytes = BitConverter.GetBytes(d);
    Console.WriteLine("Byte array value:");
    Console.WriteLine(BitConverter.ToString(bytes));
票数 12
EN

Stack Overflow用户

发布于 2010-08-26 02:50:25

你可以通过连续地将分数乘以16,去掉“整数”,然后重复使用余数,将基数10转换为基数16。

因此,要将0.1十进制转换为十六进制

代码语言:javascript
运行
复制
0.1 * 16
= 1.6

因此,1成为第一个十六进制值。继续使用剩下的0.6

代码语言:javascript
运行
复制
0.6 * 16 = 9.6

因此,9成为第二个十六进制值。继续使用剩下的0.6

代码语言:javascript
运行
复制
0.6 * 16 = 9.6

等。

所以0.1十进制= 0.19999..递归十六进制

在内存中,这对任何基数都有效。显然,在十六进制中,10的整数值应该是A,依此类推。

票数 4
EN

Stack Overflow用户

发布于 2010-08-26 20:45:38

假设您想要转换为十六进制的基数/基数,下面的代码应该可以完成此任务:

代码语言:javascript
运行
复制
static void Main(string[] args)
{
    Console.WriteLine(Base16(135.34375, 10));
    Console.ReadLine();
}

private static string Base16(double number, int fractionalDigits)
{
    return Base(number, fractionalDigits, new char[]{
        '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
        'A', 'B', 'C', 'D', 'E', 'F' });
}

private static string Base(double number, int fractionalDigits, params char[] characters)
{
    int radix = characters.Length;
    StringBuilder sb = new StringBuilder();

    // The 'whole' part of the number.
    long whole = (long)Math.Floor(number);
    while (whole > 1)
    {
        sb.Insert(0, characters[whole % radix]);
        whole = whole / radix;
    }

    // The fractional part of the number.
    double remainder = number % 1;
    if (remainder > Double.Epsilon || remainder < -Double.Epsilon)
    {
        sb.Append('.');

        double nv;
        for (int i = 0; i < fractionalDigits; i++)
        {
            nv = remainder * radix;
            if (remainder < Double.Epsilon && remainder > -Double.Epsilon)
                break;
            sb.Append(characters[(int)Math.Floor(nv)]);
            remainder = nv % 1;
        }
    }

    return sb.ToString();
}

135.34375的十六进制转换为87.58

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3569041

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档