https://blog.csdn.net/livecoldsun/article/details/25489429
对以上博客的精华总结:
输入原理简述:
程序的输入都建有一个缓冲区,即输入缓冲区。每次输入过程是这样的,当一次键盘输入结束时会将输入的数据存入输入缓冲区,而cin函数直接从输入缓冲区中取数据。正因为cin函数是直接从缓冲区取数据的,所以有时候当缓冲区中有残留数据时,cin函数会直接取得这些残留数据而不会请求键盘输入。
对于cin ,在遇到结束符(Space、Tab、Enter)就结束,其余存入缓冲区.
三个函数:
1.cin.get(字符数组名,接收长度,结束符)
若接受长度大于等于数组长度,数组最后一个被设为结束符号,其余的被保留在输入缓冲区,结束符号也保留在缓冲区;
第三个参数可以缺省,当第一个参数为一个字符变量时,第二个参数也就缺省了,
三个参数都可以缺省,与只有第一个参数用处类似,接收缓冲区中不需要的字符。
2.cin.getline(字符数组名,接收长度,结束符)
若接受长度大于等于数组长度,会引起cin函数的错误,之后的cin无法进行,
结束符号不会被保留在缓冲区。
3.getline(cin,s,结束符)
s只能为string类型,并且会接收程序之前缓冲区的内容(但自己的结束符不会被保留在缓冲区中),这就可能导致了第一个s为’\n’,并且每次调用时,会将s中的内容先清空,若直接遇到结束符,s就是空串了。