当前位置:   article > 正文

QT基本数据类型

QT基本数据类型

第一章QT基本数据类型


1.基础类型

Qt基本数据类型定义在#include <QtGlobal>中,Qt基本数据类型有:

类型名称注释备注
qint8signed char字符型
qint16signed short短整型
qint32signed int整型
qint64long long int长整型
qintptrqint32或qint64指针类型,32位系统是qint32~
qlonglonglong long int或(__int64)Windows中定义为__int64
qptrdiffqint32或qint64指针偏移,根据系统类型不同而不同~
qrealdouble或float实型,除非配置了-qreal float选项,否则默认double
quint8unsigned char无符号字符型
quint16unsigned short无符号短整型
quint32~~
quint64~~
quintptr~~
qulonglong~~
ucharunsigned char~
uintunsigned int~
ulongunsigned long~
ushortunsigned short~
qsizetypesize_t~

2. log输出

在Qt中进行log输出,Qt框架提供了专门用于日志输出的类,头文件名QDebug

基本分类

  • qDebug:调试信息提示
  • qInfo:输出信息
  • qWarning:一般的警告提示
  • qCritical:严重的错误提示
  • qFatal:致命错误提示,会直接中断程序
    qint8 v1='c';
    qint32 v2=100;
    quint8 v3='a';
    quint32 v4=100;
    qintptr *p=nullptr;
    qDebug("v1 = %" PRIdQSIZETYPE "",v1);
    qInfo("v2 = %d",v2);
    qWarning("v3=%c",v3);
    qCritical("v4=%d",v4);
    qFatal("致命错误");
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

格式化日志

默认情况下,日志格式是只输出对应的日志内容没有额外信息的。我们可以通过修改环境变量QT_MESSAGE_PATTERN或者调用方法qSetMessagePattern来修改日志的输出格式,日志格式中常用的占位符符号如下:

%{appname}		应用程序的名称(QCoreApplication::applicationName())
%{category}		日志所处的领域
%{file}			打印该日志的文件路径
%{fuction}		打印日志的函数
%{line}			打印日志在文件中的行数
%{message}		打印日志的内容
%{pid}			打印日志程序的PID
%{threadid}		打印日志的线程ID
%{qthreadptr}	打印日志的线程指针
%{type}			日志级别("debug","warning","critical" or "fatal")
%{time process}	日志发生时程序启动了多久
%{time boot}	日志发生时系统启动了多久
%{time [format]}以固定时间格式输出日志打印的时间,默认为QISODate格式
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

普通格式化

	qSetMessagePattern("%{time [yy-MM-dd hh:mm:ss]} %{file} %{function}(%{line}) %{message}");
    qInfo()<<"qInfo";
    qDebug()<<"qDebug";
    qWarning()<<"qWarning";
    qCritical()<<"qCritical";
  • 1
  • 2
  • 3
  • 4
  • 5

注意:在Release模式下,文件名、函数名、行号获取不到,需要添加编译时宏QT_MESSAGELOGCONTEXT
添加方法如下:

在cmakeLists.txt文件中添加
add_definitions(-DQT_MESSAGELOGCONTEXT) # 全局范围可用
或者
target_compile_definitions(你的可执行程序名称 PRIVATE QT_MESSAGELOGCONTEXT) #目标范围可用

条件格式化

  QString s_debug="%{if-debug} [%{type}] line%{line} %{endif}";
  QString s_info = "%{if-info} [%{type}] %{file} %{endif}";
  qSetMessagePattern("%{time [yy-MM-dd hh:mm:ss]}"+s_debug+s_info+"%{message}");
  • 1
  • 2
  • 3
  • 案例把日志写入文件
#include "MainWindow.h"
#include <QtGlobal>
#include <QApplication>
#include <QDebug>
#include <QFile>

//日志消息处理函数
void logMessageHander(QtMsgType type,const QMessageLogContext &ctx,const QString &msg)
{
   //获取格式化日志信息
   QString typestr=qFormatLogMessage(type,ctx,msg);
   //可以根据日志级别进行过滤(比如不要debug,可以直接return)
   QString levelText;
   switch(type)
   {

   case QtDebugMsg:
       levelText="debug";
       return;
       break;
   case QtWarningMsg:
       levelText ="warning";
       break;
   case QtCriticalMsg:
       levelText ="critical";
       break;
   case QtFatalMsg:
       levelText ="fatal";
       break;
   case QtInfoMsg:
       levelText ="info";
       break;
   }
   QFile file("mylog.txt");
   file.open(QIODeviceBase::WriteOnly|QIODeviceBase::Append);
   if(file.isOpen())
   {
       QTextStream tStream(&file);
       tStream<<typestr<<"\n";
       file.close();
   }
}
int main(int argc, char *argv[])
{
   QApplication a(argc, argv);

   QString s_debug="%{if-debug} [%{type}] line%{line} %{endif}";
   QString s_info = "%{if-info} [%{type}] %{file} %{endif}";

   qSetMessagePattern("%{time [yy-MM-dd hh:mm:ss]}"+s_debug+s_info+"%{message}");
   qInstallMessageHandler(logMessageHander);
   MainWindow w;

   qint8 v1='c';
   qint32 v2=100;
   quint8 v3='a';
   quint32 v4=100;
   qintptr *p=nullptr;
   QString say="你好,世界";
   qDebug("v1 = %" PRIdQSIZETYPE "",v1);
   qDebug()<<say;
   qInfo("v2 = %d",v2);
   qWarning("v3=%c",v3);
   qCritical("v4=%d",v4);
   //qFatal("致命错误");


   w.show();
   return a.exec();
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70

环境变量格式化

    qputenv("QT_MESSAGE_PATTERN",QByteArray("%{time yyyyMMdd h:mm:ss.zzz t} %{if-debug}D %{endif}"
                                             "%{file} %{function}(%{line}) %{message}"));
  • 1
  • 2

和上面的qSetMessagePattern()一起使用的话,qputenv()就无效了

禁用输出

在开发或者调试时,我们必须借助日志来进行判断,但是当程序需要发布时,调试的日志信息不再需要,此时如果把代码删除,又不太方便
Qt提供了禁用qInfo、qwarning、qdebug输出的宏,qcritical和qfatal不能屏蔽
在CMakeLists.txt文件中添加如下三行,即可禁用

add_compile_definitions(QT_NO_INFO_OUTPUT)
add_compile_definitions(QT_NO_WARNING_OUTPUT)
add_compile_definitions(QT_NO_DEBUG_OUTPUT)
  • 1
  • 2
  • 3

3.字符串类型

  1. QByteArray
可以通过这个类的构造函数申请一个内存,用于存储我们需要处理的字符串数据
  • 1
  • 构造函数
    QByteArray arr1("hello,world!");
    QByteArray arr2("你好世界");
    QByteArray arr3(10,'a');
    qDebug()<<arr1;
    qDebug()<<QString::fromUtf8(arr2);//输出中文要通过qstring转
    qDebug()<<arr3;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 数据操作
    arr2.append("我好帅");//尾插
    qDebug()<<QString::fromUtf8(arr2);  //"你好世界我好帅"
    
    arr1.insert(3,"abc");
    qDebug()<<arr1; //"helabclo,world!"
    arr1.insert(10,"@@&^",1);
    qDebug()<<arr1; //"helabclo,w@orld!"
    arr3.insert(20,'*');//超出长度用空格填充
    qDebug()<<arr3; //"aaaaaaaaaa          *"    
    
    arr1.remove(3,3); //移除第三个位置的后面3个字符
    qDebug()<<arr1; //"hello,w@orld!"

    arr1.removeIf([](char a){return a<'i';});//移除里面小于'i'的字符
    qDebug()<<arr1; //"lloworl"
    
    arr3.truncate(5);//从第5个位置开始截断
    qDebug()<<arr3;//"aaaaa"

    arr3.replace(1,2,"我是个大聪明啊,你是不是也和我一样");//从第一个位置开始,把后面2个字符替换成内容
    qDebug()<<QString::fromUtf8(arr3);//"a我是个大聪明啊,你是不是也和我一样aa"
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 字符串查找和判断
  	qDebug()<<"arr3包含大聪明"<<arr3.contains("大聪明");//arr3包含大聪明 true
    qDebug()<<"arr3以大聪明开头"<<arr3.startsWith("大聪明");//arr3以大聪明开头 false
    qDebug()<<"arr3以大聪明结尾"<<arr3.endsWith("大聪明");//arr3以大聪明结尾 false  
    qDebug()<<arr1.at(2);
    qDebug()<<arr1[2];//第二个位置的字符    
  • 1
  • 2
  • 3
  • 4
  • 5
  • 遍历
    for(auto i :arr1)
        qDebug()<<i;
  • 1
  • 2
  1. QString
  • 构造函数
    QString s1="你好";
    QString s2(QByteArray("abc"));
    qDebug()<<s1<<s2; 
  • 1
  • 2
  • 3
  • 数据操作
    和QByteArray类似,append,prepend,insert
    s2.chop(1);//尾部删除一个字符
    qDebug()<<s2;
  • 1
  • 2
  • 字符串格式化
    s2 = QString::asprintf("hello %s","world");//跟sprintf差不多
    qDebug()<<s2;

    qDebug()<<QString("我叫%1,今年%2岁,职业是%3").arg("张三").arg(30).arg("程序员");//"我叫张三,今年30岁,职业是程序员"
  • 1
  • 2
  • 3
  • 4
  • 不同字符串类型转换
    //string->qstring
    s1= QString::fromStdString("你好china");
    qDebug()<<s1;
    //qstring->string
    std::string str1= s1.toStdString();
    std::cout<<str1<<std::endl;
    //qstring->qbytearry
    QByteArray qarr1 = s1.toUtf8();//转换为utf8编码格式的字符串
    qarr1 = s1.toLatin1();//转换为latin1编码,不支持中文
    qarr1 = s1.toLocal8Bit();//转换为本地编码,跟随操作系统
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  1. QVariant

变体数据类型,可以保存很多的数据类型,包括QBrush,QColor,QCursor,QDateTime,QFont,QKeySequence,QPalette,QPen,QPixmap,QPoint,QRect,QRegion,QSize和QString,并且还有C++基本类型,如int,float等

    QVariant var1(666);
    QVariant var2 = QVariant::fromValue(QString("野人诺"));
    QVariant var3;
    var3.setValue(QByteArray("张三"));

    qDebug()<<var1.toInt()<<var2.toString()<<var3.toByteArray();
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

qDebug()输出时,转换类型要和原来的一致,否则输出为空
上面运行结果为: 666 “野人诺” “”

qDebug()<<var3.typeName();//const char*
  • 1

自定义类型
mainwindow.h加上自定义类

class Person
{
public:
    QString name;
    quint8 age;
    friend QDebug operator<<(QDebug debug,const Person &person)
    {
        debug<<"Person("<<person.name<<","<<person.age<<")";
        return debug;
    }    
};
Q_DECLARE_METATYPE(Person)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

main.cpp里使用

    var3.setValue(Person());
    qDebug()<<var3.value<Person>();//输出结果Person( "" , 0 )
    return a.exec();
  • 1
  • 2
  • 3

判断类型使用

    if(var3.canConvert<int>())
    {
        qDebug()<<var3.value<int>();
    }
    else if(var3.canConvert<Person>())
    {
        qDebug()<<var3.value<Person>();
    }
    else
        qDebug()<<var3.typeName();
    return a.exec();
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/334795
推荐阅读
相关标签
  

闽ICP备14008679号