I am running valgrind tool on our code base and I see many memory leaks in the below function.
std::string utils::toUtf8(const sdk::String& str)
{
ByteString byteStr = str.ToUtf8();
return std::string(byteStr.GetConstData());
}
- sdk::String is our internal string object representation.
- str.ToUtf8() returns a ByteString object which releases memory after its lifetime(at the end of this function).
- getConstData() returns a const char pointer to the above ByteString object contents
Below is the back trace
==2833== 3,830 bytes in 160 blocks are definitely lost in loss record 33,600 of 34,381
==2833== at 0x40084DA: malloc (vg_replace_malloc.c:296)
==2833== by 0x43898CC: SCHeapAlloc (in /opt/sw/libSystemCommon-2.7.so)
==2833== by 0x459BCF64: std::string::_Rep::_S_create(unsigned int, unsigned int, std::allocator<char> const&) (in /usr/lib/libstdc++.so.6.0.17)
==2833== by 0x459BEE9D: char* std::string::_S_construct<char const*>(char const*, char const*, std::allocator<char> const&, std::forward_iterator_tag) (in /usr/lib/libstdc++.so.6.0.17)
==2833== by 0x459BF59A: std::basic_string<char, std::char_traits<char>, std::allocator<char> >::basic_string(char const*, std::allocator<char> const&) (in /usr/lib/libstdc++.so.6.0.17)
==2833== by 0x1359C87B: utils::toUtf8(sdk::String const&) (String.cpp:17)
I am not able to understand why returning a simple string object is leaking memory.