【发布时间】:2012-03-14 03:58:18
【问题描述】:
我在将 int64_t 转换为 char 数组并返回时遇到问题。我不知道下面的代码有什么问题,这对我来说完全合乎逻辑。如图所示,该代码适用于a,但不适用于第二个数字b,它显然属于int64_t 的范围。
#include <stdio.h>
#include <stdint.h>
void int64ToChar(char mesg[], int64_t num) {
for(int i = 0; i < 8; i++) mesg[i] = num >> (8-1-i)*8;
}
int64_t charTo64bitNum(char a[]) {
int64_t n = 0;
n = ((a[0] << 56) & 0xFF00000000000000U)
| ((a[1] << 48) & 0x00FF000000000000U)
| ((a[2] << 40) & 0x0000FF0000000000U)
| ((a[3] << 32) & 0x000000FF00000000U)
| ((a[4] << 24) & 0x00000000FF000000U)
| ((a[5] << 16) & 0x0000000000FF0000U)
| ((a[6] << 8) & 0x000000000000FF00U)
| ( a[7] & 0x00000000000000FFU);
return n;
}
int main(int argc, char *argv[]) {
int64_t a = 123456789;
char *aStr = new char[8];
int64ToChar(aStr, a);
int64_t aNum = charTo64bitNum(aStr);
printf("aNum = %lld\n",aNum);
int64_t b = 51544720029426255;
char *bStr = new char[8];
int64ToChar(bStr, b);
int64_t bNum = charTo64bitNum(bStr);
printf("bNum = %lld\n",bNum);
return 0;
}
输出是
aNum = 123456789
bNum = 71777215744221775
代码还给出了两个我不知道如何摆脱的警告。
warning: integer constant is too large for ‘unsigned long’ type
warning: left shift count >= width of type
【问题讨论】:
-
第二个警告是关键。
<<的操作数提升为int,所以a[0]<<56将始终为0。尝试((int64_t)a[0])等。第一个警告是关于51544720029426255,你需要说51544720029426255LL。