c++ string::compare() fn 的意外行为

问题描述

string::compare() 有其重载形式之一

int compare (size_t pos,size_t len,const string& str) const;

现在考虑以下两种情况:

场景 1:

string s1="steven",s2="steve";
cout<<s1.compare(0,5,s2);

场景 2:

string s1="steven",s2="stevec";
cout<<s1.compare(0,s2);

第一种情况下的 O/P 为 0(预期),但在第二种情况下产生 -1(意外)。 fn 调用转换为将 s1 的前 5 个字符与 s2 的那些字符进行比较。那么,输出如何受到 s2 的第 6 个字符的影响。有人可以解释一下这种实现背后的原因吗?一个标准库 fn。

解决方法

in cppreference所述:

  1. 将此字符串的 [pos1,pos1+count1) 子字符串与 str 进行比较。如果 count1 > size() - pos1 子串是 [pos1,size()).

没有说第二个字符串的大小。这意味着比较整个 string2。所以一切都在预料之中。