如何将64位整数转换为char数组并返回?

use*_*604 11 c linux

我无法将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;
}
Run Code Online (Sandbox Code Playgroud)

输出是

aNum = 123456789
bNum = 71777215744221775
Run Code Online (Sandbox Code Playgroud)

该代码还提供了两个警告,我不知道如何摆脱.

warning: integer constant is too large for ‘unsigned long’ type
warning: left shift count >= width of type
Run Code Online (Sandbox Code Playgroud)

Jac*_*ack 7

这很简单,问题是你在char数组中移位,但是大小a[i]是4个byes(向上转换int),所以你的移位只是超出范围.尝试在代码中替换它:

int64_t charTo64bitNum(char a[]) {
  int64_t n = 0;
  n = (((int64_t)a[0] << 56) & 0xFF00000000000000U)
    | (((int64_t)a[1] << 48) & 0x00FF000000000000U)
    | (((int64_t)a[2] << 40) & 0x0000FF0000000000U)
    | (((int64_t)a[3] << 32) & 0x000000FF00000000U)
    | ((a[4] << 24) & 0x00000000FF000000U)
    | ((a[5] << 16) & 0x0000000000FF0000U)
    | ((a[6] <<  8) & 0x000000000000FF00U)
    | (a[7]        & 0x00000000000000FFU);
  return n;
}
Run Code Online (Sandbox Code Playgroud)

通过这种方式,您char可以在转换之前将其转换为64位数字,并且不会超出范围.您将获得正确的结果:

entity:Dev jack$ ./a.out 
aNum = 123456789
bNum = 51544720029426255
Run Code Online (Sandbox Code Playgroud)

只是旁注,我认为这也可以正常工作,假设您不需要查看char数组:

#include <string.h>

void int64ToChar(char a[], int64_t n) {
  memcpy(a, &n, 8);
}

int64_t charTo64bitNum(char a[]) {
  int64_t n = 0;
  memcpy(&n, a, 8);
  return n;
}
Run Code Online (Sandbox Code Playgroud)