C++ string::at和下标访问区别_C++字符串越界检查安全性对比

admin 百科 13
c++kquote>string::at会进行越界检查并抛出异常,而operator[]不检查,越界访问导致未定义行为;at更安全但性能略低,operator[]适用于已知合法索引的高效场景。

C++ string::at和下标访问区别_C++字符串越界检查安全性对比-第1张图片-佛山资讯网

在C++中,string::at下标访问(operator[]) 都用于获取字符串中指定位置的字符,但它们在越界检查和异常处理方面有重要区别。理解这些差异有助于写出更安全、健壮的代码。

1. 越界检查机制不同

string::at 在访问时会进行边界检查。如果索引超出字符串的有效范围(即 >= string.size()),它会抛出 std::out_of_range 异常。

operator[] 不提供运行时越界检查。访问非法索引属于未定义行为(undefined behavior),可能导致程序崩溃或数据损坏,但不会主动抛出异常。

示例对比:

#include <string>
#include <iostream>
#include <stdexcept>

int main() {
    std::string str = "hello";

    try {
        // 使用 at(),越界时抛出异常
        char c1 = str.at(10);  // 抛出 std::out_of_range
    } catch (const std::out_of_range& e) {
        std::cout << "at() 越界: " << e.what() << "\n";
    }

    // 使用 [],越界行为未定义,可能崩溃
    char c2 = str[10];  // 危险!不要这样做
    std::cout << "str[10] = " << c2 << "\n";  // 输出不可预测
}

登录后复制

2. 性能与安全性权衡

at() 因为每次调用都做边界检查,会有轻微性能开销,适合调试或需要确保安全的场景。

标签: ai c++ ios stream 区别

发布评论 0条评论)

还木有评论哦,快来抢沙发吧~