QSettings 类

时间:2022-06-21 17:15:24
一 、QSettings介绍:

用户通常希望应用程序记住其设置。在windows中,这些设置保存在注册表中,ios在属性文件列表中,而unix,在缺乏标准的情况下,其存储在ini文本中。QSettings有两种存储格式:QSettings::NativeFormat(在windows平台可读写注册表)、QSettings::IniFormat(读写ini文件)、QSettings::InvalidFormat

    QSettings使用户可以保存应用程序设置,并且支持用户自定义存储格式。QSetings API基于QVariant,因而你可以存储却大部分类型的数据。如果你需要一个非持久性的存储,推荐使用QMap<QString,QVariant>.

二、QSettings常用API:
  • 创建QSettings对象
  1. QSettings(const QString & organization, const QString & application = QString(), QObject * parent = 0)
    创建一个QSettings对象,必须传入应用程序名称,及公司名称。如果你的设置来自程序中不同的地方,你需要通过QCoreApplication::setOrganizationName() and QCoreApplication::setApplicationName()指定程序名称和公司名称,并且使用默认的构造函数QSettings settings。
    QCoreApplication::setOrganizationName("MySoft");
    QCoreApplication::setOrganizationDomain("mysoft.com");
    QCoreApplication::setApplicationName("Star Runner");
    ...
    QSettings settings;
  • 写入数据
  1. settings.setValue("editor/wrapMargin", 68);
     每一条信息包含一个key和一个value,value类型为QVariant。
  • 读取数据
  1. int margin = settings.value("editor/wrapMargin").toInt();
    如果key不存在,则返回 null QVariant(可以被转化为整数0)
    读取数据的时候,可以传递第二个参数,给定新的value:
  1. int margin = settings.value("editor/wrapMargin", 80).toInt();
  • 其他
    判断key是否存在: contains(const QString & key) const
    移除某项:remove(const QString & key)
    得到所有键:QStringList QSettings::allKeys() 

三、使用示例
  • 读写注册表

实例化对象时,设置存储格式为:QSettings::NativeFormat,利用'/'来填写要读写的注册表:

    
  1. QSetings settings(("HKEY_CURRENT_USER/", QSettings::NativeFormat);
  2. settings.setValue("regedit/test","green");//设置key-value键值对
  3. QString value = settings.value("regedit/test");//读取key对应的value
  • 读写ini文件
  1. #include <QApplication>
  2. #include <QSettings>
  3. int main(int argc, char *argv[])
  4. {
  5. QApplication a(argc, argv);
  6. QSettings settings("E:/QTProject/BLOG/Settings_test/test.ini", QSettings::IniFormat);
  7. settings.setValue("Student/name", "ChengKeKe");
  8. settings.setValue("Student/sex", "man");
  9. settings.setValue("Student/age", 24);
  10. settings.setValue("Address", "Xi'an");
  11. QString name = settings.value("Student/name").toString();
  12. QString sex = settings.value("Student/sex").toString();
  13. return a.exec();
  14. }
打开test.ini如图:
QSettings 类
  注: 其中注意读取Value时,如果存储值为16进制,不能使用int QVariant::toInt(bool * ok = 0) const,结果将返回0;