V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
ArchStacker
V2EX  ›  程序员

之前说的那个在 Windows 上读取各种类型文件系统的程序,求填坑

  •  
  •   ArchStacker ·
    Archstacker · 2015-09-19 11:05:47 +08:00 · 3063 次点击
    这是一个创建于 3359 天前的主题,其中的信息可能已经有所发展或是发生改变。

    之前的帖子见 https://www.v2ex.com/t/217087
    因为以前没接触过驱动编程,看样子如果我写的话有些人也信不过,正巧有个轮子,我就直接用轮子了。
    用的是dokany,功能类似于 FUSE 但是是在 Windows 上。就是装了它的驱动之后,如果我在用户态实现文件系统各个操作相关接口,然后再调用 dokany 就可以创建出一个相应的盘。
    文件系统部分还是基于 GRUB 源码做的,项目地址: https://github.com/Archstacker/GRUB 。目前的关键功能都已实现,可以对文件、目录进行打开、复制操作。关键代码见grub-mount-win.c。目前最新版下载及说明见此
    不过现在存在的最大的问题是程序还不太稳定,用 Windows 自带的资源管理器打开,尤其是某个操作还没完成就进行下一个操作的话,经常会出现程序崩溃、目录打开后没东西(刷新后就好了)、文件有可能打不开(多次打开的话有可能出现), 建议使用第三方资源管理器打开或是压缩软件来浏览,或者直接使用各种终端命令
    经过我几天的调试,发现问题在于 GRUB 是单线程的,而我写好接口之后 dokany 是以多线程调用的,尤其是 Windows 默认的资源管理器会同时开启超多线程,导致出现问题的情况大大增加。
    GRUB 其中一处多线程有可能产生冲突的地方我已经修好了。但是现在最棘手的就是 GRUB 中使用全局变量grub_errno 来记录上次错误的错误号。但是在多线程的情况下有可能出现错误号被另一个线程冲掉了的情况。现在的各种问题应该都是这个原因。
    这个问题应该来说比较好修,只需要保证在这个程序中调用的所有函数,错误号都通过返回值返回或是进行相关检测好了,感觉这就算是个体力活。不过由于我这两周把大量时间都花在这个上面,堆了好多事要做,接下来一段时间会比较忙,没有功夫做这件事情。不知道有没有人有兴趣把这个坑填上?感觉虽然需求量比较少,但还是有一定意义的。

    最后再强调一下,现在程序会出现一些问题,不过那都是在使用 Windows 自带资源管理器的情况下碰到的。我使用第三方工具查看的话还没遇到过问题,足够日常使用,希望大家能帮忙测试。

    第 1 条附言  ·  2015-09-19 20:02:23 +08:00
    刚刚把程序改成单线程的了,这下应该很难再见到各种不稳定的情况了,不过同时也使得程序运行比较慢。看来如果想做好的话还是得改相关代码。
    1 条回复    2017-01-19 10:46:39 +08:00
    zhudong2
        1
    zhudong2  
       2017-01-19 10:46:39 +08:00
    编译的时候出现 unicodedecodeerror:'utf8' code can't decode byte 0xb0 in position 37.是怎么回事啊。在 ubunut 下编译的, python 为 2.7
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2864 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 13:23 · PVG 21:23 · LAX 05:23 · JFK 08:23
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.