QSettings类 简介(Qt说明文档)
QSettings类提供了持久的跨平台应用程序设置。用户通常期望应用程序记住它的设置(窗口大小、位置等)所有会话。这些信息通常存储在Windows系统注册表,OS X和iOS的属性列表文件中。在Unix系统中,在缺乏标准的情况下,许多应用程序(包括KDE应用程序)使用INI文本文件。QSettings围绕这些抽象技术,使我们能够以便携的方式保存和恢复应用程序设置。它还支持自定义存储格式。QSettings API基于QVariant,可以保存很多基础的类型,比如 QString、QRect、QImage等。如果你需要的是一个非持久性的基于内存结构,可以考虑使用QMap<QString, QVariant>代替。
文件路径获取方法:
QString exe_FilePath = QCoreApplication::applicationDirPath(); //获取exe应用程序路径
QString current_FilePath= QDir::currentPath(); //获取当前工作目录路径
// 文件名
QString ini_FileName ="IP_config";
//文件生成路径
QString ini_FilePath= exe_FilePath +"/config/" + ini_FileName;
QSetting对象既可以创建在栈上,也可以创建在堆(即new)上,构建和销毁速度很快。当创建一个QSetting对象时,必须指定公司或组织名称(或文件名),和产品应用名称(或文件格式,例如Windows中的.ini)。
1、创建QSetting对象
方法一:
// 创建一个QSettiQngs对象,格式为.ini
QSettings configIniWrite (ini_FilePath,QSettings::IniFormat);
方法二:
//指定组织名
QCoreApplication::setOrganizationName("MySoft");
QCoreApplication::setOrganizationDomain("mysoft.com");
//指定应用名
QCoreApplication::setApplicationName("Star Runner");
...
// 创建QSetting对象
QSettings configIniWrite ;
2、写配置文件内容
方法一:
//【IP】为组名,【/】为分层键,first为键值对名称,后为键值,与下方方法同理
configIniWrite.setValue("/IP/first", "192.168.0.1");
效果如下
[IP]
first=192.168.0.1
方法二:
// 设置组名
configIniWrite.beginGroup("section1");
// 写入键值对 key = value
configIniWrite.setValue("IP_multicast",IP_multicast.toString());
// 写入键值对 key = value
configIniWrite.setValue("Port_multicast",Port_multicast);
// 结束该组内容
configIniWrite.endGroup();
效果如下
[section1]
IP_multicast=239.1.2.1
Port_multicast=6664
3、读配置文件内容
//创建QSettings 对象
QSettings configIniRead(ini_FilePath,QSettings::IniFormat);
//读出内容
QString IP_multicast = configIniRead.value("section1/IP_multicast").toString();
QString Port_multicast = configIniRead.value("section1/Port_multicast").toString()