为什么在使用类似的逻辑递增两种不同的指针类型时得到不同的地址
Why am I getting different addresses when using similar logic to increment two different pointer types?
我不明白为什么我的浮子的地址增加了 16,而我的浮标的大小是 4。有人可以解释一下吗?
法典:
char* mychar = new char[SIZE];
float* myfloat = new float[SIZE];
for(int i = 0; i < SIZE; i++)
{
mychar[i] = 'A' + i;
myfloat[i] = 101 + i;
}
for(int i = 0; i < SIZE; i++)
{
cout << setw(12) << "new char @ <" << static_cast<void*>(mychar) + sizeof(char)*i << ">=<" << mychar[i] << ">"
<< setw(14) << " new float @ <" << myfloat + sizeof(float)*i << ">=<" << myfloat[i] << ">n";
}
cout<< "Size of float: " << sizeof(float) << endl << "Size of char: " << sizeof(char);
输出:
new char @ <0x800102e8>=<A> new float @ <0x800102f8>=<101>
new char @ <0x800102e9>=<B> new float @ <0x80010308>=<102>
new char @ <0x800102ea>=<C> new float @ <0x80010318>=<103>
new char @ <0x800102eb>=<D> new float @ <0x80010328>=<104>
Size of float: 4
Size of char: 1
请注意,myfloat
是一个float*
。这意味着如果你写一个表达式,比如
myfloat + n
结果将是一个指向float
的指针,该指针在地址从 myfloat
开始的 float
数组中向下n
位置。换句话说,在此处添加n
将自动将指针递增 n * sizeof(float)
个字节,因为指针添加知道对象的大小。
因此,如果你写
myfloat + n * sizeof(float)
您不是向前跳跃 n * sizeof(float)
个字节,而是向前跳n * sizeof(float) * sizeof(float)
字节,恰好是 16n 个字节。
希望这有帮助!
相关文章:
- C++中的双指针类型转换
- C++默认情况下,指针类型数组的元素是否保证初始化为 nullptr?
- 将类指针类型转换为键时出错
- 错误:表达式必须具有算术、无作用域枚举或带有运算符重载的指针类型
- C++在一个映射中存储不同的指针类型(并处理销毁)
- 指针类型类成员的动态强制转换的恒定性是什么?
- 我正在尝试将表的地址传递给要在另一个函数中使用的指针,但得到不兼容的指针类型
- 在将派生类指针类型转换为派生类指针后,从基类指针调用派生类函数
- 如何使用静态多态性在 int 和指针类型之间进行转换?
- STL 函数和函数类型与函数指针类型
- 如何调用指针类型的方法(禁用多态性)?
- 为什么新表达式可以正确生成指针类型,即使它应该返回 void*?
- 对于非常量指针类型的参数,未调用具有常量指针模板类型参数的功能
- 是否允许调用方对我的 Builder 类使用任何指针类型(包括智能指针)?
- OPENCL 警告:不兼容的指针类型将'float __global[16]'传递给类型为 '__global float4 的参数 *
- 专门用于"direct"函数类型(与函数指针类型相对)
- 指向成员的指针类型和模板
- 返回对常量结构(指针类型)成员的引用:明显的左值到右值转换
- 在C++17中,为什么类模板和函数模板的指针类型推导明显不一致
- 为什么允许将整型、枚举和指向成员的指针类型reinterpret_cast到自身?