// 将tasks保存到二进制文件中
public Boolean saveToFile(String file)
{
    try
    {
        )
        {
            // 没任务就不存
            return false;
        }

        if (File.Exists(file))
        {
            // 原有文件删掉
            File.Delete(file);
        }

        // 写文件
        FileStream writeStream = new FileStream(file, FileMode.Create);
        BinaryWriter bw = new BinaryWriter(writeStream);

        foreach (Dld tt in tasks)
        {
            bw.Write((String)tt.getID());// 以下强制类型转换并非必要,而是为了阅读时辨别类型
            bw.Write((String)tt.getFilename());
            bw.Write((String)tt.getUrl());
            bw.Write((long)tt.getRemoteFileSize());
            bw.Write((String)tt.getPercent());
            bw.Write((String)tt.getStatus());
            bw.Write((String)tt.getType());
            bw.Flush();
        }

        bw.Close();
        writeStream.Close();

        return true;
    }catch(Exception e){
        throw e;
    }
}

// 从二进制文件中提取tasks
public Boolean loadFromFile(String file)
{
    try
    {
        if (File.Exists(file)==false)
        {
            // 文件不存在直接返回
            return false;
        }

        // 读文件
        FileStream readStream = new FileStream(file, FileMode.Open);
        BinaryReader br = new BinaryReader(readStream);

        try
        {
            while(true)
            {                // 读取过程正好是写入过程的逆序
                String id = br.ReadString();
                String filename = br.ReadString();
                String url = br.ReadString();
                long remoteFileSize = br.ReadInt64();
                String percent = br.ReadString();
                String status = br.ReadString();
                String type = br.ReadString();

                // 这个地方要根据类型判断
                Dld tnew = null;

                if (type.Equals("http"))
                {
                    tnew = new HttpDld(mainGui, id, filename, url, remoteFileSize, type);
                }
                else if (type.Equals("ftp"))
                {
                    tnew = new FtpDld(mainGui, id, filename, url, remoteFileSize, type);
                }

                tnew.setStatus(status);
                tnew.setPercent(percent);

                tasks.Add(tnew);
            };
        }
        catch(EndOfStreamException ex){// 读完会抛出这个异常,正常过程
            System.Console.WriteLine("文件" + file + "读取完毕,读取任务" + tasks.Count+"条.");
        }

        br.Close();
        readStream.Close();

        return true;
    }
    catch (Exception e)
    {
        throw e;
    }
}

C# 将链表存入二进制文件及读取二进制文件得到链表示例的更多相关文章

  1. 信息管理代码分析<二>读取二进制文件数据

    first和end做为全局变量,分别指向链表的头和尾.建立链表的方式也比较简易,从二进制文件数据块中,依次从头到尾读取,每读取一个就建立一个结点. /*基本模型*/ EMP *emp1; while( ...

  2. 用 C# 读取二进制文件

    当想到所有文件都转换为 XML时,确实是一件好事.但是,这并非事实.仍旧还有大量的文件格式不是XML,甚至也不是ASCII.二进制文件仍然在网络中传播,储存在磁盘上,在应用程序之间传递.相比之下,在处 ...

  3. 获取博客积分排名,存入数据库,读取数据进行绘图(python,selenium,matplotlib)

    该脚本的目的:获取博客的排名和积分,将抓取时间,排名,积分存入数据库,然后把最近的积分和排名信息进行绘图,查看积分或者排名的变化情况. 整个脚本的流程:是利用python3来编写,利用selnium获 ...

  4. C语言实现数据机构链表的基本操作(从键盘输入生成链表、读取数组生成链表)

    利用头插法实现逆置 下面简单介绍一下,算法思想结合图示看 算法思想:"删除"头结点与链表其他结点的原有联系(即将头结点的指针置空),再逐个插入逆置链表的表头(即"头插&q ...

  5. c++单链表冒泡排序(交换结点),链表增删改查,运算符重载

    #include <iostream> #include <stdlib.h> #include <time.h> #include <fstream> ...

  6. java使用poi读取ppt文件和poi读取excel、word示例

    java使用poi读取ppt文件和poi读取excel.word示例 http://www.jb51.net/article/48092.htm

  7. 牛客网:将两个单调递增的链表合并为一个单调递增的链表-Python实现-两种方法讲解

    方法一和方法二的执行效率,可以大致的计算时间复杂度加以对比,方法一优于方法二   1. 方法一: 思路: 1. 新创建一个链表节点头,假设这里就叫 head3: 2. 因为另外两个链表都为单调递增,所 ...

  8. LeetCode初级算法--链表02:合并两个有序链表

    LeetCode初级算法--链表02:合并两个有序链表 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn. ...

  9. [LC]83题 Remove Duplicates from Sorted List(删除排序链表中的重复元素)(链表)

    ①英文题目 Given a sorted linked list, delete all duplicates such that each element appear only once. Exa ...

随机推荐

  1. 【12】Firefox 快捷键大全及更改和定制快捷键的方法

    [12]Firefox 快捷键大全及更改和定制快捷键的方法 答: Firefox 本身没有提供更改和定制快捷键的选项,若有需要,请安装扩展 Keyconfig 来解决.  安装地址如下: Keycon ...

  2. mantisbt邮件配置

    PHP.INI里面 [mail function]; For Win32 only.#SMTP = 192.168.0.249SMTP = smtp.163.comsmtp_port = 25 ; F ...

  3. python-高级编程-07-端口

    TCP和UDP协议中都有端口这个概念,但是端口却不是IP协议的一部分 端口的出现主要是为了给协议栈和应用对应 .协议栈端口号将数据分配给不同的应用程序 .应用层程序用端口号去区分不同的链接 TCP 和 ...

  4. rabbitmq exchange type

    This is the fourth installment to the series: RabbitMQ for Windows.  In thelast installment, we revi ...

  5. 九度oj 题目1391:顺时针打印矩阵

    题目描述: 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字1,2 ...

  6. NOJ——1656搬砖(DP)

    [1656] 搬砖 时间限制: 2000 ms 内存限制: 65535 K 问题描述 开学了,万恶的大二学长们又要领着大一的鲜肉们一起敲代码搬砖了,这不,著名的杨神拿着n块砖头,当然他把这n块砖头的重 ...

  7. pytorch下可采用visidom作为可视化工具

    2018/9/18更新  感觉tensorboardX插件更好用,已转用https://github.com/lanpa/tensorboardX 更新:新版visdom0.1.7安装方式为:cond ...

  8. BZOJ3098 Hash Killer II 【概率】

    挺有意思的一题 就是卡一个\(hash\) 我们先取L大概几十保证结果会超出\(10^9 + 7\) 然后就随机输出\(10^5\)个字符 由题目的提示我们可以想到,如果我们有\(n\)个数,选\(k ...

  9. 《常见问题集》Maven

    1.Maven Eclipse插件要不要安装? [解决方法] 打开你的Eclipse,如果已经有Maven了就不用装插件了. 方法一:没有的话或者下载最新的Eclipse(maven插件,eclips ...

  10. [APIO2009]抢掠计划 ($Tarjan$,最长路)

    题目链接 Solution 裸题诶... 直接 \(Tarjan\) 缩点+ \(SPFA\) 最长路即可. 不过在洛谷上莫名被卡... RE两个点... Code #include<bits/ ...