ConfigurationManager.AppSettings Caching
We know that IIS caches ConfigurationManager.AppSettings so it reads the disk only once until the web.config is changed. This is done for performance purposes.
Someone at:
http://forums.asp.net/p/1080926/1598469.aspx#1598469
stated that .NET Framework doesn't do the same for app.config, but it reads from the disk for every request. But I find it hard to believe, 'cause it would be slower. Please tell me that he is wrong or I'll have to fix every Console/Windows Forms/Windows Services I wrote.
Update I regret that I misinterpreted what people said in the linked forum above.
A quick test seems to show that these settings are only loaded at application startup.
//edit the config file now.
Console.ReadLine();
Console.WriteLine(ConfigurationManager.AppSettings["ApplicationName"].ToString());
Console.WriteLine("Press enter to redisplay");
//edit the config file again now.
Console.ReadLine();
Console.WriteLine(ConfigurationManager.AppSettings["ApplicationName"].ToString());
Console.ReadLine();
You'll see that all outputs remain the same.
Try it,
ConfigurationManager.RefreshSection("appSettings")
Just be careful file name (in bin folder)
Normal file name : appname.exe.config
if debug mode : appname.vshost.exe.Config
It doesn't matter if it does or not. Don't fix a performance problem if there isn't one.
It reads the application configuration file (MyApp.exe.config) once at application startup, as can easily be verified by changing the file while the app is running.
The comment in the forum post referenced by the OP was:
The values for the Web.config are stored into cache/memory when the application starts hence why the app restarts when any changes are made to the web.config. Note that this only applies to the Web.config, any other .config files you may use are accessed from the disk by default
I would interpret this comment as meaning that config files other than web.config in an ASP.NET application are accessed from the disk by default. And similarly, config files other than MyApp.exe.config in a WinForms/Console application are accessed from the disk by default.
This comment is not stating that MyApp.exe.config is read from the disk by default.
AppSettings is cached. You can improve performance by further caching to limit namevaluecollection lookups.
See: DotNetPearls Static Config Pattern