[英]Reading in a variable length string user input in C
我試圖讀取可變長度的用戶輸入並執行一些操作(例如在字符串中搜索子字符串)。
問題是我不知道我的字符串有多大(文本很可能是3000-4000個字符)。
我附上我嘗試過的示例代碼和輸出:
char t[],p[];
int main(int argc, char** argv) {
fflush(stdin);
printf(" enter a string\n");
scanf("%s",t);
printf(" enter a pattern\n");
scanf("%s",p);
int m=strlen(t);
int n =strlen(p);
printf(" text is %s %d pattrn is %s %d \n",t,m,p,n);
return (EXIT_SUCCESS);
}
輸出為:
enter a string
bhavya
enter a pattern
av
text is bav 3 pattrn is av 2
請永遠不要使用不安全之類的東西scanf("%s")
或我個人不喜歡, gets()
-有沒有辦法來防止緩沖區溢出了這樣的事情。
您可以使用更安全的輸入法,例如:
#include <stdio.h>
#include <string.h>
#define OK 0
#define NO_INPUT 1
#define TOO_LONG 2
static int getLine (char *prmpt, char *buff, size_t sz) {
int ch, extra;
// Get line with buffer overrun protection.
if (prmpt != NULL) {
printf ("%s", prmpt);
fflush (stdout);
}
if (fgets (buff, sz, stdin) == NULL)
return NO_INPUT;
// If it was too long, there'll be no newline. In that case, we flush
// to end of line so that excess doesn't affect the next call.
if (buff[strlen(buff)-1] != '\n') {
extra = 0;
while (((ch = getchar()) != '\n') && (ch != EOF))
extra = 1;
return (extra == 1) ? TOO_LONG : OK;
}
// Otherwise remove newline and give string back to caller.
buff[strlen(buff)-1] = '\0';
return OK;
}
然后,您可以設置最大大小,它將檢測到行上是否輸入了太多數據,並刷新了行的其余部分,因此不會影響您的下一個輸入操作。
您可以使用以下方法進行測試:
// Test program for getLine().
int main (void) {
int rc;
char buff[10];
rc = getLine ("Enter string> ", buff, sizeof(buff));
if (rc == NO_INPUT) {
// Extra NL since my system doesn't output that on EOF.
printf ("\nNo input\n");
return 1;
}
if (rc == TOO_LONG) {
printf ("Input too long [%s]\n", buff);
return 1;
}
printf ("OK [%s]\n", buff);
return 0;
}
在實踐中,您不應該太費力地精確。 給自己一些時間來在堆棧上保留一些內存並對此進行操作。 一旦想進一步傳遞數據,就可以使用strdup(buffer)
並將其放在堆上。 知道你的極限。 :-)
int main(int argc, char** argv) {
char text[4096];
char pattern[4096];
fflush(stdin);
printf(" enter a string\n");
fgets(text, sizeof(text), stdin);
printf(" enter a pattern\n");
fgets(pattern, sizeof(pattern), stdin);
int m=strlen(text);
int n =strlen(pattern);
printf(" text is %s %d pattrn is %s %d \n",text,m,pattern,n);
return (EXIT_SUCCESS);
}
您遇到的主要問題是具有未知大小的char數組。 只需在聲明時指定數組大小即可。
int main(int argc, char** argv) {
int s1[4096], s2[4096];
fflush(stdin);
printf(" enter a string\n");
scanf("%s", s1);
printf(" enter a pattern\n");
scanf("%s", s2);
int m = strlen(s1);
int n = strlen(s2);
printf(" text is %s of length %d, pattern is %s of length %d \n", s1, m, s2, n);
return (EXIT_SUCCESS);
}
不要使用scanf
或gets
來解決這個問題,因為正如您所說,沒有真正的方法來知道輸入將要持續多長時間。 而是將stdin
作為最后一個參數使用fgets
。 fgets
允許您指定應讀取的最大字符數。 您隨時可以返回並閱讀更多內容。
scanf(%s)
gets
讀取,直到找到終止字符,並且該字符可能會超過緩沖區的長度,從而導致一些難以解決的問題。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.