标准库函数begin和end
为了让指针的使用更简单,更安全,C++11引入了两个函数:begin和end,这两个函数定义在iterator头文件中。它们的正确使用形式是将数组作为它们的参数:
int ia[] = {0,1,2,3,4,5,6,7,8,9};
int *beg = begin(ia); //指向ia首元素的指针
int *end = end(ia); //指向ia尾元素的下一位置的指针。
sizeof 运算符
sizeof的运算符的运算对象有两种形式:
sizeof(type)
sizeof expr
第二种形式中,sizeof返回的是表达式结果的类型的大小。与众不同的是,sizeof并不实际计算其运算对象的值。 sizeof运算符的结果部分地依赖于其作用的类型:
- 对指针执行sizeof运算得到指针本身所占空间的大小
- 对解引用指针执行sizeof运算得到指向所指向对象所占空间的大小,指针不需有效
- 对数组执行sizeof运算得到整个数组所占空间的大小。注意,sizeof运算符不会把数组转换成指针来处理。
- 对string对象或vector对象执行sizeof运算只返回该类型固定部分的大小,与计算对象中元素的个数无关。
对于最后一点,我们验证一下:
#include <iostream>
#include <vector>
using namespace std;
int main() {
vector<int> vec;
cout << sizeof vec << endl;
for (int i = 0; i < 10; ++i)
vec.push_back(i);
cout << sizeof vec << endl;
}
代码的运行结果为:
可见sizeof vec与vec的元素个数无关,只与其固定的部分的大小有关(应该是vector的数据成员变量的大小)
C++ 11 新标准允许我们使用作用域运算符来获取类成员的大小。
#include <iostream>
#include <vector>
using namespace std;
class A {
public:
A() = default;
private:
int a;
string str;
};
int main() {
A a;
cout << sizeof A::a << endl;
cout << sizeof A::str << endl;
}