2

我正在使用嵌入式系统,我需要实现一种将 long long 转换为 char 的方法。

问题是我不能在这个系统中使用 sprintf 来做到这一点,所以我正在寻找替代方法/功能来实现它。

欢迎提出 LongLongToChar 函数的实现建议。

4

2 回答 2

3

谷歌“itoa”。有很多变化。这是一个例子。

char* itoa(int val, int base){

    static char buf[32] = {0};

    int i = 30;

    for(; val && i ; --i, val /= base)

        buf[i] = "0123456789abcdef"[val % base];

    return &buf[i+1];

}

具体来说,这是一个“lltoa”。

#include <stdio.h>
#include <limits.h>


char* lltoa(long long val, int base){

    static char buf[64] = {0};

    int i = 62;
    int sign = (val < 0);
    if(sign) val = -val;

    if(val == 0) return "0";

    for(; val && i ; --i, val /= base) {
        buf[i] = "0123456789abcdef"[val % base];
    }

    if(sign) {
        buf[i--] = '-';
    }
    return &buf[i+1];

}

int main() {
    long long a = LLONG_MAX;
    long long b = LLONG_MIN + 1;
    long long c = 23;

    printf("%ld\n", sizeof(a));
    printf("max '%s'\n", lltoa(a, 10));
    printf("min '%s'\n", lltoa(b, 10));
    printf("-1  '%s'\n", lltoa((long long)-1, 10));
    printf("23  '%s'\n", lltoa(c, 10));
}
于 2013-09-17T19:25:46.547 回答
1

使用lldiv(), 节省 CPU 滴答声而不是单独的 /%.
在整个long long范围内都能很好地工作,包括0那个讨厌LONG_LONG_MIN的 .

const char *ToString(long long i) {
  static char buffer[sizeof(i)*3 + 1];  // Size could be a bit tighter
  char *p = &buffer[sizeof(buffer)];
  *(--p) = '\0';
  lldiv_t qr;
  qr.quot = i;
  do {
    qr = lldiv(qr.quot, 10);
    *(--p) = abs(qr.rem) + '0';
  } while (qr.quot);
  if (i < 0) {
    *(--p) = '-';
  }
  return p;
}
于 2013-09-17T20:21:43.157 回答