全部博文(245)
分类: LINUX
2009-05-11 17:47:16
|
文件传送链表由专门的线程维护,这样,线程1就可以专心进行处理文件传输队列就可以了,线程1始终查询这个链表,如果表头为NULL,就说明没有要传输的文件,表头非空,就开始发送报文,获得正确的应答后,就可以开始文件的传输了,文件传输结束,将相应的链表节点删除。这里借鉴了很多程序中使用非常广泛的“命名池”相关的概念,只不过这里我们使用的是“文件池”,可以这么认为,如果有文件要传输,可以不用考虑是否有文件正在传输,只要把要传输的文件放入 “文件池”就可以了 , 同时,不用考虑“文件池”的大小,线程1是文件池的服务线程,它检测文件池的大小,如果非空,就会逐次传输文件。
这里需要特别注意的就是关于文件夹的传输,这个IPMSG飞鸽传书一个难点,应为对与文件夹的内容是没有显示的,需要我们逐次的判断,在飞鸽传书中是这么处理的,如果是一个文件夹,就发送文件属性为IPMSG_FILE_DIR的信息包,IPMSG飞鸽传书客户端收到这个信息包后,就创建这个文件夹,然后发起发送的IPMSG飞鸽传书客户端,进入文件夹,传送文件夹内的文件,如果该文件夹下,还有文件夹,使用相同的方法,在文件夹内的文件传送结束后,就发送IPMSG_FILE_RETPARENT信息包,接受的IPMSG_FILE_RETP报文的IPMSG飞鸽传书客户端,执行返回上一级目录,IPMSG飞鸽传书发送端,就需发送目录下的文件。这样循环操作,最终完成文件的传输,这个过程比较难以理解。
有了上边的知识,文件的接受也可以类推了,同样开启一个线程维护接受文件链表,逐次接受身下的文件,链表为空时,等待。
感悟: 有很多的程序都是“池”这个概念,其实就是队列,而之所以称之为“池”,是因为这个队列有一个服务函数,可以这么认为:池=队列+服务函数,在以后的编程中,如果遇到多任务做逐次的处理,可以使用这个方法,开启一个线程用于维护这个队列,开启另外的线程用于处理这个队列,这样,就不用在加入新的任务的时候考虑是否旧任务已经完成,这样的话,程序的框架思路就非常的清晰,而且会非常的高效,如果在一些特殊情况下,任务的执行需要耗费很长的时间,而又对任务的快速执行要比较严格的要求,可以开启多个线程来服务这个队列。
|