2012-04-05 85 views
1

這是一個C實現,根據我需要移植到MIPS的基數,將整數轉換爲ASCII字符串。在我完全可以做到這一點之前,我需要了解代碼的工作原理(完整代碼在底部),並且從未真正處理過純粹的C代碼。這個算法是如何工作的?

什麼IM不確定的:

是什麼

*p ++ = hexdigits[c]; 

做什麼呢?它看起來像p是一個char數組,所以我不確定這裏的分配是什麼。如果我能弄清楚p的功能到底是什麼,我肯定我可以弄清楚其餘的。謝謝!

#include <stdio.h> 
#include <stdlib.h> 

char * my_itoa(unsigned int v, char *p, int r) 
{ 
    unsigned int c; 
    char *p_old, *q; 
    static char hexdigits[16] = "ABCDEF"; 

    if (r < 2 || r > 16) { 
     *p = 0; 
     return p; 
    } 

    if (v == 0) { 
     *p = '0'; 
     return p; 
    } 

    p_old = p; 
hy 
    // doing the conversion 
    while (v > 0) { 
     // You can get both c an v with ONE MIPS instruction 
     c = v % r; 
     v = v/r; 
     *p ++ = hexdigits[c]; 
    } 

    *p = 0; 

    // reverse the string 

    // q points to the head and p points to the tail 
    q = p_old; 
    p = p - 1; 

    while (q < p) { 
     // swap *q and *p 
     c = *q; 
     *q = *p; 
     *p = c; 

     // increment q and decrement p 
     q ++; 
     p --; 
    } 

    return p_old; 
} 

char buf[32]; 

int main (int argc, char **argv) 
{ 
    int r; 
    unsigned int m0 = (argc > 1) ? atoi(argv[1]) : 100; 

    for (r = 2; r <= 16; r ++) 
     printf("r=%d\t%s\n", r, my_itoa(m0, buf, r)); 

    return 0; 
} 

回答

7

此:

*p ++ = hexdigits[c]; 

是相同的這一點:

*p = hexdigits[c]; 
p++; 
+7

或'P [0] = hexdigits [C];的p ++;' – 2012-04-05 00:25:15