之前好像在哪里见到过这个问题,时间有点久,想不起来了,今天写字符串又碰到这个问题,书上给出的定义是当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地方减一
原文地址:http://blog.csdn.net/familyvirtue/article/details/40431909