Qt中的强制类型转换

在C++开发中经常要进行数据类型的强制转换。

刚开始学习的时候,直接对基本数据类型强制类型转换,如float fnum = 3.14; int num = (int)fnum;

随着C++标准的发展,又提供了dynamic_cast、const_cast 、static_cast、reinterpret_cast等高级安全的强制转换方法。

dynamic_cast: 通常在基类和派生类之间转换时使用,run-time cast。
const_cast: 主要针对const和volatile的转换。
static_cast: 一般的转换,no run-time check.通常,如果你不知道该用哪个,就用这个。
reinterpret_cast: 用于进行没有任何关联之间的转换,比如一个字符指针转换为一个整形数。

QT框架提供的强制类型转换方法:

qobject_cast  qobject_cast()函数的行为类似于标准C ++ dynamic_cast(),其优点是不需要RTTI支持,并且它可以跨动态库边界工作。

QObject *obj = new QTimer;          // QTimer inherits QObject

QTimer *timer = qobject_cast<QTimer *>(obj);

// timer == (QObject *)obj

QAbstractButton *button = qobject_cast<QAbstractButton *>(obj);

// button == 0

qgraphicsitem_cast  场景视图Item类转换

QGraphicsScene和 QGraphicsItem 的大多数便利函数(例如:items(),selectedItems()、collidingItems()、childItems())返回一个 QList<QGraphicsItem *> 列表,在遍历列表的时候,通常需要对其中的 QGraphicsItem 进行类型检测与转换,以确定实际的 item。

以下代码出处:https://blog.csdn.net/liang19890820/article/details/53612446

QList<QGraphicsItem *> items = scene->items();

foreach (QGraphicsItem *item, items) {

if (item->type() == QGraphicsRectItem::Type) {        // 矩形

QGraphicsRectItem *rect = qgraphicsitem_cast<QGraphicsRectItem*>(item);

// 访问 QGraphicsRectItem 的成员

} else if (item->type() == QGraphicsLineItem::Type) {      // 直线

QGraphicsLineItem *line = qgraphicsitem_cast<QGraphicsLineItem*>(item);

// 访问 QGraphicsLineItem 的成员

} else if (item->type() == QGraphicsProxyWidget::Type) {    // 代理 Widget

QGraphicsProxyWidget *proxyWidget = qgraphicsitem_cast<QGraphicsProxyWidget*>(item);

QLabel *label = qobject_cast<QLabel *>(proxyWidget->widget());

// 访问 QLabel 的成员

} else if (item->type() == CustomItem::Type) {         // 自定义 Item

CustomItem *customItem = qgraphicsitem_cast<CustomItem*>(item);

// 访问 CustomItem 的成员

} else {

// 其他类型 item

}

}

需要注意的是,为了使该函数正确使用自定义Item,需要在QGraphicsItem子类中重写type()函数才行。

class CustomItem : public QGraphicsItem

{

public:

enum { Type = UserType + 1 };

int type() const override

{

// Enable the use of qgraphicsitem_cast with this item.

return Type;

}

...

};

qvariant_cast  QVariant类型转换为实际的类型

Returns the given value converted to the template type T.

This function is equivalent to QVariant::value().

等等...

原文地址:https://www.cnblogs.com/MakeView660/p/11045437.html

时间: 2024-08-19 09:22:51

Qt中的强制类型转换的相关文章

C#中的强制类型转换与as转换的区别

C#中的强制类型转换 例如有ClassA与ClassB两个类创建两个类的对象进行转换 1 2 ClassA a = new ClassA();  ClassB b = new ClassB(); 如果使用强制转换 1 ClassB c = (ClassB)a; 会报InvalidCastException异常 无法将类型为ClassA的对象强制转换为类型ClassB 若使用as关键字进行转换则 1 2 3 4 5 ClassB c=a as ClassB;  if(c!=null)  {  Me

详细理解javascript中的强制类型转换

将值从一种类型转换为另一种类型通常称为类型转换,这是显式的情况:隐式的情况称为强制类型转换,JavaScript 中的强制类型转换总是返回标量基本类型值,如字符串.数字和布尔值. 如何理解: 类型转换发生在静态类型语言的编译阶段,而强制类型转换则发生在动态类型语言的运行时? 1.如果是静态语言,比如c等,所有的类型转换应该都是在编译阶段处理的吧? 2.如果是动态语言,如js等, 编译阶段会处理类型转换吗? 一.ToString 它负责处理非字符串到字符串的强制类型转换 数字的字符串化遵循通用规则

慕课网-安卓工程师初养成-2-10 Java中的强制类型转换

来源:http://www.imooc.com/code/1241 相信小伙伴们也发现了,尽管自动类型转换是很方便的,但并不能满足所有的编程需要. 例如,当程序中需要将 double 型变量的值赋给一个 int 型变量,该如何实现呢? 显然,这种转换是不会自动进行的!因为 int 型的存储范围比 double 型的小.此时就需要通过强制类型转换来实现了. 语法:( 数据类型 ) 数值 运行结果:  可以看到,通过强制类型转换将 75.8 赋值给 int 型变量后,结果为 75,数值上并未进行四舍

赋值中的强制类型转换

赋值中的类型转换 当赋值运算符两边的运算对象类型不同时,将要发生类型转换, 转换的规则是:把赋值运算符右侧表达式的类型转换为左侧变量的类型.具体的转换如下: (1) 浮点型与整型 ● 将浮点数(单双精度)转换为整数时,将舍弃浮点数的小数部分(是直接舍弃,编译器不会自动四舍五入), 只保留整数部分.将整型值赋给浮点型变量,数值不变,只将形式改为浮点形式, 即小数点后带若干个0.注意:赋值时的类型转换实际上是强制的. (2) 单.双精度浮点型 ● 由于C语言中的浮点值总是用双精度表示的,所以floa

Java中的强制类型转换

例如,当程序中需要将 double 型变量的值赋给一个 int 型变量,该如何实现呢? 显然,这种转换是不会自动进行的!因为 int 型的存储范围比 double 型的小.此时就需要通过强制类型转换来实现了. public class HelloWorld{ public static void main(String[] args) { double heightAvg1=176.2; int heightAvg2=(int)heightAvg1; System.out.println(hei

JS中的强制类型转换

<script type="text/javascript">   /*    * 强制类型转换    * 指的是将一个数据类型强制转换为其他的数据类型    * 类型转换主要指,将其他的数据类型,转换为String,Number,Boolean    *     */      /*    * 将其他的数据类型转换为String    * 方式一:    * 调用被转换数据类型的tostring()方法    * 该方法不会影响原变量,它会将转换的结果返回    * 但是

JS在if中的强制类型转换

这个属于很基础了,但是却很有用,需要的补个坑吧: JS在很多情况下会进行强制类型转换,其中,最常见两种是: 1.使用非严格相等进行比较,对==左边的值进行类型转换: 2.在if判断时,括号内的值进行类型转换,转化为布尔值: 强制转换为false的四种情况 在if中进行强制转换为false的情况只有四种,分别是: 1.数字0 2.NaN 3.空字符串 4.null或undefined But:这里存在2中特殊情况,数组和对象(因为,在上述条件下恒为true),改如何判断呢? 其实也简单:前者arr

关于继承中的强制类型转换

dynamic_cast是与继承相关的类型转换关键字dynamic_cast要求相关的类中必须有虚函数用于直接或者间接继承关系的指针(引用)之间-指针: 转换成功:得到目标类型的指针 转换失败:得到一个空指针 -引用: 转换成功:得到目标类型的引用 转换失败:得到一个异常操作信息 编译器会检查dynamic_cast的使用是否正确类型转换的结果只可能在运行阶段才能得到 #include <iostream> #include <string> using namespace std

函数声明中的强制类型转换

如何写一个程序使得微处理器在启动时自动调用0位置处的子例程呢? 首先我们要找到这样的一个位置,的办法就是用一个指针指向该位置,而该位置正好又是一个我们所需要的任意类型的函数,那么问题就能得到解决.假设我们有一个指向该位置的函数指针,其类型为空.如:(*fp)().现在最重要的问题就是如何让fp指向0位置处. 我们想到了类型的强制转换.比如将整数0,转换为指向空类型的函数的指针(void(*)())0,这个指针的含义与fp的类型完全相同,我们的目的就是用它来替换fp. 所以这段代码可以写成((vo