[英]ImageSourceConverter throws a NullReferenceException … why?
[英]Why does this code throws NullReferenceException?
public FileEntry ReadFileConfiguration(string id)
{
string configurationPath = "conf.xml";
XDocument data = XDocument.Load(configurationPath);
return (from c in data.Descendants("file")
where (c.Attribute("Id") != null && c.Attribute("Id").Value.Equals(id))
select new FileEntry()
{
Name = c.Element("Name").Value,
Path = c.Element("Path").Value,
SheduledTime = Convert.ToDateTime(c.Element("SheduledTime").Value),
Size = (long)Convert.ToDouble( c.Element("Size").Value),
IsFolder = Convert.ToBoolean( c.Element("IsFolder").Value),
LastAccess = Convert.ToDateTime(c.Element("LastAccess").Value),
DoEncrypt = Convert.ToBoolean( c.Element("DoEncrypt").Value)
}).First();
}
主要程序是:
main()
{
string id = "C:\\Users\\Radhesh\\Documents\\Visual Studio 2008\\Projects\\Rme\\Rme\\test.txt";
ReadFileConfiguration(id);
}
我的 XML 頁面是:
<?xml version="1.0" encoding="utf-8" ?>
<Files>
<file Id="C:\Users\Radhesh\Documents\Visual Studio 2008\Projects\Rme\Rme\test.txt">
<Name>test.txt</Name>
<Path>C:\Users\Radhesh\Documents\Visual Studio 2008\Projects\Rme\Rme\test.txt</Path>
<IsFolder>False</IsFolder>
<DoEncrypt>True</DoEncrypt>
<Size>0</Size>
<LastAcess>7/9/2011 11:35:53 PM</LastAcess>
<SheduledTime>7/10/2011 1:59:20 PM</SheduledTime>
</file>
</Files>
我的 class:
class FileEntry
{
public string Name { get;set;}
public string Path { get; set; }
public bool IsFolder { get; set; }
public long Size { get;set; }
public DateTime LastAccess { get;set; }
public DateTime SheduledTime { get; set; }
public bool DoEncrypt { get; set; }
}
請問,有人可以幫忙嗎?
<LastAcess>7/9/2011 11:35:53 PM</LastAcess>
LastAccess = Convert.ToDateTime(c.Element("LastAccess").Value),
注意: "Acess"
和Access
從分解它開始。
string configurationPath = "conf.xml";
XDocument data = XDocument.Load(configurationPath);
var files = from c in data.Descendants("file") select c;
Debug.WriteLine("Count = {0}", files.Count());
...
return files.First();
這應該是 output 1(或更高)。
如果成功,則在select
之前添加where
子句。
然后更改為完整的 select 部分並添加Name = c.Element("Name").Value,
第 1 行和第 1 行。
我按照@Henk Holterman 建議的步驟進行操作,這就是您看到 Null 參考異常的原因。 在您的 select 中:
LastAccess = Convert.ToDateTime(c.Element("LastAccess").Value)
如果您查看 XML 文件,您有:
<LastAcess>7/9/2011 11:35:53 PM</LastAcess>
簡而言之,你有一個錯字。 查詢的 select 部分找不到名為“LastAccess”的元素,因此拋出 Null 參考異常。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.