管理QByTearray :: FromRawdata()的内存
Memory Managing QByteArray::fromRawData()
在我的程序中,我具有处理一些数据并将其发送回的功能。在功能中,我分配了一个新的字节数组:
byte *buffer = new byte[bufferSize];
然后,我将其传递给填充一些数据的库。完成后,我想将其发送回QByteArray
。所以我打电话:
myByteArray = QByteArray::fromRawData(reinterpret_cast<const char*>(buffer), bufferSize);
字节阵列返回,一切都很好,但是我现在有一个内存泄漏(自从我的RAM使用Skyrockets以来,自从我打电话数千次以来就可以肯定(。当我将buffer
分配给New时,我在调用fromRawData
后无法将其删除,因为myByteArray
共享相同的数据指针。文档状态 The bytes are not copied. The QByteArray will contain the data pointer.
所以我的问题是,当myByteArray
脱离范围时,如何确保buffer
被删除?它不在类中的范围。
感谢您的时间。
,而不是用new[]
手动分配数组,您可以直接从QByteArray
开始。
QByteArray myByteArray;
myByteArray.resize( bufferSize );
byte * buffer = myByteArray.data(); // Pointer to the memory allocated by the QByteArray
// Pass 'buffer' to library function..
相关文章:
- 将字符串存储在c++中的稳定内存中
- C++ 指针的内存地址和指向数组的内存地址如何相同?
- Win32编译器选项和内存分配
- 当vector是tje全局变量时,c++中vector的内存管理
- 带内存和隔离功能的SQLite
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 迭代时从向量和内存中删除对象
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 多个文件的内存分配错误"在抛出 'std :: bad_alloc' what (): std :: bad_alloc 的实例后终止调用" [C++]
- 为什么示例代码访问IUnknown中已删除的内存
- 如何在C++类内存结构中创建"spacer"?
- 从构造函数抛出异常时如何克服内存泄漏
- malloc() 可能出现内存泄漏
- 如何理解将半精度指针转换为无符号长指针和相关的内存对齐
- 在调用FreeLibrary后,释放动态链接到具有相同版本的CRT堆的DLL的内存
- 如何针对特定情况调试和修复此双自由内存损坏问题
- 类型总是使用其大小存储在内存中吗
- 管理QByTearray :: FromRawdata()的内存
- 确保 QByteArray 拥有其内存 (QByteArray::fromRawData)