std::string_view是C++17引入的轻量只读字符串视图,仅持起始指针和长度,零拷贝、不拥有所指数据;适用于函数参数、切片等高频只读场景,但需确保底层内存生命周期长于view本身。

std::string_view 是 C++17 引入的一个轻量级、只读的字符串“视图”类型,它不拥有字符串数据,只是持有指向已有字符串内存的指针和长度——因此不分配内存、不复制字符,天然支持零拷贝。
为什么叫“视图”而不是“字符串”?
它本身不管理内存,也不存储字符数据,只记录两个信息:起始地址 + 长度。你可以把它理解成一个“窗口”,透过它看一段已存在的字符序列(比如 const char*、std::string、字面量等),但不能修改内容,也不能延长生命周期。
构造开销极小:仅 2 个指针大小(通常 16 字节)避免隐式转换和临时 std::string 构造(尤其在函数参数中)对字符串字面量(如 “hello”)直接视图化,无任何运行时开销
典型用法:替代 const std::string& 参数
旧写法常把函数参数设为 const std::string&,看似避免拷贝,但调用时若传入 C 风格字符串或字面量,会隐式构造临时 std::string,产生堆分配和复制;而用 std::string_view 就能统一、高效地接收各种来源:
"abc" → 直接绑定,零成本std::string s = "def"; f(s); → 取 s.data() 和 s.size(),无复制const char* p = "xyz"; f(p); → 自动推导长度(遇 停止),注意:若 p 不以 结尾或含内嵌 ,需显式指定长度
使用时要注意的坑
因为 string_view 不拥有数据,它依赖外部内存的有效性:
立即学习“C++免费学习笔记(深入)”;
绝不能保存指向局部 std::string 或临时对象的 string_view(例如 return std::string_view(s);,s 出作用域后视图悬空)对 C 字符串构造时,默认按 截断;若原始数据含 或无结束符,应显式传入长度:std::string_view(p, len)不提供 .c_str() 方法(无权保证返回指针长期有效),需要时可手动取 .data()
适合哪些场景?
高频、只读、多来源的字符串处理是它的主场:
函数参数(尤其是库接口、解析器、格式化函数)字符串切片(substr 返回仍是 string_view,仍零拷贝)编译期字符串处理(配合 constexpr,C++20 起更强大)避免日志、配置、路径拼接等场景中的冗余分配
以上就是c++++的std::string_view是什么 零拷贝的字符串视图【性能优化】的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1489717.html
微信扫一扫
支付宝扫一扫