应使用 std::getline 读带空格字符串,因 std::cin >> 遇空格即停止;混合使用时需用 std::cin.ignore() 清除残留换行符,否则 getline 会立即返回空。
用 std::getline 读带空格的字符串,别用 std::cin >> ——后者遇到空格就停。
std::cin >> 不能读带空格的字符串因为 operator>> 默认以空白字符(空格、制表符、换行)为分隔符,读到第一个空格就结束。比如输入 "hello world",std::cin >> s 只拿到 "hello","world" 留在输入缓冲区里,后续读取可能出错。
std::cin >> 和 std::getline 时,getline 立刻返回空字符串——其实是前面的 >> 留下了换行符在缓冲区getline”,而是先用 std::cin.ignore() 清掉残留换行符>> 更简洁;但只要含空格、制表或整行文本,必须切到 getline
std::getline 的基本用法和参数差异std::getline 是从输入流中读取字符直到遇到指定分隔符(默认是 '\n'),把之前的内容存进 std::string,且不包含该分隔符本身。
std::getline(std::cin, str) ——读一整行,含空格,不含末尾换行符std::getline(std::cin, str, ';') ——读到分号为止(比如解析 CSV 片段)char,不能是字符串或 std::string;想按字符串分割得自己写逻辑std::istream&),可用来判断是否读取成功:if (std::getline(std::cin, s)) { ... }
>> 和 getline 时的典型陷阱这是新手最容易

cin >> 读一个整数或单词,紧接着用 getline 读描述,结果描述为空。
cin >> 不吃掉它后面那个换行符,getline 遇到换行立刻返回getline 前加 std::cin.ignore(1, '\n') ——忽略最多 1 个字符,直到遇到换行(更安全)std::cin.ignore(std::numeric_limits<:streamsize>::max(), '\n') ——清空整行残留(推荐用于不确定输入长度时)int id; std::string name; std::cin >> id; // 输入 123 后按回车,缓冲区剩下 '\n' std::cin.ignore(); // 忽略一个字符(即 '\n') std::getline(std::cin, name); // 这才开始读下一行
std::getline 内部会动态扩容 std::string,对极长行(如几 MB)要注意内存分配开销;但日常输入完全不必担心。
"\r\n",Linux/macOS 是 "\n",getline 自动处理,统一以 '\n' 为终止,'\r' 会被当作普通字符读入(除非你手动去掉)gets 或 fgets,务必避开 ——gets 已被 C++14 移除,fgets 容易缓冲区溢出std::ifstream fin("data.txt"); std::string line; while (std::getline(fin, line)) { ... }
真正容易被忽略的,是那个隐藏的换行符——它不报错、不提示,只是让 getline “莫名其妙”地跳过输入。每次用完 >> 就条件反射加一句 ignore,比事后调试快得多。