Qt通过QSttings类读取*.ini配置文件

Posted 林夕07

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Qt通过QSttings类读取*.ini配置文件相关的知识,希望对你有一定的参考价值。

目录

ini文件

什么是ini文件

INI(Initialization File)是微软Windows操作系统中的文件扩展名。这些字母表示初始化。正如该术语所表示的,INI文件被用来对操作系统或特定程序初始化或进行参数设置。在项目也会将一些配置信息存于ini文件,所以读取配置文件是项目中不可缺少的一部分。由于ini只有节和参数比较简单,在Qt中又有QSettings类使得更加便捷。

格式

INI文件由节、键、值组成。
[section]
参数 (键=值) name=value
注解 注解使用分号表示(;)。在分号后面的文字,直到该行结尾都全部为注解。如; comment textINI文件的数据格式的例子(配置文件的内容) [Section1 Name]

KeyName1=value1
KeyName2=value2
...
[Section2 Name]
KeyName21=value21
KeyName22=value22

其中:
[Section1 Name]用来表示一个段落。

需要的参数

头文件:#include <QSettings>
qmake: QT += core; (一般的qt工程默认会配置core)

需要了解的API

构造函数:QSettings(const QString &fileName, Format format, QObject *parent = Q_NULLPTR)
fileName:文件名(包括路径,注意转义)
Format:是枚举类型。该enum类型指定QSettings使用的存储格式。
parent: 父类
下图Qt官方文档原文

中文对照

类型说明
QSettings::NativeFormat0C使用最适合平台的存储格式。 在Windows上,这意味着系统注册表; 在macOS和ios上,这意味着CFPreferences API; 在Unix上,这意味着INI格式的文本配置文件。
QSettings::Registry32Format2仅限Windows:从64位Windows上运行的64位应用程序显式访问32位系统注册表。 在32位Windows上或从64位Windows上的32位应用程序中,此操作与指定NativeFormat相同。 这个enum值是在Qt 5.7中添加的。
QSettings::Registry64Format3仅限Windows:从运行在64位Windows上的32位应用程序显式访问64位系统注册表。 在32位Windows上或从64位Windows上的64位应用程序中,此操作与指定NativeFormat相同。 这个enum值是在Qt 5.7中添加的。
QSettings::IniFormat1将设置存储在INI文件中。
QSettings::InvalidFormat16由registerFormat()返回的特殊值。

这里的话我们一般用的是QSettings::IniFormat

设置参数的值: void setValue(const QString &key, const QVariant &value)

获取参数的值: QVariant value(const QString &key, const QVariant &defaultValue = QVariant()) const
这里defaultValue意思是如果未找到该参数的值将会返回你给你默认值,否则返回空或者0。

单例

单例有其独有的使用场景,一般是对于那些业务逻辑上限定不能多例只能单例的情况,例如:类似于计数器之类的存在,一般都需要使用一个实例来进行记录,若多例计数则会不准确。 其实单例就是那些很明显的使用场合,没有之前学习的那些模式所使用的复杂场景,只要你需要使用单例,那你就使用单例,简单易理解。
所以读取配置文件也需要设计成单例模式。主要分为单线程使用和多线程使用。下面列出了俩种的实例。

单线程实例

#pragma once
#include <thread>
#include <mutex>
#include <iostream>
using namespace std;
 
class Singleton

public:
    static Singleton* NewObject()//无参版本
    
        if (sm_obj == nullptr)
        
            sm_obj = new Singleton;
        
        return sm_obj;
    
    static Singleton* NewObject(int a, char b, double c)//有参版本
    
       if (sm_obj == nullptr)
       
             sm_obj = new Singleton(a, b, c);
       
        return sm_obj;
    
    void DelObject()
    
        if (Singleton::sm_obj != nullptr)
        
            delete sm_obj;
            sm_obj = nullptr;
        
    
 
private:
    Singleton()
    
        m_a = 0;
        m_b = 0;
        m_c = 0;
    
    Singleton(int a, char b, double c)
    
        m_a = a;
        m_b = b;
        m_c = c;
    
    ~Singleton() 
    Singleton(const Singleton& other) 
    void operator=(const Singleton* ohter) 
 
private:
    static Singleton* sm_obj;
    int m_a;
    char m_b;
    double m_c;
;
 
Singleton* Singleton::sm_obj = nullptr;//懒汉模式,以时间换空间
//Singleton* Singleton::sm_obj = new Singleton;//饿汉模式,以空间换时间

多线程实例

#pragma once
#include <thread>
#include <mutex>
#include <iostream>
using namespace std;
 
mutex g_m;//创建锁
class Singleton

public:
    static Singleton* NewObject()//无参版本
    
        //双重校验锁
        if (sm_obj == nullptr)//增加效率      
        
            加锁防止多线程同时创建造成内存泄漏
            lock_guard<mutex> lg(g_m);//守卫锁,也叫自解锁。防止异常死锁
            //g_m.lock();
            if (sm_obj == nullptr)
            
                sm_obj = new Singleton;
            
            //g_m.unlock();
        
        return sm_obj;
    
    static Singleton* NewObject(int a, char b, double c)//有参版本
    
        //双重校验锁
        if (sm_obj == nullptr)//增加效率      
        
            //加锁防止多线程同时创建造成内存泄漏
            //守卫锁,也叫自解锁。防止异常死锁
            lock_guard<mutex> lg(g_m);
            if (sm_obj == nullptr)
            
                sm_obj = new Singleton(a, b, c);
            
        
        return sm_obj;
    
    void DelObject()
    
        if (Singleton::sm_obj != nullptr)
        
            delete sm_obj;
            sm_obj = nullptr;
        
    
 
private:
    Singleton()
    
        m_a = 0;
        m_b = 0;
        m_c = 0;
    
    Singleton(int a, char b, double c)
    
        m_a = a;
        m_b = b;
        m_c = c;
    
    ~Singleton() 
    Singleton(const Singleton& other) 
    void operator=(const Singleton* ohter) 
 
private:
    static Singleton* sm_obj;
    int m_a;
    char m_b;
    double m_c;
;
 
Singleton* Singleton::sm_obj = nullptr;//懒汉模式,以时间换空间
//Singleton* Singleton::sm_obj = new Singleton;//饿汉模式,以空间换时间


设计一个读取ini文件的类

首先正常创建一个qt的工程,有无ui界面都可以。如下图。

然后创建一个1.ini文件。内容可以照抄下面的,[]是节的固定格式,里面的system就是节的名称。下面就ip=121.52.52.5就是赋值。

AppSettings类

头文件

#ifndef APPSETTINGS_H
#define APPSETTINGS_H
#include <string>
#include <QSettings>
#include <QMutex>
#include <QMutexLocker>

class AppSettings


public:
    static AppSettings* Instance();

    void Init(QString fileName);

    QString GetIp() const;
    void SetIp(QString ip);

private:
    AppSettings();
    ~AppSettings();

private:
    QSettings* settings;
    static AppSettings* sm_obj;
;

#endif // APPSETTINGS_H

源文件

#include "appsettings.h"
QMutex g_m;
AppSettings* AppSettings::sm_obj = nullptr;//懒汉模式,以时间换空间
AppSettings *AppSettings::Instance()

    if(sm_obj == nullptr)
    
        QMutexLocker lg(&g_m);
        if(sm_obj == nullptr)
        
            sm_obj = new AppSettings();
        
    
    return sm_obj;


void AppSettings::Init(QString fileName)

    settings = new QSettings(fileName, QSettings::IniFormat);
    settings->setIniCodec("GBK");


QString AppSettings::GetIp() const

    return settings->value("system/ip", "127.0.0.1").toString();


void AppSettings::SetIp(QString ip)

    settings->setValue("system/ip", ip);


AppSettings::AppSettings()




AppSettings::~AppSettings()




调用代码

    AppSettings::Instance()->Init("1.ini");
    AppSettings::Instance()->SetIp("12.52.52.5"); // 给Ip赋值
    qDebug() << AppSettings::Instance()->GetIp(); // 获取Ip的值

运行结果

以上是关于Qt通过QSttings类读取*.ini配置文件的主要内容,如果未能解决你的问题,请参考以下文章

vba如何读取ini文件信息

c++读取ini文件

delphi同步读取ini文件

delphi中怎么读取ini文件第2行

python读取ini配置文件+Scala读取配置文件

请问如何用ASP读取ini配置文件