指向'char buffer[128]'的指针和引用
Pointers and references to 'char buffer[128]'
>我有一个简单的程序:
char buffer[128]; // creates an array of 128 elements
memset(&buffer, 65, sizeof(buffer)); // fills buffer with 'A' (ascii 65) letter
cout << buffer << endl; // prints whole buffer - 128 times 'A' letter
cout << &buffer << endl; // prints adress of a buffer (first element of it)
cout << buffer[0] << endl; // prints first element of a buffer
到目前为止,一切都很好,但是当我称之为时,我不明白为什么
:cout << &buffer[0] << endl;
恕我直言,上面的代码应该打印缓冲区中第一个元素的地址(与&buffer
相同(,但它打印整个缓冲区,就像cout << buffer << endl;
为什么会这样?
这是因为&buffer[0]
是一个char*
,并且const char*
有一个std::ostream& operator<<
重载,它假设它是以 nul 结尾的字符串的第一个元素,并打印其字符。
&buffer[0] == buffer + 0 == buffer
并打印整个数组。
因为它是一样的。 buffer[0] 是偏移量为 0 (*(buffer+0(( 的缓冲区的取消引用。然后你再次计算它的地址,你会得到缓冲区。
你应该试试
cout << (void*) buffer << endl
相关文章:
- 如何使用基类指针引用派生类成员
- 将常量指针引用绑定到非常量指针
- 如果非动态变量被指针引用,何时超出范围?
- 转换指针引用的字符串
- 指针引用的生存期(以 C++为单位)
- 从 unique_ptr::get 发送指针作为指针引用进入函数
- 指针/引用的 CLion 格式
- 使用模板专用化来比较指针引用
- 如何保存指向抽象基类的指针/引用,但在 c++ 中仍然可以复制
- C++初始化指针/引用/复制细微差别
- 用数组或指针引用函数?
- 指针范围问题和返回类中封装的指针向量内的指针引用
- 强制转换为指针引用是否会导致未定义的行为
- 访问由 void 指针引用的结构的成员
- C 为什么当先前的步骤引发异常时,std :: shared_ptr的指针引用会被破坏
- 动态指针引用数组由三元运算符返回值,但有异常
- 悬空指向 int 和 char* 常量的指针/引用
- C++ 二维数组和指针引用
- 通过使用指针/引用,在C++中使用向量加快计算速度
- C++非类型模板模板到函数指针/引用