QSettings + INI 笔记

QSettings + INI 笔记

一、初始化

cpp 复制代码
// 创建/打开INI配置文件
QSettings settings("config.ini", QSettings::IniFormat);

二、基础读写

操作 代码示例 说明
写入 settings.setValue("组/键", 值); 支持int/bool/QString等
读取(带默认值) settings.value("组/键", 默认值).toXXX(); 需指定类型(toInt/toString等)
cpp 复制代码
// 示例:读写
settings.setValue("Window/width", 800);       // 写
int w = settings.value("Window/width", 1024).toInt(); // 读

三、使用技巧

1. 分组管理

cpp 复制代码
settings.beginGroup("Window"); // 进入分组
settings.setValue("width", 800);
settings.endGroup(); // 退出分组

2. 数组存储

cpp 复制代码
// 写数组
settings.beginWriteArray("recentFiles");
for(int i=0; i<files.size(); i++) {
    settings.setArrayIndex(i);
    settings.setValue("path", files[i]);
}
settings.endArray();

// 读数组
int size = settings.beginReadArray("recentFiles");
for(int i=0; i<size; i++) {
    settings.setArrayIndex(i);
    QString p = settings.value("path").toString();
}
settings.endArray();

3. 配置文件路径

cpp 复制代码
// 1. 应用目录(便携):./config.ini
// 2. 系统配置目录(标准):
QString path = QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation) + "/config.ini";
// 3. 绝对路径:D:/app/config.ini

四、示例

cpp 复制代码
class AppConfig {
public:
    static AppConfig& instance() { static AppConfig c; return c; }
    void load() { // 加载配置
        QSettings s("config.ini", QSettings::IniFormat);
        windowW = s.value("Window/width", 800).toInt();
        autoSave = s.value("General/autosave", true).toBool();
    }
    void save() { // 保存配置
        QSettings s("config.ini", QSettings::IniFormat);
        s.setValue("Window/width", windowW);
        s.setValue("General/autosave", autoSave);
        s.sync(); // 立即写入
    }
    // 配置项
    int windowW = 800;
    bool autoSave = true;
private:
    AppConfig() = default; // 单例私有化构造
};

五、常用操作

cpp 复制代码
settings.contains("Window/width"); // 检查键是否存在
settings.remove("Window/width");   // 删除键/分组
settings.allKeys();                // 获取所有键
settings.clear();                  // 清空所有配置
settings.sync();                   // 立即保存(默认析构时保存)

六、注意事项

  1. 路径分隔用 /,跨平台通用
  2. 中文直接支持UTF-8,无需额外处理
  3. 读取时必须指定类型(toInt/toString等)

总结

  1. 核心初始化:QSettings settings("config.ini", QSettings::IniFormat)
  2. 核心操作:setValue() 写、value(键, 默认值).toXXX()
  3. 关键技巧:分组管理、数组存储、单例封装,sync() 立即保存
相关推荐
We་ct2 小时前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
William Dawson6 小时前
2026软考中级系统集成项目管理工程师备考笔记
笔记·系统集成项目管理工程师
王老师青少年编程6 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮7 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说7 小时前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
wuweijianlove8 小时前
关于算法设计中的代价函数优化与约束求解的技术7
算法
leoufung8 小时前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了8 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
HXDGCL9 小时前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化
谭欣辰9 小时前
C++ 排列组合完整指南
开发语言·c++·算法