跟Google学写代码--Chromium/base--stl_util源码学习及应用

Ttile: Chromium/base–stl_util源码学习及应用

Chromium是一个伟大的、庞大的开源工程,很多值得我们学习的地方。

今天与大家分享的就是Chromium下base中的stl_util,是对stl的补充,封装,更有利于我们的使用,完全可以移植到自己的C++工程项目中来。

1 释放STL内存
Clears internal memory of an STL object.

我们知道,vector的clear()方法式清除了vector中的内容,但是vector object所占的内存不会清除。

因此,std_util中有个这个方法:

template<class T>
void STLClearObject(T* obj) {
  T tmp;
  tmp.swap(*obj);
  // Sometimes "T tmp" allocates objects with memory (arena implementation?).
  // Hence using additional reserve(0) even if it doesn't always work.
  obj->reserve(0);
}

也就是使用swap,之前写过一篇博客:
《实战c++中的vector系列–正确释放vector的内存(clear(), swap(), shrink_to_fit())》
地址:http://blog.csdn.net/wangshubo1989/article/details/50359750

2 释放容器内的指针对象
这里隐藏了一个巨大的坑儿,就是迭代器的失效问题,之前也有博客里面介绍过:

《实战c++中的vector系列–可怕的迭代器失效(vector重新申请内存)》
地址:http://blog.csdn.net/wangshubo1989/article/details/50334297

《实战c++中的vector系列–可怕的迭代器失效之二(删除vector中元素)》
地址:http://blog.csdn.net/wangshubo1989/article/details/50334503

template <class ForwardIterator>
void STLDeleteContainerPointers(ForwardIterator begin, ForwardIterator end) {
  while (begin != end) {
    ForwardIterator temp = begin;
    ++begin;
    delete *temp;
  }
}

3 正确删除容器内pairs对象

template <class ForwardIterator>
void STLDeleteContainerPairPointers(ForwardIterator begin,
                                    ForwardIterator end) {
  while (begin != end) {
    ForwardIterator temp = begin;
    ++begin;
    delete temp->first;
    delete temp->second;
  }
}

4 删除容器内pairs对象中的第一个元素

template <class ForwardIterator>
void STLDeleteContainerPairFirstPointers(ForwardIterator begin,
                                         ForwardIterator end) {
  while (begin != end) {
    ForwardIterator temp = begin;
    ++begin;
    delete temp->first;
  }
}

5 删除容器内pairs对象中的第二个元素

template <class ForwardIterator>
### OceanBase 协议详解 #### Mysql协议兼容性 OceanBase 客户端与 MergeServer 之间采用 MySQL 协议进行通信。这意味着任何支持标准 MySQL 协议的应用程序都可以无缝连接到 OceanBase 数据库,无需额外开发工作[^4]。 #### SQL处理流程 当用户向 OceanBase 发送一条 SQL 请求时,MergeServer 首先接收并解析这条请求中的 MySQL 协议数据包。随后,系统会对该 SQL 进行词法分析和语法验证,确保其合法性。一旦确认无误,则继续执行后续阶段的工作——即构建逻辑查询计划(Logical Query Plan),再进一步转换成具体的物理查询计划(Physical Execution Plan)。最终依据此计划来调用相应的内部操作函数完成整个查询过程。 ```sql SELECT * FROM table_name WHERE condition; ``` 以上是一个简单的 SQL 查询例子,它会被按照上述描述的方式逐步处理直至返回结果给客户端应用。 #### 应用实例:使用 C/C++ 程序访问 OceanBase 由于 OceanBase 支持 MySQL 的 lib 库 (例如 MySQL Connector/C),因此可以直接利用这些接口编 C 或者 C++ 代码实现对 OceanBase 数据库的操作。下面给出一段基本示例: ```c++ #include <mysql.h> // 初始化 MySQL 结构体指针 my_connection 和其他必要的变量... if (!mysql_real_connect(my_connection, "localhost", "root", "", "testdb", 0, NULL, CLIENT_MULTI_STATEMENTS)) { fprintf(stderr, "%s\n", mysql_error(my_connection)); } else{ printf("Connected successfully!\n"); } char* query = "INSERT INTO test_table VALUES ('value')"; int ret = mysql_query(my_connection ,query); if(ret){ finish_with_error(my_connection); } ``` 这段代码展示了怎样建立同本地运行着的 OceanBase 实例间的 TCP/IP 连接,并尝试插入一行记录至指定表内;如果遇到错误则会打印出来以便调试[^2]。
评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一苇渡江694

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值