2012-04-05 22 views
1

MIPSに移植する必要がある基数に応じて、整数をASCII文字列に変換するCの実装です。私がそれを完全に行う前に、このコードがどのように機能するのか(完全なコードは下に)、そしてiveは純粋なCを決して扱っていないことを理解する必要があります。このアルゴリズムはどのように機能しますか?

のわからない何イム

*p ++ = hexdigits[c]; 

は正確に何をするん

? pがchar配列であるように見えるので、ここでどのような割り当てが行われているのかわかりません。私はそれが正確に何をしているのか分かりましたら、残りの部分を見つけ出すことができますか?ありがとう!

#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 ++; ' –

関連する問題