草庐IT

qobject_cast

全部标签

c++ - 在 visual studio 2010 中为新的 QOBJECT 文件生成 MOC

我使用qmake创建了一个项目,它自动为直接或间接继承QObject的类生成moc文件。但是,如果我添加一个继承QObject的新类,则QT插件在构建过程中不会生成MOC文件。我应该调整哪些设置以便每次添加新的QObject文件时都可以自动执行此操作? 最佳答案 如果您的自定义类没有自动moc'ed,您可能忘记在类声明中添加Q_OBJECT宏,或者在多重继承的情况下将QObject作为第一个继承的类(类的顺序您的派生类继承事项)。如果不是您的情况,您可能需要阅读以下内容:http://truth2.wordpress.com/201

c++ - Q_INVOKABLE 是否需要在 Qt5 中从 QML 调用公共(public) QObject 函数?

我刚刚意识到我几乎可以调用公开给QML的对象的任何函数。现在我对Q_INVOKABLE很好奇。Qt5docs状态:[...]anyQMLcodecanaccessthefollowingmembersofaninstanceofaQObject-derivedclass:PropertiesMethods(providingtheyarepublicslotsorflaggedwithQ_INVOKABLE)SignalsSinceQt5(在C++中)我可以像槽一样调用QObject的任何公共(public)函数,即我不必将它们声明为“公共(public)槽”。这是否意味着我可以从QM

c++ - 如何将低级常量应用于模板变量。我正在尝试编写一个 const_cast 实现

如何让这个static_assert传递到我失败的代码中?我尝试了T周围const的所有排列,但我无法获得constint*。编译器总是将其解释为int*const。templateunionconst_cast_impl{usingCT=constT;static_assert(std::is_same::value,"CTisnotconstint*");Tdata;CTcdata;const_cast_impl(CTptr):cdata(ptr){}operatorT(){returndata;}};intmain(){inta=2;constint*ptr=&a;int*ptr

c++ - Static Cast 访问静态 const 类成员

这个问题在这里已经有了答案:Undefinedreferencetostaticconstint(9个回答)关闭5年前。所以昨天我正在寻找SO,但找不到以下问题的答案。这种情况来self正在使用的一些代码,但这里是MCVE来演示它。我在A.h中定义了一个类A,其中只有一个静态常量。我已经在标题中对其进行了初始化。#ifndefA_H_#defineA_H_classA{public:staticconstinttest=5;~A(){};};#endif/*A_H_*/然后我有一个B类需要从A类访问publicstaticconst。在这个例子中,它将把值深度复制到一个vector中。

c++ - 有什么理由更喜欢 static_cast 而不是一系列隐式转换?

假设我有一个实现多个接口(interface)的类classCMyClass:publicIInterface1,publicIInterface2{};并且在该类的一个成员函数中,我需要获得一个指向这些接口(interface)之一的void*指针(IUnknown::QueryInterface()中的典型情况。典型的解决方案是使用一个static_cast来实现指针调整:void*pointer=static_cast(this);如果没有从CMyClass继承的已知类,在这种情况下是安全的。但是如果这样的类存在:classCDerivedClass:publicCUnrelat

c++ - 什么时候需要 dynamic_cast?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:dynamic_castinc++这两种将派生类赋值给基类指针的方式有什么区别?Derivedd1;Base*b1=&d1Derivedd2;Base*b2=dynamic_cast&d2

c++ - && 在 bitwise_cast<void*>(&&__opcode) 上下文中的含义;

我正在查看下面来自JavascriptCore的代码,但我不知道&&在下面的上下文中的含义。地址的地址没有任何意义。有人可以解释下&&在下面的上下文中的含义吗。(bitwise_cast使用union来避免reinterpret_cast带来的严格别名问题)下面的代码在clang(可能还有gcc)上编译,但不在我们自己专有的C++编译器上编译。可以找到完整的源代码here.#ifENABLE(COMPUTED_GOTO_OPCODES)Opcode*opcodeMap=LLInt::opcodeMap();#defineOPCODE_ENTRY(__opcode,length)\opc

c++ - 将 C 风格的转换更改为 static_cast 总是安全的吗?

由于cppcheckcstyleCast样式警告,我正在尝试消除代码库中的所有C样式转换。将C风格的转换更改为static_cast总是安全的吗?安全,我的意思是,是否存在旧的C风格转换可以正常工作,但static_cast会引发错误或未定义行为的情况?type1a;type2b=(type2)a;//Cstylecasttype2b=static_cast(a);//Isthisalwaysavalidreplacementforabovecast? 最佳答案 C风格的转换通常是static_cast的组合或reinterpret

c++ - dynamic_cast<> 将变量参数传递给模板

我有一个执行测试用例的C++应用程序。某些测试用例可能会依赖于其他测试用例的输出。所有测试用例都实现一个基本接口(interface):///baseclassforalltestcasesclassITest{public:virtualvoidExecute()=0;};产生一些可能对其他测试用例有用的对象的测试用例实现这个接口(interface):///implementedbytestcasesthatprovidedatatoothertestcasestemplateclassIDependency{public:virtualObjGet()=0;};需要来自其他测试用

c++ - 调用 moveToThread() 不会将 QObject 移动到另一个线程。

设functionClass是从QObject派生的类。在我的QMainWindow类(尚未启动任何其他线程)的类构造函数中,我有以下代码:QThreadworkThread;functionClass*functionClassObj=newfunctionClass;coutthread()->currentThreadId()moveToThread(&workThread);coutthread()->currentThreadId()如果我调用moveToThread(),为什么currentThreadId()函数打印相同的内容? 最佳答案