背景思想就是
ctrl+z本来就全跳过所有的while循环的
设置个什么符号 等于就break

我想到
(1)一个while(cin>>n) 和一个 scanf_s("%d",&data)!=EOF格式(使用于visual studio)
while ( scanf_s("%d",&data)!=EOF ) {

}
此时,用ctrl+z结束只是跳出第一个死循环,可以继续,但是第二个循环就需要2-3次ctrl+z才结束。

(2)while(cin>>n)

在我2个循环中都是使用while(cin>>n)

由2个while(cin>>n)同时存在,退出循环的问题引起的思考_数据


抵不住结束的。

但是只有一个循环就可以

=============================
输入(cin)缓冲是行缓冲。当从键盘上输入一串字符并按回车后,这些字符会首先被送到输入缓冲区中存储。每当按下回车键后,cin 就会检测输入缓冲区中是否有了可读的数据。
cin 还会对键盘上是否有作为流结束标志的 Ctrl+Z 或者 Ctrl+D 键按下作出检查,其检查的方式有两种:阻塞式以及非阻塞式。
阻塞式检查方式指的是只有在回车键按下之后才对此前是否有 Ctrl+Z 组合键按下进行检查,非阻塞式样指的是按下 Ctrl+D 之后立即响应的方式。如果在按 Ctrl+D 之前已经从键盘输入了字符,则 Ctrl+D的作用就相当于回车,即把这些字符送到输入缓冲区供读取使用,此时Ctrl+D不再起流结束符的作用。如果按 Ctrl+D 之前没有任何键盘输入,则 Ctrl+D 就是流结束的信号。
阻塞式的方式有一个特点:只有按下回车之后才有可能检测在此之前是否有Ctrl+Z按下。还有一个特点,如果输入缓冲区中有可读的数据则不会检测 Ctrl+Z(因为有要读的数据,还不能认为到了流的末尾)。还有一点需要知道,Ctrl+Z产生的不是一个普通的ASCII码值,也就是说它产生的不是一个字符,所以不会跟其它从键盘上输入的字符一样能够存放在输入缓冲区。
Windows系统中一般采用阻塞式检查 Ctrl+Z、Unix/Linux系统下一般采用非阻塞式的检查 Ctrl+D。
=======================这里的解释来自​

其他相关的特殊问题:

while(scanf("%d",&data))
如果输入的不是数字,而是字符就会死循环,不是我们想要的结果,它拼命地刷,因为输入字符后,缓冲区里一直都是那个字符,一直会循环
需要fflush(stdin);//清理缓冲,避免重复循环。

由2个while(cin>>n)同时存在,退出循环的问题引起的思考_输入缓冲区_02

=======================================================
2个getchar()输入字符串

#include<iostream>
using namespace std;
int main(){
int c;
while ((c = getchar()) != EOF)
putchar(c);
while ((c = getchar()) != EOF)
putchar(c);
return 0;
}

由2个while(cin>>n)同时存在,退出循环的问题引起的思考_输入缓冲区_03

=======================================================
本文最早提及到的
2个while (scanf_s("%c", &ch) != EOF)输入字符串

int main(){
int c;
char ch;
while (scanf_s("%c", &ch) != EOF) {
printf("%c", ch);
}
cout << "stop one" << endl;
while (scanf_s("%c", &ch) != EOF) {
printf("%c", ch);
}
cout << "stop two" << endl;
return 0;
}

需要按多次ctrl+z,具体原因不清楚

由2个while(cin>>n)同时存在,退出循环的问题引起的思考_数据_04


相同的

int main(){
int c;
while (scanf_s("%d", &c) != EOF) {
printf("%d\n", c);
}
cout << "stop one" << endl;
while (scanf_s("%d", &c) != EOF) {
printf("%d\n", c);
}
cout << "stop two" << endl;
return 0;
}

由2个while(cin>>n)同时存在,退出循环的问题引起的思考_输入缓冲区_05