//
错误 C2039 “staticMetaObject”: 不是“CommunicateManageData”的成员
错误 C2039 “qt_metacast”: 不是“CommunicateManageData”的成员
错误 C2039 “qt_metacall”: 不是“CommunicateManageData”的成员
错误写法:
class SelfModBus : public CommunicateManageData, public QObject
正确写法:
class SelfModBus : public QObject, public CommunicateManageData
解决办法:子类优先继承Qt的类
//
在子线程创建了一个QObject的子类,之后销毁掉该子线程,会导致QObject子类无法响应槽函数
先查看对象所属线程
cout << QObject::thread();//对象所依附线程已被销毁
解决办法:在创建QObject的子类时,改变QObject的子类的归属线程
QThread *thread = QCoreApplication::instance()->thread();//获取主线程
object->moveToThread(thread);
//
C++错误代码0x4000015
犯了很严重的错误,函数返回引用作为参数传给另一个函数,导致内存被提前释放
class A
{
public:
double position[MAX] = {};
};
double A::operator[](int id)
{
return position[id];
}
A a;
execute_fun(a[0]);//因为我重载的[]返回值是引用,所以execute_fun执行完后把我的a[0]内存释放掉了,血的教训
解决办法:重载函数[]不返回引用了,函数返回引用很不安全
//
C++数组下标越界时不一定会奔溃,这对程序定位有时候造成很大麻烦,甚至有时候数组下标是负数的也没事,原因是数组申请的内存可能刚好与程序其他变量的内存相邻
解决办法:用容器比较方便,一越界就会奔溃
//
//此时dlg.data是基类指针
CommunicateIo * new_data = (CommunicateIo *)dlg._data;
基类指针转子类指针时,发现子类指针所指向的内容错乱了,很疑惑
解决办法:忘记添加子类头文件,但是编译竟然不会报错