"x = &v"和"*x = v"是否等效?
Are `x = &v` and `*x = v` equivalent?
int * x;
int v = 7;
给定此代码,两者之间有什么区别 1.x = &v
和 2.*x = v
? 我知道在这两种情况下,*x
都包含7
但在这两种情况下x
都包含v
的内存位置吗?如果不是,x
在案例 1 和 2 中包含什么,这是两者之间唯一的显着区别吗?
给定语句:
int v = 7;
v
内存中有一些位置。行为:
x = &v;
将x
"指向"v
的内存位置,实际上*x
将具有值7
。
但是,在此声明中:
*x = v;
您将v
的值存储在x
指向的地址处。但是x
没有指向有效的内存地址,因此此语句调用未定义的行为。
所以要回答你的问题,不,这两个陈述并不等同。
x = &v
修改x。操作后 x 将指向 v。
*x = v
修改 x 指向的对象。在示例中,x 不指向任何内容,因为指针未初始化。因此,行为是不确定的。
&
表示地址。
*
表示价值在。
x = &v
v
的地址被分配给x
。
在*x = v
-x
处的值(地址x
处的值(被分配值v
。
这两个是非常不同的说法。
最初x
将包含垃圾值。因此,*x
将尝试取消引用未初始化的地址,并将导致未定义的行为(在大多数情况下是分段错误(,因为*x
指的是未初始化的内容。因此,*x = v
将v
中的值分配给x
指向的位置。
在x = &v
中,x
将包含v
的地址。从这一点开始x
包含v
的地址,*x
将引用v
中的值。因此,这种说法是正确的。因此,x = &v
将v
的地址分配为x
的值。
第一个为x
赋值。第二个具有未定义的行为。
int v=7;
假设地址 v = 00ZXCDFCDGDD2345
int x=&v;
这里的'&'表示地址和x用于存储地址*(00ZXCDFCDGDD2345)*
,而x本身存储在某个位置表示*00254DBHJBDHDW*
。
现在,如果我们想访问 v 的值,我们使用指针。
int *x=v;
在此语句中,'*x' 是一个指向 v 的指针变量,表示它存储v的值,但 x 本身是未定义的,它存储垃圾值。 因此,两者都是不同的。
- 在提升multi_index容器中,是否定义了"default index"?
- 在C++STL中是否有Polyval(Matlab函数)等价物?
- 检查输入是否不是整数或数字
- 是否可以初始化不可复制类型的成员变量(或基类)
- 在C++中,是否可以基于给定的标识符创建基类的新实例,反之亦然
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 此代码是否违反一个定义规则
- 是否需要删除包含对象的"pair"?
- 是否可以从int转换为enum类类型
- 无论条件是否为true,if总是在c++中执行
- 如何找到大小'x'数组是否完全填充,在C++?
- 检查值是否在集合p1和p2中,但不在p3中
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 检查 std::shared_ptr<> 的当前底层类型是否为 T
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- GL_SHADERSTORAGE_BUFFER位置是否与其他着色器位置冲突
- 子目录是否继承属性,例如add_definitions,include_directories和父Cmakelist.t
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- C/C++预处理器是否可以检测一些编译器选项
- 是否可以用"iostream"包装现有的TCP/OOpenSSL会话