QSettings Class
QSettings类
- QSettings类
- 公共类型(枚举)
- 公有成员函数
- 静态成员函数
- 函数作用
- 这个类写文件的特征
QSettings类
QSettings类提供持久的独立于平台的应用程序设置。
头文件: | #include< QSettings > |
qmake: | QT + =core |
继承(父): | QObject |
公共类型(枚举)
0:使用最适合平台的存储格式存储设置。
在Windows上,这意味着系统注册表;
在macOS和iOS上,这意味着CFPreferences API在Unix上,这意味着INI格式的文本配置文件。(PC平台QSettings::NativeFormat )
1:将设置保存在INI文件中。注意,INI文件失去了数字数据和用于编码它们的字符串之间的区别,所以写为数字的值应该作为QString读回。(嵌入式平台QSettings::IniFormat )
在Unix上,NativeFormat和IniFormat意思相同,只是文件扩展名不同(。用于NativeFormat的配置。ini格式的ini)。
enum Format { NativeFormat, Registry32Format, Registry64Format, IniFormat, InvalidFormat }
0:将设置存储在特定于当前用户的位置(例如,在用户的主目录中)。
1:将设置存储在全局位置,以便同一台计算机上的所有用户都可以访问同一组设置。
enum Scope { UserScope, SystemScope }
0:没有发生错误。
1:出现访问错误(例如,试图写入只读文件)。
2:出现格式错误(例如,加载格式错误的INI文件)。
enum Status { NoError, AccessError, FormatError }
注意点
INI文件格式对键的语法有严格的限制。Qt通过在键中使用%作为转义字符来解决这个问题。此外,如果您保存一个顶级设置(一个没有斜杠的键,例如“someKey”),它将出现在INI文件的“General”部分。为了避免覆盖其他键,如果您使用像“General/someKey”这样的键来存储内容,该键将位于“%General”部分,而不是“General”部分。
遵循我们应该在接受的内容上开明,在生成的内容上保守的原则,QSettings将接受Latin-1编码的INI文件,但生成纯ASCII文件,其中非ASCII值使用标准INI转义序列进行编码。为了提高INI文件的可读性(但可能不太兼容),可以调用setIniCodec()。
公有成员函数
返回类型 | 函数 |
---|---|
构造函数 | QSettings(QSettings::Scope scope, QObject *parent = nullptr) |
构造函数 | QSettings(QObject *parent = nullptr) |
构造函数 | QSettings(const QString &fileName, QSettings::Format format, QObject *parent = nullptr) |
构造函数 | QSettings(QSettings::Format format, QSettings::Scope scope, const |
构造函数 | QSettings(QSettings::Scope scope, const QString &organization, const |
构造函数 | QSettings(const QString &organization, const QString &application = QString(), QObject *parent = nullptr) |
virtual | ~QSettings() |
QStringList | allKeys() const |
QString | applicationName() const |
void | beginGroup(const QString &prefix) |
int | beginReadArray(const QString &prefix) |
void | beginWriteArray(const QString &prefix, int size = -1) |
QStringList | childGroups() const |
QStringList | childKeys() const |
void | clear() |
bool | contains(const QString &key) const |
void | endArray() |
void | endGroup() |
bool | fallbacksEnabled() const |
QString | fileName() const |
QSettings::Format | format() const |
QString | group() const |
QTextCodec * | iniCodec() const |
bool | isAtomicSyncRequired() const |
bool | isWritable() const |
QString | organizationName() const |
void | remove(const QString &key) |
QSettings::Scope | scope() const |
void | setArrayIndex(int i) |
void | setAtomicSyncRequired(bool enable) |
void | setFallbacksEnabled(bool b) |
void | setIniCodec(QTextCodec *codec) |
void | setIniCodec(const char *codecName) |
void | setValue(const QString &key, const QVariant &value) |
QSettings::Status | status() const |
void | sync() |
QVariant | value(const QString &key, const QVariant &defaultValue = QVariant()) const |
静态成员函数
返回类型 | 函数 |
---|---|
QSettings::Format | defaultFormat() |
QSettings::Format | registerFormat(const QString &extension, QSettings::ReadFunc readFunc, QSettings::WriteFunc writeFunc, Qt::CaseSensitivity caseSensitivity = Qt::CaseSensitive) |
void | setDefaultFormat(QSettings::Format format) |
void | setPath(QSettings::Format format, QSettings::Scope scope, const QString &path) |
函数作用
构造函数
QSettings::QSettings(const QString &organization, const QString &application = QString(), QObject *parent = nullptr)
代码
QSettings settings("Moose Soft", "Facturo-Pro");
相当于
QCoreApplication::setOrganizationName("Moose Soft");
QCoreApplication::setApplicationName("Facturo-Pro");
QSettings settings;
常用构造函数
QSettings::QSettings(const QString &fileName, QSettings::Format format, QObject *parent = nullptr)
构造一个QSettings对象,用于访问存储在名为文件名,带父级父母。如果该文件尚不存在,则创建该文件。
如果格式是
QSettings::NativeFormat
,的意思文件名取决于平台。在Unix上,文件名是INI
文件的名称。在macOS和iOS上,文件名是的名称.plist
文件。在Windows上,文件名是系统注册表中的路径。如果格式是QSettings::IniFormat, 文件名是INI文件的名称。
构造函数
QSettings::QSettings(QSettings::Format format, QSettings::Scope scope, const QString &organization, const QString &application = QString(), QObject *parent = nullptr)
如果范围是
QSettings::UserScope
,QSettings对象首先搜索用户特定的设置,然后作为后备搜索系统范围的设置。
如果范围是QSettings::SystemScope
,QSettings对象忽略用户特定的设置,并提供对系统范围设置的访问。如果格式是
QSettings::NativeFormat
本机API用于存储设置。如果格式是QSettings::IniFormat
,则使用INI
格式。如果没有给出应用程序名称,QSettings对象将只访问整个组织位置.
析构函数
QSettings::~QSettings()
任何未保存的更改最终都将被写入永久存储。
获取所有键
QStringList QSettings::allKeys() const
例子:可以存储颜色,点,布尔等等
QSettings settings;
settings.setValue("fridge/color", QColor(Qt::white));
settings.setValue("fridge/size", QSize(32, 96));
settings.setValue("sofa", true);
settings.setValue("tv", false);QStringList keys = settings.allKeys();
// keys: ["fridge/color", "fridge/size", "sofa", "tv"]
如果使用beginGroup()设置组,则只返回组中的键,而不返回组前缀:
settings.beginGroup("fridge");
keys = settings.allKeys();
// keys: ["color", "size"]
开始一个组
void QSettings::beginGroup(const QString &prefix)
向当前组追加前缀。 当前组自动添加到指定给QSettings的所有键的前面。此外,查询函数如childGroups()、childKeys()和allKeys()都是基于组的。默认情况下,不设置任何组。 群组有助于避免反复键入相同的设置路径。例如:
settings.beginGroup("mainwindow");
settings.setValue("size", win->size());
settings.setValue("fullScreen", win->isFullScreen());
settings.endGroup();settings.beginGroup("outputpanel");
settings.setValue("visible", panel->isVisible());
settings.endGroup();
调用endGroup()将当前组重置为对应的beginGroup()调用之前的状态。组可以嵌套。
向当前组添加前缀,并开始从数组中读取。返回数组的大小。
int QSettings::beginReadArray(const QString &prefix)
struct Login {QString userName;QString password;
};
QList<Login> logins;
...QSettings settings;
int size = settings.beginReadArray("logins");
for (int i = 0; i < size; ++i) {settings.setArrayIndex(i);Login login;login.userName = settings.value("userName").toString();login.password = settings.value("password").toString();logins.append(login);
}
settings.endArray();
向当前组添加前缀,并开始写入大小为size的数组。如果size为-1(默认值),则根据写入条目的索引自动确定。 如果某一组键出现了很多次,可以使用数组来简化操作。例如,假设您想要保存一个可变长度的用户名和密码列表。然后你可以写:
void QSettings::beginWriteArray(const QString &prefix, int size = -1)
struct Login {QString userName;QString password;
};
QList<Login> logins;
...QSettings settings;
settings.beginWriteArray("logins");
for (int i = 0; i < logins.size(); ++i) {settings.setArrayIndex(i);settings.setValue("userName", list.at(i).userName);settings.setValue("password", list.at(i).password);
}
settings.endArray();
存储格式
logins/size
logins/1/userName
logins/1/password
logins/2/userName
logins/2/password
logins/3/userName
logins/3/password
...
如果存在名为key的设置,则返回true否则返回false。
bool QSettings::contains(const QString &key) const
返回使用此QSettings对象写入的设置的存储路径。
QString QSettings::fileName() const
删除设置键和键的任何子设置。
void QSettings::remove(const QString &key)
例子
QSettings settings;
settings.setValue("ape");
settings.setValue("monkey", 1);
settings.setValue("monkey/sea", 2);
settings.setValue("monkey/doe", 4);settings.remove("monkey");
QStringList keys = settings.allKeys();
// keys: ["ape"]
请注意,如果其中一个回退位置包含具有相同键的设置,则在调用remove()后该设置将可见。 如果key为空字符串,则删除当前组()中的所有键。例如:
QSettings settings;
settings.setValue("ape");
settings.setValue("monkey", 1);
settings.setValue("monkey/sea", 2);
settings.setValue("monkey/doe", 4);settings.beginGroup("monkey");
settings.remove("");
settings.endGroup();QStringList keys = settings.allKeys();
// keys: ["ape"]
注意,Windows注册表和INI文件使用不区分大小写的键,而macOS和iOS上的CFPreferences API使用区分大小写的键。为了避免可移植性问题。
设置访问INI文件的编解码器(包括。Unix上的conf文件)转换为编解码器。编解码器用于对从INI文件读取的任何数据进行解码,并对写入文件的任何数据进行编码。默认情况下,不使用编解码器,非ASCII字符使用标准INI转义序列进行编码。
void QSettings::setIniCodec(QTextCodec *codec)
警告
:在访问任何数据之前,必须在创建QSettings对象之后立即设置编解码器。
设置访问INI文件的编解码器(包括。conf文件)转换为由codecName指定的编码的QTextCodec。codecName的常用值包括“UTF-8”、“ISO 8859-1”和“UTF-16”。如果编码没有被识别,什么都不会发生。
void QSettings::setIniCodec(const char *codecName)
将用于存储给定格式和范围的设置的路径设置为path。该格式可以是自定义格式。
void QSettings::setPath(QSettings::Format format, QSettings::Scope scope, const QString &path)
下表总结了默认值:
将设置键的值设置为value。如果该键已经存在,以前的值将被覆盖。
void QSettings::setValue(const QString &key, const QVariant &value)
注意,Windows注册表和INI文件使用不区分大小写的键,而macOS和iOS上的CFPreferences API使用区分大小写的键。
将任何未保存的更改写入永久存储,并重新加载同时已被另一个应用程序更改的任何设置。 这个函数由QSettings的析构函数自动调用,并由事件循环定期调用,所以通常不需要自己调用。
void QSettings::sync()
返回设置键的值。如果该设置不存在,则返回defaultValue。 如果没有指定默认值,则返回默认的QVariant。
注意,Windows注册表和INI文件使用不区分大小写的键,而macOS和iOS上的CFPreferences API使用区分大小写的键。
QVariant QSettings::value(const QString &key, const QVariant &defaultValue = QVariant()) const
QSettings settings;
settings.setValue("animal/snake", 58);
settings.value("animal/snake", 1024).toInt(); // returns 58
settings.value("animal/zebra", 1024).toInt(); // returns 1024
settings.value("animal/zebra").toInt(); // returns 0
这个类写文件的特征
用户通常希望应用程序记住它的设置(窗口大小和位置,选项等)。)跨会话。
这些信息通常存储在Windows的系统注册表中,以及macOS和iOS的属性列表文件中。
在Unix系统上,由于缺乏标准,许多应用程序(包括KDE应用程序)都使用INI文本文件。
QSettings是围绕这些技术的抽象,使您能够以可移植的方式保存和恢复应用程序设置。它还支持自定义存储格式。
QSettings的API基于QVariant,可以让你用最少的努力保存大多数基于值的类型,比如QString、QRect、QImage
。 如果您只需要一个非持久的基于内存的结构,可以考虑使用QMap<QString,QVariant >来代替。
QSettings对象既可以在堆栈上创建,也可以在堆上创建(即使用new)。构造和销毁QSettings对象的速度非常快。
学完一定要看看妹子,放松下
相关文章:

QSettings Class
QSettings类 QSettings类公共类型(枚举)公有成员函数静态成员函数函数作用这个类写文件的特征 QSettings类 QSettings类提供持久的独立于平台的应用程序设置。 头文件:#include< QSettings >qmake:QT core继承(父):QObje…...
【vue】关于vue中的插槽
当在Vue.js中构建可复用的组件时,有时候需要在父组件中传递内容给子组件。Vue的插槽(slot)机制提供了一种灵活的方式来实现这种组件间通信。 插槽允许你在父组件中编写子组件的内容,然后将其传递给子组件进行渲染。这样ÿ…...

Springboot整合Mybatis Plus【超详细】
文章目录 Mybatis Plus简介快速整合1,导入依赖2,yml文件中配置信息3,启动类上加上扫描mapper接口所在包的注解4,编写配置类5,实现自动注入通用字段接口(非必需)6,编写生成器工具类 使…...

接口测试-使用mock生产随机数据
在做接口测试的时候,有的接口需要进行大量的数据进行测试,还不能是重复的数据,这个时候就需要随机生产数据进行测试了。这里教导大家使用mock.js生成各种随机数据。 一、什么是mock.js mock.js是用于生成随*机数据,拦截 Ajax 请…...

Kohl‘s百货的EDI需求详解
Kohls是一家美国的连锁百货公司,成立于1962年,总部位于美国威斯康星州的门多西。该公司经营各种商品,包括服装、鞋子、家居用品、电子产品、化妆品等,并拥有超过1,100家门店,分布在美国各地。本文将为大家介绍Kohls的E…...
二叉树part6 | ● 654.最大二叉树 ● 617.合并二叉树 ● 700.二叉搜索树中的搜索 ● 98.验证二叉搜索树
文章目录 654.最大二叉树思路代码 617.合并二叉树思路代码 700.二叉搜索树中的搜索思路代码 98.验证二叉搜索树思路官方题解代码困难 今日收获 654.最大二叉树 思路 前序遍历构造二叉树。 找出数组中最大值,然后递归处理左右子数组。 时间复杂度On2 空间复杂度On …...
Linux命令记录
Shells 查看当前系统shell cat /etc/shells # 输出 # /etc/shells: valid login shells /bin/sh /bin/bash /usr/bin/bash /bin/rbash /usr/bin/rbash /bin/dash /usr/bin/dash查看正在使用的shell echo $SHELL # 输出 /bin/bashLinux文件结构 bin:系统可执行文件b…...
eBPF 入门实践教程十五:使用 USDT 捕获用户态 Java GC 事件耗时
eBPF (扩展的伯克利数据包过滤器) 是一项强大的网络和性能分析工具,被广泛应用在 Linux 内核上。eBPF 使得开发者能够动态地加载、更新和运行用户定义的代码,而无需重启内核或更改内核源代码。这个特性使得 eBPF 能够提供极高的灵活性和性能,…...

Linux :: vim 编辑器的初次体验:三种 vim 常用模式 及 使用:打开编辑、退出保存关闭vim
前言:本篇是 Linux 基本操作篇章的内容! 笔者使用的环境是基于腾讯云服务器:CentOS 7.6 64bit。 学习集: C 入门到入土!!!学习合集Linux 从命令到网络再到内核!学习合集 目录索引&am…...

Linux内核进程创建流程
本文代码基于Linux5.10 内容主要参考《Linux内核深度解析》余华兵 当Linux内核要创建一个新进程时, 流程大致如下 ret fork(); if (ret 0) {/* 子进程装载程序 */ret execve(filename, argv, envp); } else if (ret > 0) {/* 父进程 */ } 大致可以分为创建新…...
【03.04】大数据教程--HTTP协议和静态Web服务器
HTTP协议和静态Web服务器 HTTP(Hypertext Transfer Protocol)是一种用于传输超文本的协议,它是Web上的基础通信协议。静态Web服务器是指能够提供静态内容(如HTML、CSS、JavaScript和图像文件)的服务器。 在本教程中&am…...

数据共享传输:台式机和笔记本同步文件!
为什么要在台式机和笔记本同步文件? “我想在台式机和笔记本同步文件。因为我工作时使用笔记本,在家里使用安装了Windows 10系统的台式机,我想要在笔记本和台式机之间同步应用程序、游戏、文档等。有没有一种可以在台式机和笔记本同步文件的…...

java设计模式(十二)代理模式
目录 定义模式结构角色职责代码实现静态代理动态代理jdk动态代理cglib代理 适用场景优缺点 定义 代理模式给某一个对象提供一个代理对象,并由代理对象控制对原对象的引用。说简单点,代理模式就是设置一个中间代理来控制访问原目标对象,以达到…...

Umi微前端水印踩坑以及解决方案
最近公司需要在管理后台加一个水印方案~ 项目用的umi方案,以为就是改一个配置的问题,后来发现坑点还蛮多~ 希望此稳定能帮助到用umi 的你们. 一. 先来说说心路历程 坑点1 umi的水印适配只能在layout中进行配置,也就是路由配置中layout为false的页面无法配置水印,比如说登录页…...
Android RK3588-12 hdmi-in Camera方式支持NV24格式
hdmi-in Camera方式支持NV24格式 modified: hardware/interfaces/camera/device/3.4/default/ExternalCameraDevice.cpp modified: hardware/interfaces/camera/device/3.4/default/ExternalCameraDeviceSession.cpp diff --git a/hardware/interfaces/camera/device/3.4…...
Hive窗口函数详细介绍
文章目录 Hive窗口函数概述样本数据表结构表数据 窗口函数窗口聚合函数count()SQL演示 sum()SQL演示 avg()SQL演示 min()SQL演示 max()SQL演示 窗口分析函数first_value() 取开窗第一个值应用场景SQL演示 last_value()取开窗最后一个值应用场景SQL演示 lag(col, n, default_val…...
牛客网【c语言练习】
单选题 下面代码段的输出是(-12 ) int main() {int a3; printf("%d\n",(aa-a*a)); } aa-9,此时还是等于3,因为a*a只是运算,并没有赋值;之后再算a-9,运算之前a等于3,运算…...

C++类和对象(上)
文章目录 🦍1. 面向过程和面向对象🦧2. 类的引入🐶3. 类的定义🦮4. 类的访问控制和封装🍖4.1 访问限定符🍖4.2 封装 🐩5. 类的作用域🐅6. 类的实例化🐄7. 类的大小计算&a…...

JavaScript 数据透视表 DHTMLX Pivot Crack
DHTMLX Pivot JavaScript 数据透视表 - 强大的数据汇总和报告 使用我们的高速 JavaScript/HTML5 Pivot 组件可视化您的复杂数据,从而提高您的商业智能。 它可以帮助您以方便的方式汇总大型数据集。 主要特征 纯 JavaScript 库,可轻松与任何服务器端集成…...
QT链接库设置
以windows 平台为例,在.pro 文件中: 1 增加 INCLUDEPATH <头文件路径> DEPENDPATH <头文件路径> 2 LIBS -L<库目录路径> -l<库得名字> 3 设置MT、MTD、MD、MDD运行时库 win32:CONFIG(debug, debug|release): { QMAKE_CFLAGS_…...
挑战杯推荐项目
“人工智能”创意赛 - 智能艺术创作助手:借助大模型技术,开发能根据用户输入的主题、风格等要求,生成绘画、音乐、文学作品等多种形式艺术创作灵感或初稿的应用,帮助艺术家和创意爱好者激发创意、提高创作效率。 - 个性化梦境…...
Java 语言特性(面试系列1)
一、面向对象编程 1. 封装(Encapsulation) 定义:将数据(属性)和操作数据的方法绑定在一起,通过访问控制符(private、protected、public)隐藏内部实现细节。示例: public …...

23-Oracle 23 ai 区块链表(Blockchain Table)
小伙伴有没有在金融强合规的领域中遇见,必须要保持数据不可变,管理员都无法修改和留痕的要求。比如医疗的电子病历中,影像检查检验结果不可篡改行的,药品追溯过程中数据只可插入无法删除的特性需求;登录日志、修改日志…...

家政维修平台实战20:权限设计
目录 1 获取工人信息2 搭建工人入口3 权限判断总结 目前我们已经搭建好了基础的用户体系,主要是分成几个表,用户表我们是记录用户的基础信息,包括手机、昵称、头像。而工人和员工各有各的表。那么就有一个问题,不同的角色…...
代码随想录刷题day30
1、零钱兑换II 给你一个整数数组 coins 表示不同面额的硬币,另给一个整数 amount 表示总金额。 请你计算并返回可以凑成总金额的硬币组合数。如果任何硬币组合都无法凑出总金额,返回 0 。 假设每一种面额的硬币有无限个。 题目数据保证结果符合 32 位带…...

【从零学习JVM|第三篇】类的生命周期(高频面试题)
前言: 在Java编程中,类的生命周期是指类从被加载到内存中开始,到被卸载出内存为止的整个过程。了解类的生命周期对于理解Java程序的运行机制以及性能优化非常重要。本文会深入探寻类的生命周期,让读者对此有深刻印象。 目录 …...

数学建模-滑翔伞伞翼面积的设计,运动状态计算和优化 !
我们考虑滑翔伞的伞翼面积设计问题以及运动状态描述。滑翔伞的性能主要取决于伞翼面积、气动特性以及飞行员的重量。我们的目标是建立数学模型来描述滑翔伞的运动状态,并优化伞翼面积的设计。 一、问题分析 滑翔伞在飞行过程中受到重力、升力和阻力的作用。升力和阻力与伞翼面…...

五子棋测试用例
一.项目背景 1.1 项目简介 传统棋类文化的推广 五子棋是一种古老的棋类游戏,有着深厚的文化底蕴。通过将五子棋制作成网页游戏,可以让更多的人了解和接触到这一传统棋类文化。无论是国内还是国外的玩家,都可以通过网页五子棋感受到东方棋类…...
6️⃣Go 语言中的哈希、加密与序列化:通往区块链世界的钥匙
Go 语言中的哈希、加密与序列化:通往区块链世界的钥匙 一、前言:离区块链还有多远? 区块链听起来可能遥不可及,似乎是只有密码学专家和资深工程师才能涉足的领域。但事实上,构建一个区块链的核心并不复杂,尤其当你已经掌握了一门系统编程语言,比如 Go。 要真正理解区…...
机器学习的数学基础:线性模型
线性模型 线性模型的基本形式为: f ( x ) ω T x b f\left(\boldsymbol{x}\right)\boldsymbol{\omega}^\text{T}\boldsymbol{x}b f(x)ωTxb 回归问题 利用最小二乘法,得到 ω \boldsymbol{\omega} ω和 b b b的参数估计$ \boldsymbol{\hat{\omega}}…...