我试图获得ftp下载文件的速度,但有时我会得到无限的原因?

时间:2014-12-08 14:03:59

标签: c# .net winforms ftp

这是计算下载速度的方法:

private void CalculateDownload(int ln, BackgroundWorker backw)
{
    string speed;
    DateTime DownloadStart = DateTime.Now;

    int dnsize = ln;

    if (dnsize > 0)
    {
        DateTime DownloadEnd = DateTime.Now;
        TimeSpan DownloadSub = DownloadEnd.Subtract(
            DownloadStart);

        speed = string.Format("Download speed: {0:F0} bps\n",
            (dnsize / DownloadSub.TotalMilliseconds) * 1000);
        backw.ReportProgress(0,speed);
    }
}

这是我用来从ftp服务器下载文件的方法。每次单个文件。

public int FtpDownload(object sender, string file, string filesdirectories, string fn)
{
    string tmp = "";

    BackgroundWorker bw = sender as BackgroundWorker;
    string filenameonly = Path.GetFileName(file);
    string ftpdirectories = Path.Combine(ftpcontentdir, filesdirectories);
    string fileurl = "ftp://" + file;
    FtpWebRequest reqFTP;
    reqFTP = (FtpWebRequest)FtpWebRequest.Create(fileurl);
    reqFTP.Credentials = new NetworkCredential(UserName, Password);
    reqFTP.UseBinary = true;
    reqFTP.UsePassive = true;
    reqFTP.KeepAlive = true;

    reqFTP.Method = WebRequestMethods.Ftp.DownloadFile;
    try
    {
        FtpWebResponse response = (FtpWebResponse)reqFTP.
            GetResponse();

        Stream responseStream = response.GetResponseStream();
        StreamReader reader = new StreamReader(responseStream);
        tmp = reader.ReadToEnd();
        CalculateDownload(tmp.Length, bw);
        reader.Close();
        response.Close();
    }
    catch (WebException e)
    {
        Console.WriteLine(e.ToString());
    }

    return tmp.Length;
}

计算下载方法中的第一个文件下载我获取文件大小:

变量ln例如是66349

然后变速包含:下载速度:21367 bps 在下一个文件中:

ln = 59892

然后速度是:下载速度:25100 bps

当我使用断点时工作正常但是如果我没有使用断点而不是25100 bps我会看到infinity bps

在form1中我发送文件如下:

private void backgroundWorker2_DoWork(object sender, DoWorkEventArgs e)
{
    for (int i = 0; i < numberOfFiles.Count; i++)
    {
        int fn = numberOfFiles[i].IndexOf(txtHost.Text, 0);
        string fn1 = numberOfFiles[i].Substring(txtHost.Text.Length + 1, numberOfFiles[i].Length - (txtHost.Text.Length + 1));
        string dirs = Path.GetDirectoryName(fn1);
        string filename = Path.GetFileName(fn1);
        ftpProgress1.FtpDownload(sender, numberOfFiles[i], dirs, filename);
    }
}

进度改变了form1中的事件:

private void backgroundWorker2_ProgressChanged(object sender, ProgressChangedEventArgs e)
{           
    this.toolStripStatusLabel1.Text = e.UserState.ToString();
}

为什么当我使用断点时,它会显示每个文件所播放的时间,但没有断点,它显示的是无穷大?

2 个答案:

答案 0 :(得分:4)

当使用浮点数或双精度数时,除以0会给出无穷大。

您可以添加额外的检查以查看是否已经过了0毫秒 在那种情况下不计算价值。在时间= 0,因为没有下载任何内容 但该值可能对用户没有用。

您还可以通过传递实现具有右侧接口的类来添加单元测试 模拟对back.ReportProgress的调用的方法如:

private void CalculateDownload(int ln, IBackgroundWorker backw)

弄清楚在时间= 0,时间= 1等情况下会发生什么。

最后一行:

int dnsize = ln;

没用,因为您已经将变量传递给函数

答案 1 :(得分:0)

如果你在使用断点时得到一个结果,但是当你让它运行时得到无穷大,我怀疑你是在不到1ms内下载它,所以你除以0.你可以尝试一个更大的文件看看你是否没有断点就能获得更好的结果。或者考虑像DateTime.Ticks那样精确的东西。

注意,string.length将是字节而不是位。