CMake构建学习笔记17-uriparser库的构建和使用

鼠扑  金牌会员 | 2024-9-17 12:38:53 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 923|帖子 923|积分 2769

在一连论述了几篇关于CMake如何使用的文章之后,笔者也是感觉被掏空了。接下来几篇就照旧回到构建依赖库的题目上,容笔者花时间找到更好的主题来介绍更多关于CMake使用干货。如何有的读者自大已经很认识这方面的知识,可以进行跳过,在必要的时候再进行查阅。
uriparser是一个严酷遵循RFC 3986的URI解析和处理库,使用C89(“ANSI C”)编写。笔者认为在构建上uriparser这个库非常不错,在主页上就已经提供了CMake项目的引入示例和可用的CMake构建选项,大家可以参考一下。不得不说,要是所有的第三方库的文档都写的这么清晰那就世界和平了。
好了不废话了,直接给出构建的关键指令如下所示:
  1. # 配置CMake  
  2. cmake .. -G "$Generator" -A x64 `
  3.     -DCMAKE_BUILD_TYPE=RelWithDebInfo `
  4.     -DCMAKE_INSTALL_PREFIX="$InstallDir" `
  5.     -DURIPARSER_BUILD_TESTS=OFF `
  6.     -DURIPARSER_BUILD_DOCS=OFF
  7. # 构建阶段,指定构建类型
  8. cmake --build . --config RelWithDebInfo
  9. # 安装阶段,指定构建类型和安装目标
  10. cmake --build . --config RelWithDebInfo --target install
复制代码
另外笔者重要使用这个库对URI字符串进行解码,使用的函数如下所示:
  1. std::string UriDecode(const std::string& encoded) {
  2.   // 创建一个可修改的字符缓冲区
  3.   std::vector<char> buffer(encoded.begin(), encoded.end());
  4.   buffer.push_back('\0');  // 确保以 '\0' 结尾
  5.   // 进行解码,uriUnescapeInPlaceA 解码数据时修改输入缓冲区
  6.   uriUnescapeInPlaceA(buffer.data());
  7.   return buffer.data();
  8. }
复制代码
有以下几点必要注意:

  • uriUnescapeInPlaceA只解码%开头的字符,+字符大概换行编码必要自己处理大概使用其他API。
  • uriUnescapeInPlaceA不用思量资源开释的题目,由于是在自身的资源空间处理的,解码的字符串长度只会收缩,所以资源空间够用,不用额外申请。
  • 尝试过直接在std::string管理的字符串空间进行修改,也可以得到正常的结果且效率更高。不过chatgpt的回答表示这样不太安全,就照旧多申请了一段空间std::vector buffer来进行处理。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

鼠扑

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表