2011-07-08 110 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这样的重复数据行。 –

相关问题