目录
简述
App.config 是 C#中最常用的配置文件类型。 通常位于项目的根目录中,以 XML 格式存储配置信息。App.config 文件可以包含多个配置节,如 appSettings、connectionStrings、system.web 等,用于存储不同的配置信息。如图资源管理器中引用中可以看到它的身影。它是引用.net库中的System.Configuration.dll文件。
这里我们用appSettings节点的读写来简单描述一下它的使用。
代码描述
我们因为是配置信息,我们一般将其写在初始化或构造函数中提前读取,下面是代码构建步骤及说明。
一、构建App.config
中间的内容是我们构建或者说是添加的配置项目,一个key对应一个value值。
xml
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<startup>
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.7.2" />
</startup>
<appSettings>
<add key="num" value="1"/>
</appSettings>
</configuration>
二、调用代码
1、代码步骤说明
- 我们首先通过读取参数获取字符串的值,
- 然后将字符串转整型后加1,
- 最后再写入配置中,
- 再次读取配置文件。
c
public Form1()
{
InitializeComponent();
add_one();
}
private void add_one()
{
//读取参数
string readStr = ConfigurationManager.AppSettings["num"];
if (string.IsNullOrEmpty(readStr))
{
readStr = "0";
}
Console.WriteLine($"num1={readStr}");
//+1
string writeStr = (int.Parse(readStr) + 1).ToString();
//写入新值
Configuration config = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);
config.AppSettings.Settings["num"].Value = writeStr;
config.Save(ConfigurationSaveMode.Minimal);
Console.WriteLine($"num2={writeStr}");
//再次读取仍然是原值//除非重新启动
string rereadStr = ConfigurationManager.AppSettings["num"];
Console.WriteLine($"num3={readStr}");
}
打印输出
num1=8
num2=9
num3=8
2、输出结果说明
可以从打印输出可以看出,虽然改变了配置参数,但是重新读取的配置参数书不糊及变化的,这个是它的关键特殊所在,也就是说,一旦启动后无论如何改变它,读的值是不变的,相当于readonly。
但是如果重启后是什么情况呢,请小伙伴们自己试一试吧!