翻阅《C++ Primer中文版(第4版)》,里面出现的for大多都是类似如下的循环:
vector<int> ivec(10);
for (vector<int>::size_type ix = 0; ix != ivec.size(); ++ix) {
ix = 1;
}
从以上的代码中,不由得让人产生两个疑问:
1、判断条件为什么用'ix != ivec.size()'而不用'ix < ivec.size()'呢?
在书中的第82页的解释为:C++程序员习惯于优先选用!=而不是<来编写循环判断条件。
2、为什么调用size成员函数而不提前保存它返回的值?
同样,在书中的第82页的解释为:这反映了一种良好的编程习惯,在C++中,有些数据类型(如vector)可以动态增长,而在循环中容易地增加新元素,如果确实增加了新元素的话,那么测试提前保存的size值就会有问题。在C++函数中有些函数可以声明为内联函数。编译器遇到内联函数时就会直接扩展相应代码,而不是进行实际的函数调用。像size这样的小库函数几乎都定义为内联函数,故每次循环过程中调用它的运行时代价是比较小的。