(3)Qt中的变体数据类型(QVariant)

QVariant的使用

        QVariant(变体数据类型)这个类很神奇,或者说方便。很多时候,需要几种不同的数据类型需要传递,如果用结构体,又不大方便,容器保存的也只是一种数据类型,而QVariant则可以统统搞定。QVariant 这个类型充当着最常见的数据类型的联合。QVariant 可以保存很多Qt的数据类型,包括QBrush、QColor、QCursor、QDateTime、QFont、QKeySequence、 QPalette、QPen、QPixmap、QPoint、QRect、QRegion、QSize和QString,并且还有C++基本类型,如int、float等。

Qvariant操作基本数据类型

 使用QVariant操作int类型的数据

QVariant var(1001);
qInfo() << var;					//  QVariant(int, 1001)

 获取QVariant变体类型中存储的值

//获取var里面的值
qInfo() << var.value<int>();	//	1001
qInfo() << var.toInt();			//	1001

 设置QVariant变体类型中存储的值

//设置变体类型中存储的值
var.setValue(666);
qInfo() << var.value<int>();	//	666

QVariant操作字符串数据类型

 使用QVariant操作字符串类型的数据

QVariant var("Hello");
qInfo() << var;						//	QVariant(QString, "Hello")
qInfo() << var.value<QString>();	//	"Hello"
qInfo() << var.toString();			//	"Hello"

        使用构造函数构造默认存储为QString类型的数据,但是使用setValue()函数设置值后会变成const char* 类型,因此再使用toString()方法是不能访问到数据的。因此只能使用value()的方式访问数据。

var.setValue("Have");				//	设置值
qInfo() << var;						//	QVariant(const char*, 0x7ff70dcbbe70)
qInfo() << var.toString();			//	""
qInfo() << var.value<const char*>();//	Have

        将字符串封装成QString类型之后使用toString()方法访问QVariant中存储的值可以解决上面的问题。

QVariant var("Hello");

var.setValue(QString("Have"));		//	设置值
qInfo() << var;						//	QVariant(QString, "Have")
qInfo() << var.toString();			//	"Have"

var = QVariant::fromValue(QString("Good"));
qInfo() << var;						//	QVariant(QString, "Good")
qInfo() << var.toString();			//	"Good"

QVariant数据类型的获取 

QVariant var("Hello");

qInfo() << var.type();				//	QVariant::QString
qInfo() << var.userType();			//	10
qInfo() << var.metaType().id();		//	10
qInfo() << var.typeName();			//	QString

var.type()这是被Qt6弃用的函数 add_compile_definitions(QT_DISABLE_DEPRECATED_BEFORE=0x60000)(可在CMakeLists中设置弃用Qt6弃用的函数)

QVariant操作自定义数据类型 

        除了标准类型, 我们自定义的类型也可以使用QVariant类进行封装, 被QVariant存储的数据类型需要有一个默认的构造函数和一个拷贝构造函数。为了实现这个功能,首先必须使用Q_DECLARE_METATYPE()宏。

 使用QVariant操作自定义数据类型的数据

class MM
{
public:
	QString sign;
	int age;
	MM() = default;
	MM(const QString& sign,int age) : sign(sign),age(age){}
	//隐式共享 不需要传入引用  但是MM& m 必须传入引用
	friend QDebug operator<<(QDebug out, const MM& m)
	{
		out << m.sign << m.age;
		return out;
	}
};

//自定义类型注册	
//Qt6以前需要手动注册自定义类型,才能使用,Qt6可以自动识别
Q_DECLARE_METATYPE(MM);
QVariant var;
MM m("貂蝉",18);
var.setValue(m);
qInfo() << var;								//	QVariant(MM, "貂蝉"18)
qInfo() << var.value<MM>();					//	"貂蝉" 18
var = QVariant::fromValue(MM("西施",20));	
qInfo() << var;								//	QVariant(MM, "西施"20)

        因为是自定义数据类型,因此只能使用setValue()函数或者静态函数fromValue()的方式设置变体类型的值,获取值也只能使用value()的方式获取。

  • 0
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

石小浪♪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值