std::string 数据buffer 在centos下的表现
- 在拷贝的时候:
std::string a = "test";
std::string b = a;
b 和a 的数据buffer是同一块内存。 a和b用智能指针来管理这块内存。
- 在数据改变的时候:
a = "a_test";
那么a会重新malloc一块内存放置新的数据, 老的buffer仍然给b使用。 这是std::string的延迟拷贝特性。
- 在等长数据填充的时候:
for_each(b.begin(), b.end(), [](char& c){c='a';});
b仍会使用旧buffer。
- std::string::clear():
clear操作只是把‘\0’放在buffer[0]处, 实质上数据还是可以通过内存查到。 - 慎用memset处理string的数据buffer
因为std::string copy后仍然共享数据buffer, 所以贸然使用memset或者OPENSSL_cleanse 来清空buffer, 很可能会导致逻辑异常。比如:
std::string a = "test";
std::string b = a;
OPENSSL_cleanse(&a[0], a.size());
std::cout << b << std::endl;
b的数据也被破坏了。