C#读文件为什么结束不了啦,大家帮忙看看代码
[解决办法]
你将if里面的改成大于0试一下,我记得好像读到末尾的时候就返回值为0.
但是你说1024的时候就好着。。。
[解决办法]
这里有两个错误,另一个错误你还不容易发现
1 fs.Read 如果遇到文件结束,会返回 0 ,但你并不退出循环,这就是问题
2 fo.Write 的长度你写错了,应该用 fs.Read 返回的长度,这样会导致文件比原来的长,多出来的部分内容是最后第二次读取的,导致文件长度变成数组长度的整数倍。
[解决办法]
我试了一下,你将等号去掉,就好了,虽然会出现你上面说的那个问题,但是多出来的大小不会大于你定义的一个byte的大小的,因为只有在最后读取的一个byte里面才会出现内容不足的情况
------解决方案--------------------
按照你之前的那样不行吗?
[解决办法]
肯定比你这个1024*1024这个大!
[解决办法]
应该是读写时候的长度精确出问题了吧,不过也没有理由2G的东西能多出几G来啊
[解决办法]
为什么不用File.Copy,多好,别人一看就知道那干嘛用的
[解决办法]
用StreamReader流读取,EndOfStream属性就能判断是否结束!
[解决办法]
因为用了Socket网络传输,所以就快不了!
[解决办法]
有简单的做法,为什么要弄那么复杂呢?
System.IO.FileStream fs = System.IO.File.OpenRead(@"G:\音乐\杰子 - 玫瑰花儿开.mp3");
fs.CopyTo(System.IO.File.OpenWrite(@"G:\音乐\杰子 - 玫瑰花儿开1.mp3"));
[解决办法]
如果想一次读完,有简单方法
var fs = System.IO.File.OpenRead()
using(var ms = new MemoryStream(fs))
byte[] datas = ms.ToArray();
不过大文件一般都是分块发送
[解决办法]
你一次读完再发送还想快,要想快就分块异步读取异步发送
[解决办法]
while (fs.Read(b,0,b.Length) >= 0)
{
fo.Write(b,0,b.Length);
fo.Flush();
}
问题出在这里!
[解决办法]
String path = @"D://TDDOWNLOAD//Ju-on.2000.2in1.DVDRip-AVC.mkv";
//Open the stream and read it back.
FileStream fs = File.OpenRead(path);
FileStream fo = File.OpenWrite(@"E://Ju-on.2000.2in1.DVDRip-AVC.mkv");
byte[] b = new byte[1024 * 1024];
while (fs.Read(b,0,b.Length) >= 0)
{
fo.Write(b,0,b.Length);
fo.Flush();
}
fo.Close();
fs.Close();
这是按照帮助文档上写的读写文件,刻个文件一共2G,可是一直结束不了,会多出几个G出来。
byte写1024的话就没有问题,些1024 * 1024 就有问题了。
String path = @"D://TDDOWNLOAD//Ju-on.2000.2in1.DVDRip-AVC.mkv";
//Open the stream and read it back.
FileStream fs = File.OpenRead(path);
FileStream fo = File.OpenWrite(@"E://Ju-on.2000.2in1.DVDRip-AVC.mkv");
byte[] b = new byte[1024 * 1024];
while (fs.Read(b,0,b.Length) >= 0) <-问题出在这知道没
{
fo.Write(b,0,b.Length);
fo.Flush();
}
fo.Close();
fs.Close();
//改成这样
String path = @"D://TDDOWNLOAD//Ju-on.2000.2in1.DVDRip-AVC.mkv";
//Open the stream and read it back.
FileStream fs = File.OpenRead(path);
FileStream fo = File.OpenWrite(@"E://Ju-on.2000.2in1.DVDRip-AVC.mkv");
byte[] b = new byte[1024 * 1024];
int reLen=0;
while ((reLen=fs.Read(b,0,b.Length))>= 0) //<--这里要这样
{
fo.Write(b,0,reLen); 《-这里要这样
fo.Flush();
}
fo.Close();
fs.Close();
[解决办法]
byte[] b = new byte[1024 * 1024];
红色字建议改为何4096或8192
while (fs.Read(b,0,b.Length) >4096或8192)
[解决办法]
String path = @"D://TDDOWNLOAD//Ju-on.2000.2in1.DVDRip-AVC.mkv";
//Open the stream and read it back.
FileStream fs = File.OpenRead(path);
FileStream fo = File.OpenWrite(@"E://Ju-on.2000.2in1.DVDRip-AVC.mkv");
byte[] b = new byte[1024 * 1024];
while (fs.Read(b,0,b.Length) >= 0)
{
fo.Write(b,0,b.Length);
fo.Flush();
}
fo.Close();
fs.Close();
这是按照帮助文档上写的读写文件,刻个文件一共2G,可是一直结束不了,会多出几个G出来。
byte写1024的话就没有问题,些1024 * 1024 就有问题了。
你是为了传输文件?那要做分块。。写个文件分块类。。看你结贴率高,就给你一个我项目上用的文件传输分块的类,你一下就明白了。
public class FileReader
{
private long _partCount;
private long _length;
private int _partSize = 4096 * 4;//每个块容量
private string _md5;
private object _tag;
private byte[] _partBuffer;
private int readPartIndex;
private string _filePath;
private DateTime _LastReadTime;
private string _fileName;
public DateTime LastReadTime { get { return _LastReadTime; } }
public bool IsTimeout
{
get
{
return (DateTime.Now - _LastReadTime).TotalMinutes > 5;
}
}
public string Key { get; set; }
/// <summary>
/// 块数量
/// </summary>
public long PartCount
{
get { return _partCount; }
}
/// <summary>
/// 文件长度
/// </summary>
public long Length
{
get { return _length; }
}
/// <summary>
/// 每块容量
/// </summary>
public int PartSize
{
get { return _partSize; }
}
/// <summary>
/// 文件路径
/// </summary>
public string FilePath
{
get { return _filePath; }
}
/// <summary>
/// 文件名
/// </summary>
public string FileName
{
get { return _fileName; }
}
/// <summary>
/// MD5码
/// </summary>
public string MD5
{
get { return _md5; }
}
public object Tag
{
get
{
return _tag;
}
set
{
_tag = value;
}
}
public FileReader(string filePath)
{
this._filePath = filePath;
this._fileName = Path.GetFileName(filePath);
this._partBuffer = new byte[_partSize];
InitReader();
}
public FileReader(string filePath, int partSize)
{
this._filePath = filePath;
this._fileName = Path.GetFileName(filePath);
this._partSize = partSize;
this._partBuffer = new byte[_partSize];
InitReader();
}
private void InitReader()
{
_LastReadTime = DateTime.Now;
using (FileStream _fileStream = CreateReader())
{
_length = _fileStream.Length;
_partCount = _length / _partSize;
if (_length % _partSize != 0)
{
_partCount++;
}
_md5 = MD5Helper.CretaeMD5(_fileStream);
_fileStream.Close();
}
}
private FileStream CreateReader()
{
FileStream fileStream = new FileStream(_filePath, FileMode.Open, FileAccess.Read, FileShare.Read, _partSize * 10, false);
return fileStream;
}
public byte[] Read(long index)
{
_LastReadTime = DateTime.Now;
if (index >= _partCount
[解决办法]
index < 0)
return null;
int size = _partSize;
if (_length - _partSize * index < _partSize)
{
size = (int)(_length - _partSize * index);
}
using (FileStream _fileStream = CreateReader())
{
_fileStream.Position = index * _partSize;
int len = _fileStream.Read(this._partBuffer, 0, size);
byte[] buffer = new byte[len];
Buffer.BlockCopy(_partBuffer, 0, buffer, 0, len);
_fileStream.Close();
return buffer;
}
}
}