草庐IT

qobject_cast

全部标签

c++ - 比 C++ 中的 dynamic_cast 更好的解决方案

我有一个为我的项目设计的类层次结构,但我不确定如何实现它的一部分。这是类层次结构:classShape{};classColored{//Onlypurevirtualfunctions};classSquare:publicShape{};classCircle:publicShape{};classColoredSquare:publicSquare,publicColored{};classColoredCircle:publicCircle,publicColored{};在我的部分项目中,我有一个不同类型形状的std::vector。不过,为了运行算法,我需要将它们放在彩色对

c++ - 将 QObject 类公开到 qml 时,在 Qt 中管理内存的正确方法?

我使用C++来编写我的大部分程序逻辑。我喜欢将C++类公开到QML中,以便QML可以使用JS来完成许多复杂的工作。然而,问题来了:如果C++函数返回一个QObject*Q_INVOKABLEQObject*parseJson(constQString&someArguments){returnnewSomeClassExtendsQObject(someArguments);}然后分配给JS变量并使用varresult=exposingCppObj.parseJson("I'mArguments");result.someMemberFunction(...);.....如果我用del

c++ - C 样式转换和 C++ static_cast 到指针的引用

这不是C++11我对微软的第三个参数感兴趣CMapStringToOb::GetNextAssoc,其定义如下:voidGetNextAssoc(POSITION&rNextPosition,CString&rKey,CObject*&rValue)const;然后我得到了以下用于测试的简单代码:两个好的案例和一个编译器错误的案例。classCMyObject:publicCObject//inordertouseCMapStringToOb{public:CMyObject(CStringname_):name(name_){}voidSayHello(){TRACE(_T("hel

c++ - Qt如何删除QObjects?

据我了解,以下代码是创建QObject的完美方式QLabel*label=newQLabel("label");QWidgetwindow;label->setParent(&window);window.show();当我在无处不在阅读时,“父对象获得了新创建对象的所有权——并最终调用了删除”,或者“复合对象获得了子对象的所有权,因此,只要父类拥有完成后,您可以放心,当父级被销毁时,子QObjects将被销毁”(来自HowdoesQtdeleteobjects?AndwhatisthebestwaytostoreQObjects?)有人能告诉我Qt如何“取得”QObject的所有权吗

c++ - static_cast 带走了常量

据我所知(以及本主题:Whenshouldstatic_cast,dynamic_cast,const_castandreinterpret_castbeused?)const_cast是唯一应该能够消除变量常量性的强制转换。然而,当弄乱clang-6.0和g++5.4.0时,我偶然发现了一种与上述相矛盾的行为。看起来static_cast做的工作完全一样。这些主要函数在两个编译器中给出了完全相同的结果:测试类定义structBase{Base(){std::cout使用const_castintmain(void){std::cout(b).no_const();std::cout使

c++ - dynamic_cast 与动态库边界

我正在阅读“C++GUIProgrammingwithQt4”,在那里我发现了以下语句UnliketheStandardC++dynamic_cast(),Qt’sqobject_cast()workscorrectlyacrossdynamiclibraryboundaries.Qt的官方文档中也有类似的说法,网址为https://doc.qt.io/qt-5/qobject.html#qobject_cast这是什么意思?我们不能在C++中使用dynamic_cast的确切位置是什么?那么虚函数呢?将它们与动态链接库一起使用是否安全? 最佳答案

【C++入门到精通】C++类型的转换 | static_cast | reinterpret_cast | const_cast | dynamic_cast [ C++入门 ]

阅读导航引言一、强制转换(集成C语言的语法)二、static_cast操作符1.操作符介绍2.使用示例(1)基本类型之间的转换(2)类型之间的隐式转换(3)类指针和引用之间的转换三、reinterpret_cast操作符1.操作符介绍2.使用示例(1)将指针转换为整数(2)将整数转换为指针(3)将指向基类的指针转换为指向派生类的指针(4)将指向不同类型的指针进行转换四、const_cast操作符1.操作符介绍2.使用示例(1)移除常量性以修改对象的值(2)在函数中移除常量性以调用非常量版本的成员函数(3)移除常量性以进行底层操作五、dynamic_cast操作符1.操作符介绍2.使用示例(1)

c++ - 为什么 const_cast 需要说明你要转换到什么?

根据标准(§5.2.11),const_cast会丢弃cv限定符(const或volatile)。这是一个简单的例子。首先你声明两个函数接受一个指针和一个引用:classBar{...};voidfoo_ptr(Bar*);voidfoo_ref(Bar&);然后你创建一个常量引用:Barb;constBar&cb=b;然后您可以使用适当的const_cast调用任一函数:foo_ptr(const_cast(&cb));foo_ref(const_cast(cb));这是我的问题:既然const_cast不能做其他类型转换的设计目的,那么您要转换成什么不是很明显吗?换句话说,为什么语

c++ - auto_ptr 和 dynamic_pointer_cast

如果我想将dynamic_cast与shared_ptr一起使用,我可以使用dynamic_pointer_cast。如果我想转换auto_ptr,我该用什么?我假设如下所示。structB:A{};...auto_ptrbase(...);auto_ptrderive=dynamic_pointer_cast(base);我正在为shared_ptr使用boost 最佳答案 auto_ptrbase(...);if(B*query=dynamic_cast(base.get())){//takeownershipbase.rele

c++ - char * 和 const_cast<char*>(string.c_str()) 有什么区别

我使用外部库来处理两个应用程序之间的udp(OSC)通信。为了格式化将要发送的消息,库需要一个char*但我从UI中得到一个字符串,我必须转换它。当我处理代码的其他部分时,udp部分是硬编码的:char*endofMess="fromsetEndMess";并且工作正常。我认为使用我的字符串很容易让它工作并写道:std::strings="fromsetEndMess";char*endofMess=const_cast(s.c_str());但与第一个例子不同,我收到的消息格式正确,现在我只收到乱码。有人知道它可能来自哪里吗?谢谢!马修编辑:我使用的代码:每次OSCVal发送消息的方