2011-07-08 144 views
0

我在寫一個將文件轉儲爲八進制的函數。在達到一行字符數限制之後,假設打印出要傳入的文件的可打印字符。如何打印字符串數組的某些部分?

出於某種原因,我的程序總是打印文本文件的前16個字符,我將如何打印文件中的其餘字符?

這裏是文本文件,我使用的測試:

?asdfadsbgasdfassadfasdfsadfads 
asdf 
asdf 
asd 
v 
asdf 
asdf 
asd 
f 
asdf 

這裏是輸出到標準輸出:

0000000 77 141 163 144 146 141 144 163 142 147 141 163 144 146 141 163 | ?asdfadsbgasdfas 
    0000020 163 141 144 146 141 163 144 146 163 141 144 146 141 144 163 15 | ?asdfadsbgasdfas 
    0000040 12 141 163 144 146 15 12 141 163 144 146 15 12 141 163 144 | ?asdfadsbgasdfas 
    0000060 15 12 166 15 12 141 163 144 146 15 12 141 163 144 146 15 | ?asdfadsbgasdfas 
    0000100 12 141 163 144 15 12 146 15 12 141 163 144 146 15 12 ?asdfadsbgasdfa 
    0000120 

這裏是我的代碼:

void octaldump(FILE * fp) 
{ 
    int c; 
    size_t linecount = 0, index = 0, i; 
    long int address = 0; 
    char temp [LINESIZE]; 

    while((c = fgetc(fp)) != EOF) 
    { 
     if(linecount == 0) 
     { 
      printf("%07o ", address); 
      address += 16; 
     } 
     temp[index] = c; 
     index++; 

     printf("%02o ", c); 
     linecount++; 

     if(linecount == 16) 
     { 
      printf(" | "); 
      for(i = 0; i < linecount; i++) 
      { 
       if(temp[i] <= 32) 
       { 
        printf("."); 
       } 
       else 
       { 
        printf("%c", temp[i]); 
       } 
      } 
      printf("\n"); 
      linecount = 0; 
     } 
    } 

    if(linecount < 16) 
    { 
     for(i = 0; i < linecount; i++) 
     { 
      if(temp[i] <= 32) 
      { 
       printf("."); 
      } 
      else 
      { 
       printf("%c", temp[i]); 
      } 
     } 
    } 

    printf("\n%07o ", address); 
} 
+1

你會得到更好的奠定了輸出,如果你使用'「%03o」',而不是'「%02o 「'。你也可以在''中查找'isprint()'。 –

回答

3

你問題在於你沒有在linecount == 16代碼後面設置index回零。除此之外,這意味着你有一個可怕的緩衝區溢出。

在尾隨數據處理中,首先應打印出缺少字符的足夠空白,以使可打印字符與其他集合對齊。我在評論中提到使用"%03o"代替"%02o"以提供一致的對齊。另外,從<ctype.h>使用isprint()會改善事情。


這工作得相當好,我 - 測試在自己的源代碼:

#include <ctype.h> 
#include <stdio.h> 

enum { LINESIZE = 16 }; 

void octaldump(FILE * fp) 
{ 
    int c; 
    size_t linecount = 0, index = 0, i; 
    unsigned long address = 0; 
    char temp [LINESIZE]; 

    while ((c = fgetc(fp)) != EOF) 
    { 
     if (linecount == 0) 
     { 
      printf("%07lo ", address); 
      address += 16; 
     } 
     temp[index] = c; 
     index++; 

     printf("%03o ", c); 
     linecount++; 

     if (linecount == 16) 
     { 
      printf(" | "); 
      for (i = 0; i < linecount; i++) 
       printf("%c", isprint(temp[i]) ? temp[i] : '.'); 
      printf("\n"); 
      linecount = 0; 
      index = 0; 
     } 
    } 

    if (linecount < 16) 
    { 
     for (int j = linecount; j < 16; j++) 
      printf(" "); 
     printf(" | "); 

     for (i = 0; i < linecount; i++) 
      printf("%c", isprint(temp[i]) ? temp[i] : '.'); 
     printf("\n"); 
    } 

    printf("%07lo\n", address); 
} 

int main(void) 
{ 
    octaldump(stdin); 
    return 0; 
} 
+0

輸出的全長行長度爲91個字符。如果使用十六進制而不是八進制,則可以輕鬆獲得長度僅爲74個字符的行,這通常更方便。只是爲了好玩,你應該研究如何抑制像od這樣的重複數據行。 –

相關問題