最近做的一个工程项目用到了基本的数据转换,代码实现了一遍,供大家和自己参考。
先考虑如何将二进制补码转换为十进制整数:
- 若符号位是0, 则该数是正数, 原码等同于补码. 可以由原码(也就是补码)得知代表的正整数.
- 若符号为是1, 则该数一定是负数, 可按照以下方式转换: 方式一: 先把符号位去掉, 把剩下的非符号位取反后得到一个无符号位的二进制序列, 将该二进制序列转换为十进制整数(注意:无符号位二进制序列代表的一定是正数),
将该整数加1得到的数便是原补码代表的整数的绝对值. 如: a = 1011(补码), 011取反得到100, 100代表4, 4+1=5,
|a|=5, a=-5. 方式二: 利用公式: (-1)2^(n-1) + 非符号位代表整数 = 值. 如a =
1011(补码), n = 4, 011代表3, a = -1
2^3 + 3 = -5.
功能函数
int u4complement(BYTE *pData) {
int sign = int(pData[0] >> 7); if(sign == 0) return pow(256, 3)*int(pData[0]) + pow(256, 2)*int(pData[1]) + pow(256, 1)*int(pData[2]) + int(pData[3]); if(sign == 1) return -1*(pow(256, 3)*int(pData[0]^0xFF) + pow(256, 2)*int(pData[1]^0xFF) + pow(256, 1)*int(pData[2] ^ 0xFF) + int(pData[3] ^ 0xFF)+1); }
主函数
#include "pch.h" #include
#include "math.h" using namespace std; typedef unsigned char BYTE; int u4complement(BYTE *pData) ; int main() {
BYTE *complete = new BYTE[4]; complete[0] = 0xFF; complete[1] = 0xFF; complete[2] = 0xFF; complete[3] = 0xFA; cout << u4complement(complete) << endl; }
发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/177619.html原文链接:https://javaforall.net
