不要对C++类对象或struct对象做memset操作
2017-09-14 14:18
381 查看
wsrt进程在处理upgradeAccess部分一直Segment fault,又一直没看出问题。
http://blog.csdn.net/yasi_xi/article/details/17840225
原因在于这句修改,前一个版本没问题,后一个版本必现的话,注意查看版本间相关流程的差异,其实你对比的两个版本之间只有这一句有差异,你没仔细看
CUpgradeAccess cUpgradeAccess;
//memset(&cUpgradeAccess,sizeof(cUpgradeAccess),0);
memset(&cUpgradeAccess,0,sizeof(cUpgradeAccess));
前面的写法有问题,实际上没有实质操作。 而这里本来也不需要实质操作,所以是将错就错
后面写法改对了,产生了实质操作,然后就crash了
参考页面中有下面代码:
[cpp] view plain copy print?
#include <string.h>
int main() {
struct TestStruct
{
int a;
std::string b;
};
TestStruct t = {}; // OK
{
TestStruct t1;
memset(&t1, 0, sizeof t1); // ruins member 'b' of our struct
} // Application crashes here
return 0;
}
TestStruct t = {} 是正确的做法,而memset(&t1, 0, sizeof t1) 会导致crash。
crash的原因:
程序在第13行创建 t1 对象,在第15行出了{}作用域的时候,会自动执行 t1 的析构。
在析构到 t1 的string成员 b 的时候,因为 b 的内部结构都被
memset 破坏了(都赋成0了),从而不能正常进行析构操作,最终导致crash。
Crash时的callstack如下:
[plain] view
plain copy print?
(gdb) bt
#0 0x00007f383f9154ab in std::basic_string<char, std::char_traits<char>, std::allocator<char> >::~basic_string() ()
from /usr/lib64/libstdc++.so.6
#1 0x0000000000400810 in TestStruct::~TestStruct (this=0x7fff57c54ee0, __in_chrg=<value optimized out>) at t.cpp:11
#2 0x0000000000400889 in main () at t.cpp:20
http://blog.csdn.net/yasi_xi/article/details/17840225
原因在于这句修改,前一个版本没问题,后一个版本必现的话,注意查看版本间相关流程的差异,其实你对比的两个版本之间只有这一句有差异,你没仔细看
CUpgradeAccess cUpgradeAccess;
//memset(&cUpgradeAccess,sizeof(cUpgradeAccess),0);
memset(&cUpgradeAccess,0,sizeof(cUpgradeAccess));
前面的写法有问题,实际上没有实质操作。 而这里本来也不需要实质操作,所以是将错就错
后面写法改对了,产生了实质操作,然后就crash了
参考页面中有下面代码:
[cpp] view plain copy print?
#include <string.h>
int main() {
struct TestStruct
{
int a;
std::string b;
};
TestStruct t = {}; // OK
{
TestStruct t1;
memset(&t1, 0, sizeof t1); // ruins member 'b' of our struct
} // Application crashes here
return 0;
}
#include <string.h> int main() { struct TestStruct { int a; std::string b; }; TestStruct t = {}; // OK { TestStruct t1; memset(&t1, 0, sizeof t1); // ruins member 'b' of our struct } // Application crashes here return 0; }
TestStruct t = {} 是正确的做法,而memset(&t1, 0, sizeof t1) 会导致crash。
crash的原因:
程序在第13行创建 t1 对象,在第15行出了{}作用域的时候,会自动执行 t1 的析构。
在析构到 t1 的string成员 b 的时候,因为 b 的内部结构都被
memset 破坏了(都赋成0了),从而不能正常进行析构操作,最终导致crash。
Crash时的callstack如下:
[plain] view
plain copy print?
(gdb) bt
#0 0x00007f383f9154ab in std::basic_string<char, std::char_traits<char>, std::allocator<char> >::~basic_string() ()
from /usr/lib64/libstdc++.so.6
#1 0x0000000000400810 in TestStruct::~TestStruct (this=0x7fff57c54ee0, __in_chrg=<value optimized out>) at t.cpp:11
#2 0x0000000000400889 in main () at t.cpp:20
(gdb) bt #0 0x00007f383f9154ab in std::basic_string<char, std::char_traits<char>, std::allocator<char> >::~basic_string() () from /usr/lib64/libstdc++.so.6 #1 0x0000000000400810 in TestStruct::~TestStruct (this=0x7fff57c54ee0, __in_chrg=<value optimized out>) at t.cpp:11 #2 0x0000000000400889 in main () at t.cpp:20
相关文章推荐
- 不要对C++类对象或struct对象做memset操作
- 用ORM的思想操作XML文档,一个对象就搞定不要太简单。滚蛋吧!XmlDocument、XmlNode、Xml***……
- 通过操作地址的方法来访问C++类对象中私有成员变量
- struct 和 (对象)std:string不要混用
- 在全局对象(不是指针)的构造函数里不要对std集合做太多操作
- C++类与对象(3) - 空class&struct的大小
- 不要在 foreach 循环里进行元素的 remove/add 操作。remove 元素请使用 Iterator 方式,如果并发操作,需要对 Iterator 对象加锁
- C++类和对象:四个默认函数和运算符重载
- js 实现图片预加载(js操作 Image对象属性complete ,事件onload 异步加载图片)
- C++类和对象的继承
- 一起谈.NET技术,VS2010测试功能之旅:编码的UI测试(3)-操作对象的识别原理
- json对象与字符串转换操作
- Oracle批量删除表、索引等对象、批量恢复Drop操作删除的表、索引等对象
- 直接操作游戏对象C#游戏开发
- Java常用类库——Arrays类(用于普通数组操作)、比较器(Comparable、Comparator 用于对象排序)的使用
- 快速上手之 C#操作WORD对象模型
- Struts2笔记05 action操作域对象
- [android开发]对象的持久化操作 (写入对象到本地文件, 从本地文件中读取对象)
- javascript操作正则表达式对象的方法总结
- Jquery知识点三 jquery表单对象操作