为什么当我使用 std::string::operator[] 时自动变量不会成为引用?
why auto variable won't become reference when I use std::string::operator[]?
std::string::operator[] 应该返回字符引用:
char& operator[] (size_t pos);
但是当我将其传递给自动类型时,它将变成一个简单的字符。为什么它不会变成一个字符?
我有以下代码:
std::string str = "Hello";
auto strRef = str[1];
strRef = std::toupper(strRef);
std::cout << "str after:" << str << std::endl;
在输出上,我会得到"Hello"而不是"HEllo"。
当您将变量定义为非引用和非指针时,初始值设定项的引用部分将被忽略,然后strRef
被推导出为char
; 该规则与模板参数推导相同。
您需要将其显式声明为引用。
auto& strRef = str[1];
相关文章:
- C++Boost Asio Pool线程,带有lambda函数和传递引用变量
- 多个"常量引用"变量可以共享同一个内存吗?
- 如果非动态变量被指针引用,何时超出范围?
- 在 c++ 中将变量作为结构构造函数中的引用传递
- 在 gtest 中初始化堆栈上的引用变量的隔离错误
- 为什么C++可以使用未初始化的成员变量(引用或指针 *NOT 值复制*)来初始化其父类的成员变量
- 地址运算符是否返回变量引用的对象的地址
- 未在另一个函数中设置变量引用的问题
- 英特尔样式内联程序集和 AT&T 样式中的变量引用,C++
- 将成员变量引用为类成员
- 从静态变量引用非静态变量会使非静态变量先于静态变量进行析构函数
- 何时解析 C++11 lambda 表达式中的变量引用
- 堆栈/堆变量的变量/引用名称或类型存储在内存中的位置
- C++强制对变量引用进行编译优化,使之成为直接的
- Boost变量引用和相等比较
- 使复制的成员引用变量引用副本的成员,而不是原始成员的成员
- 为什么要在Java中生成变量引用数组
- 捕获和调试对移动lambda内部局部变量引用的无效使用
- 在变量初始化后更改变量引用
- 从'C'程序中提取变量定义和变量引用