主要分为两个部分
第一部分:char[]字符串的初始化
第二部分:gets和%[^\n]输入的区别
.
第一部分
char[]字符串的初始化
// char ch[25]="abcd\";会编译出错
char ch[25]="abcd\ ";
cout << strlen(ch) << endl ; // 5 \ 不算单个字符
printf("ch[4]=%d\n",ch[4]); // ch[4]=32 说明第五个字符不是 '\ ' 而是' '
char ch1[25]="abcd\na";
cout << strlen(ch1) << endl ; // 6 \n 算算一个换行字符
char ch2[25]="abcd\0a";
cout << strlen(ch2) << endl ; // 4 遇到\0就结束
总结
初始化中\0或\n等不会当作分开的单独字符,而是字符串结束标志和一个单字符:换行
.
第二部分
gets和%[^\n]输入的区别
//gets
char ch3[25];
gets(ch3); // 输入abc d\n
cout << strlen(ch3) << endl ; //输出5 说明ch3遇到\n结束但不传入\n
char ch4;
scanf("%c",&ch4); // 输入a
getchar(); // 吃掉末尾的空格
printf("ch4=%d\n",ch4); // 输出97 说明ch3没有传入的\n字符不会继续留下,不会影响下一次输入
//%[^\n]
char ch5[25];
scanf("%[^\n]",ch5); // 输入abc d\n (直到回车,但不包括回车)
cout << strlen(ch5) << endl ; // 5
char ch6;
scanf("%c",&ch6);
printf("%d\n",ch6); // 输出10,说明%[^\n]会继续留下\n给下一次输入
总结
gets输入一行字符串后不会把换行符留给下一次输入
%[^\n]输入一行字符串后会把换行符留给下一次输入