簡體   English   中英

為什么這段代碼會拋出 NullReferenceException?

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM