%p 和 cout 和 ptr 之间的C++区别
C++ difference between %p and cout &ptr
所以我有一段代码需要打印一个数字的地址和一个ptr的地址。这是代码:
int main() {
float number1 = 1;
float number2;
float *fPtr;
fPtr = &number1;
cout << "Value of object pointed to by fPtr: " << *fPtr << endl;
cout << "Value of number 2: " << number2 << endl;
cout << "Address of number 1: " << &number1 << endl;
printf("%pn", &number1);
cout << "Address fPtr: " << &fPtr << endl;
printf("%p", fPtr);
return 0;
}
输出为:
fPtr指向的对象的值:1
数值2:0
编号1的地址:0xbfb7e348
0xbfb7e348
地址fPtr:0xbfb7e34c
0xbfb7e348
为什么使用%p转换说明符打印的两个地址相同?当使用&地址不同,这正是我所期望的,因为number1和fPtr保存在不同的地址中。
除此之外,我去掉了&来自语句'printf("%p\n",&number1);'返回值为零。有人能解释一下原因吗?
在这里,您正在打印fPtr
:的地址
cout << "Address fPtr: " << &fPtr << endl;
在这里,您打印的是fPtr
:的值
printf("%p", fPtr);
这不是一回事。
如果你想用printf
打印fPtr
的地址,那么你需要
printf("%p", &fPtr);
如果你想用std::cout
打印fPtr
的值,那么你需要
cout << fPtr << endl;
代码似乎缺少&在printf行中的fPtr之前。尝试更改为:
printf("%p", &fPtr);
为什么使用%p转换说明符打印的两个地址相同?
好吧,你有
fPtr = &number1;
// ...
printf("%pn", &number1);
// ...
printf("%p", fPtr);
如果两个printf()
调用确实而打印了相同的东西,那将是非常令人惊讶的,因为它们被要求打印的值是相等的。
除此之外,我去掉了&来自语句'printf("%p\n",&number1);'返回值为零。有人能解释一下原因吗?
不,不是一般意义上的。当与转换说明符对应的参数的类型不适合该说明符时,printf()
的行为是未定义的。%p
说明符需要一个指针,但您传递了一个double
(在适用的默认转换之后)。
相关文章:
- C++中std::resize(n)和std::shrink_to_fit之间的区别
- int(c) 和 c-'0' 之间的区别。C++
- 向量 <int> a {N, 0} 和 int arr a[N] = {0} 的时间复杂度有什么区别
- C++ - "!pointer"和"pointer == nullptr"的区别?
- C++ 使用 assign 函数的字符串与直接使用 '=' 更改值的字符串之间的区别
- std::atomic和std::condition_variable wait,notify_*方法之间的区别
- 在 .h 文件中的类中声明静态变量和在.cpp文件中声明"global"变量有什么区别
- 我是C++编程的新手,这些代码之间有什么区别,我应该使用哪一个
- 在 const 函数中通过引用和指针返回之间的区别
- 我想知道长双倍和双倍之间的区别
- 返回常量对象引用 (getter) 和仅返回字符串有什么区别?
- 返回递归调用和仅递归调用的区别
- Qt:remove() 和 rmdir() 有什么区别
- 这 4 个 lambda 表达式之间有什么区别?
- 结构体 S { int align; } 之间的区别;(struct 关键字后的名称)和 struct { int al
- (double) 和 double() 之间的区别
- 将向量作为类>(值)<向量启动和向量<类>[值]有什么区别
- typedef 枚举和枚举类有什么区别?
- &C::c 和 &(C::c) 有什么区别?
- ascii 和 unicode 在处理级别有什么区别吗?