Qt下面,字符串都用QString,确实给开发者提供了方便,想想VC里面定义的各种变量类型,而且函数参数类型五花八门,经常需要今年新那个类型转换
Qt再使用第三方开源库时,由于库的类型基本上都是标准的类型,字符串遇的多的就是Char*类型
在Qt下怎样将QString转char*呢,需要用到QByteArray类,QByteArray类的说明详见Qt帮助文档。
因为char*最后都有一个‘/0’作为结束符,而采用QString::toLatin1()时会在字符串后面加上‘/0’
方法如下:
Qstring str; char* ch; QByteArray ba = str.toLatin1(); ch=ba.data();
这样就完成了QString向char*的转化。经测试程序运行时不会出现bug
注意第三行,一定要加上,不可以str.toLatin1().data()这样一部完成,可能会出错。
补充:以上方法当QString里不含中文时,没有问题,但是QString内含有中文时,转换为char*就是乱码,采用如下方法解决:
方法1:
添加GBK编码支持:
#include <QTextCodec> QTextCodec::setCodecForTr(QTextCodec::codecForName("GBK")); QTextCodec::setCodecForLocale(QTextCodec::codecForName("GBK"));
然后改变上面的第三行为:QByteArray ba = str.toLoacl8Bit(); toLoacl8Bit支持中文
方法2:
先将QString转为标准库中的string类型,然后将string转为char*,如下:
std::string str = filename.toStdString(); const char* ch = str.c_str();
qt中类型强制转换
MainWindow* mainwindow = qobject_cast< MainWindow *>( swf-> parent());
QT QMap介绍与使用
Qt中的QMap介绍与使用,在坛子里逛了一圈,发现在使用QMap中,出现过很多的问题,Map是一个很有用的数据结构。它以“键-值”的形式保存数据。在使用的时候,通过提供字符标示(键)即可得到想要的数据。这个“数据”即可以是一个字符串,也可以是任意对象,当然也包括自己定义的类对象。说明:map是以值传递的形式保存数据的。
1. 基本应用
下面以“键-值”都是QString的例子说明QMap的基本使用方法。更详细的说明,请查看《Qt帮助手册》或其他资源。
- #include <qmap.h>
- #include <iostream>
- using namespace std;
- class MapTest
- {
- public:
- void showMap()
- {
- if(!m_map.isEmpty()) return; //判断map是否为空
- m_map.insert("111", "aaa"); //向map里添加一对“键-值”
- if(!m_map.contains("222")) //判断map里是否已经包含某“键-值”
- m_map.insert("222", "bbb");
- m_map["333"] = "ccc"; //另一种添加的方式
- qDebug("map[333] , value is : " + m_map["333"]); //这种方式既可以用于添加,也可以用于获取,但是你必须知道它确实存在
- if(m_map.contains("111")){
- QMap<QString,QString>::iterator it = m_map.find("111"); //找到特定的“键-值”对
- qDebug("find 111 , value is : " + it.data()); //获取map里对应的值
- }
- cout<< endl;
- qDebug("size of this map is : %d", m_map.count()); //获取map包含的总数
- cout<< endl;
- QMap<QString,QString>::iterator it; //遍历map
- for ( it = m_map.begin(); it != m_map.end(); ++it ) {
- qDebug( "%s: %s", it.key().ascii(), it.data().ascii()); //用key()和data()分别获取“键”和“值”
- }
- m_map.clear(); //清空map
- }
- private:
- QMap<QString,QString> m_map; //定义一个QMap对象
- };
调用类函数showMap(),显示结果:
- map[333] , value is : ccc
- find 111 , value is : aaa
- size of this map is : 3
- 111: aaa
- 222: bbb
- 333: ccc
2. 对象的使用
map当中还可以保存类对象、自己定义类对象,例子如下(摘自QT帮助文档《Qt Assistant》,更详细的说明参考之):
以注释形式说明
- #include <qstring.h>
- #include <qmap.h>
- #include <qstring.h>
- //自定义一个Employee类,包含fn、sn、sal属性
- class Employee
- {
- public:
- Employee(): sn(0) {}
- Employee( const QString& forename, const QString& surname, int salary )
- : fn(forename), sn(surname), sal(salary)
- { }
- QString forename() const { return fn; }
- QString surname() const { return sn; }
- int salary() const { return sal; }
- void setSalary( int salary ) { sal = salary; }
- private:
- QString fn;
- QString sn;
- int sal;
- };
- int main(int argc, char **argv)
- {
- QApplication app( argc, argv );
- typedef QMap<QString, Employee> EmployeeMap; //自定义一个map类型,值为EmployeeMap对象
- EmployeeMap map;
- map["JD001"] = Employee("John", "Doe", 50000); //向map里插入键-值
- map["JW002"] = Employee("Jane", "Williams", 80000);
- map["TJ001"] = Employee("Tom", "Jones", 60000);
- Employee sasha( "Sasha", "Hind", 50000 );
- map["SH001"] = sasha;
- sasha.setSalary( 40000 ); //修改map值的内容,因为map采用值传递,所以无效
- //批量打印
- EmployeeMap::Iterator it;
- for ( it = map.begin(); it != map.end(); ++it ) {
- printf( "%s: %s, %s earns %d\n",
- it.key().latin1(),
- it.data().surname().latin1(),
- it.data().forename().latin1(),
- it.data().salary() );
- }
- return 0;
- }
- Program output:
- JD001: Doe, John earns 50000
- JW002: Williams, Jane earns 80000
- SH001: Hind, Sasha earns 50000
- TJ001: Jones, Tom earns 60000
QVariant类作为一个最为普遍的Qt数据类型的联合。
因为c++禁止没有构造函数和析构函数的联合体,许多继承的Qt类不能够在联合体当中使用。(联合体当中的变量共用一个存储区),没有了联合变量,我们在物体属性以及数据库的工作等方面受到很多的困扰。
一个QVariant对象在一个时间内只保留一种类型的值。我们可以使用canConvert来查询是否能够转换当前的类型。转换类型一般以toT()命名。
摘录了一个example来说明QVariant的使用方法:
QDataStream out(...); QVariant v(123); // The variant now contains an int int x = v.toInt(); // x = 123 out << v; // Writes a type tag and an int to out v = QVariant("hello"); // The variant now contains a QByteArray v = QVariant(tr("hello")); // The variant now contains a QString int y = v.toInt(); // y = 0 since v cannot be converted to an int QString s = v.toString(); // s = tr("hello") (see QObject::tr()) out << v; // Writes a type tag and a QString to out ... QDataStream in(...); // (opening the previously written stream) in >> v; // Reads an Int variant int z = v.toInt(); // z = 123 qDebug("Type is %s", // prints "Type is int" v.typeName()); v = v.toInt() + 100; // The variant now hold the value 223 v = QVariant(QStringList());
你甚至可以存储QList<QVariant>和QMap<QString ,QVariant>.所以你可以构造任意复杂的任意的数据类型。这个是非常强大而且又有用的。QVariant也支持null值,你可以定义一个没有任何值的类型,然而,也要注意QVariant类型只能在他们有值的时候被强制转换。QVariant x, y(QString()), z(QString(""));
x.convert(QVariant::Int);
// x.isNull() == true
// y.isNull() == true, z.isNull() == false
因为QVariant是QtCore库的一部分,它不能够提供定义在QtGui当中的类型的转换,如QColor,QImage,he QPixmap等。换句话说,没有toColor()这样的函数。取代的,你可以使用QVariant::value()或者qVariantValue()这两个模板函数。 QVariant variant;
...
QColor color = variant.value<QColor>();
反向转换(如把QColor转成QVariant)是自动完成的。也包含了GUI相关的那些数据类型。
QColor color=palette().background().color();
QVariant variant=color;