std::string_view是C++17引入的轻量级只读字符串视图,仅存储指针和长度,不拥有数据、零拷贝、支持多种来源隐式构造,适用于函数参数、切片、解析等只读场景,但需确保所指数据生命周期足够长。

std::string_view 是 C++17 引入的一个轻量级、只读的字符串“视图”,它不拥有字符串数据,只是对已有字符序列(比如 const char*、std::string 或字符数组)的引用和长度封装。
为什么需要 string_view?——避免不必要的拷贝
传统上,函数接收字符串常习惯用 const std::string&,但这样会隐式接受一个临时 std::string,触发堆内存分配和拷贝。例如:
log("hello"); // 构造临时 string → 拷贝 "hello" 到堆
而用 std::string_view:
log("hello"); // 直接指向字面量,零拷贝
关键点:
立即学习“C++免费学习笔记(深入)”;
- 不管理内存,仅存指针 + 长度(通常仅 16 字节)
- 支持从 C 风格字符串、std::string、字符数组等隐式构造
- 不可修改内容(只读),线程安全读取
string_view 的典型使用场景
适合所有“只读访问字符串内容、且生命周期可控”的场合:
- 函数参数:替代
const std::string&和const char*,统一接口又免拷贝 - 字符串切片:用
substr()快速获取子串视图,不分配新内存 - 解析/分词:如按空格拆分时,每个 token 都是原字符串的一段 view
- 哈希或比较:直接操作底层字符,比 string 更快(无 size() 调用开销,长度已知)
示例:
std::string data = "name=alice&age=30";auto pos = data.find('=');
std::string_view key(data.c_str(), pos); // "name"
std::string_view value(&data[pos+1], data.size() - pos - 1); // "alice&age=30"
使用 string_view 的注意事项
它高效,但不“安全”——使用者必须确保它所指向的原始数据在 view 生命周期内有效:
- 不要用局部字符数组或临时 string 的 data() 构造持久 string_view
- 避免返回局部 string 的 substr().data() —— view 会悬空
- 不能直接用作 map 的 key(因为无默认哈希和比较特化),需显式转换或自定义
- 不以 '\0' 结尾,所以不能直接传给 C 函数(需 .data() + .size() 配合,或转为 null-terminated 临时 buffer)
与 const char* 和 const std::string& 的对比
三者定位不同:
-
const char*:C 风格,无长度信息,需 strlen,易越界 -
const std::string&:安全但重(可能触发拷贝),接口不灵活 -
std::string_view:轻量、安全(带长度)、通用(支持多种来源)、零成本抽象
一句话总结:当你只需要“看看字符串”,别让它搬家(拷贝),就用 string_view。
基本上就这些。











