之前好像在哪里见到过这个问题,时间有点久,想不起来了,今天写字符串又碰到这个问题,书上给出的定义是当string.find()没有找到时返回的是一个非常大的值,网上有人说是-1,两种说法都对,由于整数在计算机中是依照补码形式存放的,一个高位的整数在少一位的整数表示时假设高位的第二位是1,那么少一位的表示下就是负数,假设高位整数的第二位包含第二位之后全是1,那么在少一位的表示下就是-1。string.find()返回的那个非常大的数是2的32次方,而在用4个字节表示的int,long整形,最多仅仅能表示到2的31次方,2的32次方减一存储的后32位的值和-1的补码全然同样:11111111 11111111 11111111 11111111;假设赋值给int或者long类型的变量自然就是-1。
以下贴上C++验证代码
#include <iostream>
#include <string>
using namespace std;
int main()
{
string str = "helloworld!";
int i;
long l;
i = str.find("y");
l = str.find("y");
cout<<i<<" "<<l<<" "<<str.find("y")<<endl;
return 0;
}
结果是-1 -1 4294967295
4294967295 等于2的32地方减一