用 operator[] 直接取 str[0] 最快但不检查越界,适合已知非空场景;at(0) 安全但有异常开销,仅推荐低频路径使用。

用 operator[] 直接取 str[0] 最快,但不检查越界
这是最常用也最轻量的方式:std::String 重载了 [],底层就是数组访问。只要确定字符串非空,str[0] 就是首字符。
但注意:如果 str.empty() 为 true,str[0] 是未定义行为(可能崩溃、返回垃圾值,或看似正常但不可靠)。
- 适合已知非空场景,比如解析固定格式输入、函数入参已校验
- 性能无额外开销,编译器通常内联为单条内存读指令
- 不能用于
const std::string&的只读访问?错——const string也能用[],它返回const char&
用 at(0) 安全但带异常开销
str.at(0) 会做边界检查,越界时抛出 std::out_of_range。适合不确定长度、且愿意用异常处理错误的逻辑。
缺点明显:每次调用都有分支判断和潜在异常栈展开成本,比 [] 慢一个数量级(尤其在 tight loop 中)。
立即学习“C++免费学习笔记(深入)”;
- 仅在调试期或低频路径中推荐,比如配置项解析、用户输入校验
- 别在循环里写
for (int i = 0; i —— 这等于主动放弃性能 - 捕获异常要写
try { ... } catch (const std::out_of_range&) { ... },不是自动静默失败
用 front() 语义最清晰,空串时仍 UB
str.front() 和 str[0] 行为一致,都是直接访问首元素,不检查空。但它语义更强:明确表达“我要头元素”,可读性优于下标。
注意:c++11 起才有 front();C++17 增加了 front() const,所以 const string 也能调。
- 比
[0]更自文档化,推荐在强调意图时使用 - 和
back()对称,便于统一风格 - 同样要求非空——
front()对空串是未定义行为,不会抛异常,也不会返回