C# FileStream读写文件(.txt)时候用excel操作此文件,写入数据线程会被终止
利用线程实时存储数据,存储为.txt用下面方法FileStreamfile=newFileStream(FilePath,FileMode.Append,FileAcce...
利用线程实时存储数据,存储为.txt 用下面方法
FileStream file = new FileStream(FilePath, FileMode.Append,FileAccess.Write,FileShare.None);
byte[] data = System.Text.Encoding.Default.GetBytes(str);
file.Seek(file.Length, SeekOrigin.Begin);
file.Write(data, 0, data.Length);
file.Flush();
file.Close();
在线程中存储,但是,我在存储过程中要查看数据 用excel打开线程会被终止,不再存储。 展开
FileStream file = new FileStream(FilePath, FileMode.Append,FileAccess.Write,FileShare.None);
byte[] data = System.Text.Encoding.Default.GetBytes(str);
file.Seek(file.Length, SeekOrigin.Begin);
file.Write(data, 0, data.Length);
file.Flush();
file.Close();
在线程中存储,但是,我在存储过程中要查看数据 用excel打开线程会被终止,不再存储。 展开
2个回答
展开全部
private void WriteIntoFile(object obj,string filename)
{
lock (o)
{
using (FileStream fs = new FileStream(filename, FileMode.Append, FileAccess.Write))
{
byte[] bytData = rawSerialize(obj);
fs.Write(bytData, 0, bytData.Length);
fs.Close();
}
}
}
第一,尝试下释放fs?
第二,尝试下运行共享写?using (FileStream fs = new FileStream(filename, FileMode.Append, FileAccess.Write,FileShare.Write))?
{
lock (o)
{
using (FileStream fs = new FileStream(filename, FileMode.Append, FileAccess.Write))
{
byte[] bytData = rawSerialize(obj);
fs.Write(bytData, 0, bytData.Length);
fs.Close();
}
}
}
第一,尝试下释放fs?
第二,尝试下运行共享写?using (FileStream fs = new FileStream(filename, FileMode.Append, FileAccess.Write,FileShare.Write))?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询