我有一个C#应用程序,其中包含以下代码:
string file = "relativePath.txt";
//Time elapses...
string contents = File.ReadAllText(file);
大部分时间都可以正常使用。该文件是相对于启动应用程序的目录读取的。但是,在测试中,已经发现如果单独放置大约5个小时,应用程序将抛出FileNotFoundException
,说无法找到“C:\ Documents and Settings \ Adminstrator \ relativePath.txt”。如果立即运行读取文件的操作,则从正确的位置读取文件,我们称之为“C:\ foo \ relativePath.txt”
是什么给出的?而且,什么是最好的解决方案?针对Assembly.GetEntryAssembly().Location
解析文件?
答案 0 :(得分:7)
可以改变你的路径的一个怪异的地方是OpenFileDialog。当用户在文件夹之间导航时,它会将您的应用程序目录更改为当前正在查看的目录。如果用户在另一个目录中关闭对话框,那么您将被困在该目录中。
它有一个名为RestoreDirectory的属性,它会使对话框重置路径。但我相信默认是“假”。
答案 1 :(得分:5)
如果文件始终位于相对于可执行程序集的路径中,则使用Assembly.Location。我主要使用Assembly.GetExecutingAssembly,而不是Assembly.GetEntryAssembly。这意味着如果您从DLL访问该文件,该路径将相对于DLL路径。
答案 2 :(得分:2)
我认为课程应该是不依赖于相对路径,它们容易出错。当前目录可以通过运行过程中的任何数量的东西来改变,比如文件对话框(虽然有一个属性可以防止它们改变它),所以你永远不能真正保证相对路径在任何时候都会导致什么,除非你使用从Application.StartupPath等已知路径生成固定路径的相对路径(虽然从Visual Studio启动时要注意)或其他一些已知路径。
使用相对路径会使您的代码难以维护,因为项目中完全不相关的部分的更改可能会导致其他部分失败。
答案 3 :(得分:1)
在System.Environment中,您拥有SpecialFolder枚举,可帮助您获得标准相对路径。
至少这种方式,路径是内部传递给你的,所以希望如果系统以某种方式改变路径,代码就会处理它。
答案 4 :(得分:1)
如果你喜欢
> cd c:\ folder 1
c:\ folder 1> ../folder 2 / theApplication.exe
应用程序的当前工作目录将是c:\ folder 1。
这是一个示例程序
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows.Forms;
namespace CWD {
class Program {
static void Main (string[] args) {
Console.WriteLine(Application.StartupPath);
}
}
}
在visualstudio中构建它,然后在debug / bin目录中打开命令提示符并执行
bin / debug> CWD.exe
然后做
bin / debug> cd ../../ >箱/调试/ CWD.exe
您将看到启动路径的差异。
关于原始问题...... “如果单独放置大约5个小时,应用程序将抛出FileNotFoundException”
应用程序运行后,仅移动或从预期位置删除该文件会导致此错误。
格雷格
答案 5 :(得分:0)
如果你使用openfiledialog并且remember path属性(不确定确切名称)是真的那么它会改变你认为的当前目录。