zoukankan      html  css  js  c++  java
  • C# 负数和十六进制(两字节)转换

    思路:

    ①负数转换为正数;例:-5,先转换成5(0000 0101);第一位标识正负

    先将十进制转换为二进制通过;例:将5转换为二进制,得到结果0000 0101

    ③求反码;例:将上面例子求反码,得到结果:1111 1010(即0变成1,1变0)

    ④求补码;例:将第四步结果求补码,得到结果:1111 1011(最后一位加1)
    ⑤转十六进制;1111 1011转十六进制即得:FB

    /// <summary>
    /// 负数转十六进制
    /// </summary>
    /// <param name="iNumber"></param>
    /// <returns></returns>
    private string NegativeToHexString(int iNumber)
    {
        string strResult = string.Empty;

        if (iNumber < 0)
        {
            iNumber = -iNumber;

            string strNegate = string.Empty;

            char[] binChar = Convert.ToString(iNumber, 2).PadLeft(8'0').ToArray();

            foreach (char ch in binChar)
            {
                if (Convert.ToInt32(ch) == 48)
                {
                    strNegate += "1";
                }
                else
                {
                    strNegate += "0";
                }
            }

            int iComplement = Convert.ToInt32(strNegate,2) + 1;

            strResult = Convert.ToString(iComplement, 16).ToUpper();
        }

        return strResult;
    }
     /// <summary> 

    /// 十六进制转为负数
    ///</summary>

    ///<param name="strNumber"></param>

    ///<returns></returns>

    privateint HexStringToNegative(string strNumber)
    {
        int iNegate = 0;
        int iNumber = Convert.ToInt32(strNumber, 16);

        if (iNumber > 127)
        {
            int iComplement = iNumber - 1;
            string strNegate = string.Empty;

            char[] binChar = Convert.ToString(iComplement, 2).PadLeft(8'0').ToArray();

            foreach (char ch in binChar)
            {
                if (Convert.ToInt32(ch) == 48)
                {
                    strNegate += "1";
                }
                else
                {
                    strNegate += "0";
                }
            }

            iNegate = - Convert.ToInt32(strNegate, 2);
        }

        return iNegate;
    }

  • 相关阅读:
    spark shuffle过程分析
    Android实现网络多线程断点续传下载
    幻世(OurDream)TM 2D图形引擎开通捐赠渠道
    MDA模型定义及扩展
    STL在迭代的过程中,删除指定的元素
    c# POST和GET方式通过server地址提交数据
    Python爬虫抓取csdn博客
    Word Ladder II
    HDU 4183 Pahom on Water(最大流SAP)
    poj1011 Sticks
  • 原文地址:https://www.cnblogs.com/zhangpengshou/p/2291418.html
Copyright © 2011-2022 走看看