gpt4 book ai didi

C - scanf 行为不当

转载 作者:太空宇宙 更新时间:2023-11-04 06:04:32 24 4
gpt4 key购买 nike

当使用第一个 scanf() 并且您回答 Y 时,第二个 scanf() 会直接跳到“未选择选项。正在退出...”。当 key 文件大于源文件并且最后一个 scanf 正常工作时,也会出现该消息。所以我在这里不知所措,出了什么问题? (代码编译得很好,所以请随意尝试)

编辑:对于反对者来说,至少发布一个理由是有帮助的。我不是一个很好的程序员,只是想在这里学习。

#include <stdio.h>
#include <stdlib.h>
#include <sys/stat.h>

int main(int argc, char **argv)
{
struct stat statbuf;
struct stat keybuf;

int key;
int data;
int output;
int count;
char ans;
FILE * keyfile;
FILE * sourcefile;
FILE * destfile;

if(argc<4)
{
printf("OTP-Bunny 1.0\n");
printf("USAGE: OTP <source file> <output file> <keyfile>\n");
return (0);
}

/* Check number of arguments. */
if(argc>4)
{
printf("Too many arguments.\n");
printf("USAGE: OTP <source file> <output file> <keyfile>\n");
return(1);
}

/* Check if sourcefile can be opened. */
if((sourcefile = fopen(argv[1], "rb"))== NULL)
{
printf("Can't open source file.\n");
printf("Please enter a valid filename.\n");
printf("USAGE: OTP <source file> <output file> <keyfile>\n");
perror("Error");
return (1);
}

/* Get size of sourcefile */
fstat(fileno(sourcefile), &statbuf);

/* Check if keyfile can be opened. */
if((keyfile = fopen(argv[3], "rb"))== NULL)
{
printf("Can't open keyfile.\n");
printf("Please enter a valid filename.\n");
printf("USAGE: OTP <source file> <output file> <keyfile>\n");
perror("Error");
return(1);
}

/* Get size of keyfile */
fstat(fileno(keyfile), &keybuf);

/* Check if keyfile is the same size as, or bigger than the sourcefile */
if((keybuf.st_size) < (statbuf.st_size))
{
printf("Source file is larger than keyfile.\n");
printf("This significantly reduces cryptographic strength.\n");
printf("Do you wish to continue? (Y/N)\n");
scanf("%c", &ans);
if(ans == 'n' || ans == 'N')
{
return (1);
}
if(ans == 'y' || ans == 'Y')
{
printf("Proceeding with Encryption/Decryption.\n");
}
else
{
printf("No option selected. Exiting...\n");
return (1);
}
}

/* Check if destfile can be opened. */
if((keyfile = fopen(argv[2], "wb"))== NULL)
{
printf("Can't open output file.\n");
perror("Error");
return(1);
}

/* Open destfile. */
destfile=fopen(argv[2], "wb");

/* Encrypt/Decrypt and write to output file. */
while(count < (statbuf.st_size))
{
key=fgetc(keyfile);
data=fgetc(sourcefile);

output=(key^data);

fputc(output,destfile);
count++;
}

/* Close files. */
fclose(keyfile);
fclose(sourcefile);
fclose(destfile);

printf("Encryption/Decryption Complete.\n");

/* Delete keyfile option. */
printf("Do you wish to delete the keyfile? (Y/N)\n");
scanf("%c", &ans);
if(ans == 'y' || ans == 'Y')
{
if ( remove(argv[3]) == 0)
{
printf("File deleted successfully.\n");
}
else
{
printf("Unable to delete the file.\n");
perror("Error");
return(1);
}
}

if(ans == 'n' || ans == 'N')
{
return(0);
}
else
{
printf("No option selected. Exiting...\n");
}
return(0);
}

最佳答案

实际上,scanf() 的行为是正确的,但要正确使用它是一个非常棘手的函数,您的期望很容易与其记录的行为不同。

您的第一个 scanf() 调用读取单个字符,将换行符留在后面。

您的第二个 scanf() 调用会读取一个换行符,因为那是下一个...导致问题。

您可以使用 "%c" 修复代码;前导空白跳过(可选)空白。

通常,更好的解决方法是结合使用 fgets() 或等价物(可能是 POSIX 2008 中的 readline())和 sscanf ()。使用fgets()将一行数据读入内存;使用 sscanf() 对其进行分析。这样,您也可以更好地报告错误;您拥有用户键入的所有可用于错误报告的信息。

关于C - scanf 行为不当,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12900949/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com