何故オーバーフロー??
http://oshiete1.goo.ne.jp/qa4423673.html
さらに続きになります。
#include<stdio.h>
#include<string.h>
#define NAME 256 // 暫定的に最大値を決めてます
int Convert(const char* pInFileName, const char* pOutFileName);
int ReConvert(const char* pInFileName, const char* pOutFileName);
int main(){
int a,ret=-1;
char InFileName[NAME]; // 入力ファイル名
char OutFileName[NAME]; // 出力ファイル名
FILE *pInFileName; // 入力ファイルポインタ
FILE *pOutFileName; // 出力ファイルポインタ
printf("1:コンバート 2:リコンバート\n");
scanf("%d",&a);
/***** 入力ファイル名入力 *****/
printf("\n@@@@@入力ファイル名入力\n");
scanf("%s",&InFileName);
// 入力ファイルオープン
if((pInFileName=fopen(InFileName,"rb"))==NULL){
printf("ファイルがありません\n");
return -1;
}
/***** 出力ファイル名入力 *****/
printf("\n@@@@@暗号化後ファイル名入力\n");
scanf("%s",&OutFileName);
// 出力ファイルオープン
if((pOutFileName=fopen(OutFileName,"r"))!=NULL){
// read出来るのなら既にファイルあるという事なのでエラーにする
printf("同名のファイルが既にあります\n");
return -1;
}
pOutFileName=fopen(OutFileName,"wb");
// 1:コンバート
// 2:リコンバート
// 1,2以外:終了
if(a==1){
ret=Convert((const char*)pInFileName,(const char*)pOutFileName);
}
else if(a==2){
ret=ReConvert((const char*)pInFileName,(const char*)pOutFileName);
}
if(ret==0){
printf("正常終了\n");
}
else{
printf("異常終了\n");
return -1;
}
printf("数字+エンターで終了します\n");
scanf("%d",&a);
fclose(pOutFileName);
fclose(pInFileName);
return 0;
}
/*****コンバート*****/
int Convert(const char* pInFileName, const char* pOutFileName)
{
unsigned char moji;
while(1)
{
if(fread( &moji, 1, 1, (FILE*)pInFileName )>0){
fprintf((FILE*)pOutFileName,"%02x",moji);
}
else break;
}
return 0;
}
/*****リコンバート*****/
int ReConvert(const char* pInFileName, const char* pOutFileName)
{
char moji16[3]; // 16進表記
char moji10[4];★★★★★★★★★★
long i,j;
while(1)
{
if(fread( moji16, 1, 2, (FILE*)pInFileName )>0){
for(i=0,j=0;i<2;i+=2,j++){
sscanf(&moji16[i], "%2x", moji10);
}
fprintf((FILE*)pOutFileName,"%c",moji10);
}
else break;
}
return 0;
}
上記の
char moji10[4];★★★★★★★★★★
の部分ですが、これを配列を用いずに、moji10とした場合(応じてsscanfでは&moji10になる)や
moji10[2]、moji10[3]とした場合でもオーバーフローが検出されました。
sscanfの行になった時に、moji10[0]には文字が入りますが、
moji10[1]~moji10[3]まで、NULL文字'\0'が入っていました。
何故moji10[4]にしないとオーバーフローが消えないのでしょうか?
尚、Visual C++ 2008です。
お礼
ありがとうございます。 while (fgets(moji, 100, stdin) != NULL) { if (moji[strlen(moji) - 1] == '\n') { printf("success\n"); } else { printf("Ctrl+Zが入力されたので終了します\n"); } } ってことですよね?もう一つ質問良いでしょうか?この場合だと、文中に(ctrl-z)が入力されるとエラーメッセージを表示するようにしていますが、最初に(ctrl-z)が入力された場合にも同様のエラーメッセージを出力してから終了することは可能でしょうか?
補足
出来ました。