

新闻资讯
技术教程用 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 中)。
for (int i = 0; i —— 这等于主动放弃性能
try { ... } catch (const std::out_of_range&) { ... },不是自动静默失败front() 语义最清晰,空串时仍 UBstr.front() 和 str[0] 行为一致,都是直接访问首元素,不检查空。但它语义更强:明确表达“我要头元素”,可读性优于下标。
注意:C++11 起才有 front();C++17 增加了 front() const,所以 const string 也能调。
[0] 更自文档化,推荐在强调意图时使用back() 对称,便于统一风格front() 对空串是未定义行为,不会抛异常,也不会返回 \0
真要兼顾安全与简洁,得自己兜底。没有银弹,只有明确判断:
char first_char = str.empty() ? '\0' : str[0];
或者返回可选值(C++17):
std::optionalsafe_front(const std::string& s) { return s.empty() ? std::nullopt : std::optional{s[0]}; }
别依赖 data() 或 c_str() 加指针解引用——虽然 str.data()[0] 在非空时有效,但 data() 对空串返回的指针不一定可解引用(C++20 前未保证),反而增加理解负担。
空字符串的判定必须用 empty() 或 size() == 0,别用 str[0] = 判断是否为空——那只是碰巧成立,且先触发了 UB。