.net – IO.FileNotFoundException但文件应该存在
发布时间:2020-12-17 00:23:03 所属栏目:大数据 来源:网络整理
导读:虽然我确信该文件存在,但我得到了令人惊讶的FileNotFoundException. 我只是想添加Logfiles(IO.FileInfo)作为电子邮件的附件,因此我试图检查每个文件的长度,以检测它们是否必须添加/压缩. 如果这些文件已存在,这可以正常工作. 但是,如果我在这次运行中创建它
虽然我确信该文件存在,但我得到了令人惊讶的FileNotFoundException.
我只是想添加Logfiles(IO.FileInfo)作为电子邮件的附件,因此我试图检查每个文件的长度,以检测它们是否必须添加/压缩. 这是一些代码…… 在名为Log的类的构造函数中创建其中一个文件: Me.LogFile = New IO.FileInfo(infoLogPath) If Not LogFile.Exists() Then 'tried to use `Using` on the Stream but that doesn't change anything' Using stream = Me.LogFile.Create() 'close and dispose implicitely End Using End If 我可以毫无问题地写入文件: Me.Log.WriteInfo("BlahBlahBlah...",False) 我在LogFile.Length上获得异常后的一行: If Me.Log.LogFile.Length <> 0 Then files.Add(Me.Log.LogFile) End If Me.Log是一个名为Log的自定义日志记录类对象,它保存对FileInfo对象的引用. 这是类Log中的WriteInfo,LogFile是IO.FileInfo-onject: Public Sub WriteInfo(ByVal message As String,ByVal finishLog As Boolean) Try Using w As IO.StreamWriter = Me.LogFile.AppendText If Me.WithTimestamp Then w.WriteLine(Date.Now.ToString(Globalization.CultureInfo.InvariantCulture) & ": " & message) Else w.WriteLine(message) End If If finishLog Then w.WriteLine("__________________________") w.Flush() w.Close() End Using Catch writeLogException As Exception Try WriteError(writeLogException,True) Catch innerEx As Exception 'ignore End Try End Try End Sub 实际上@ShellShocks solution与Refresh很简单.从来没有听说过这个函数,奇怪的是,当我不刷新文件时,我得到了一个FileNotFoundException. Me.Log.LogFile.Refresh()
尝试在FileInfo.Exists或FileInfo.Length之前调用
FileInfo.Refresh – 这些属性可能会被缓存,因此Refresh将获取最新值.
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |