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.
You'll see that all outputs remain the same.
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:
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.
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.
AppSettings is cached. You can improve performance by further caching to limit namevaluecollection lookups.
See: DotNetPearls Static Config Pattern
As John says only spend more time on this if you are actually seeing a performance hit.
Also I'm pretty sure that these applications hold the configuration in memory, and to see any changes within a config the application would have to be restarted.
For some further reading about remaining mysteries.