1

环境: flutter-sdk(v1.5.4-hotfix.1@stable)

运行flutter脚本的时候有时会遇见Wrong full snapshot version, expected '…' found '…'的错误, 其实这时候是因为在${FLUTTER_ROOT}/bin/cache里缓存的快照过期或者无效了导致的.

网上有把${FLUTTER_ROOT}/bin/cache目录删除了的, 有用git clean -xfd命令解决的, 其实还是删除了${FLUTTER_ROOT}/bin/cache目录, 这样的做法不太好, fluter脚本会重新下载dartSDK等一系列工具,整个过程会持续很长时间.

${FLUTTER_ROOT}/bin/cache有8个标识用的时间戳
bin/cache/android-sdk.stamp
bin/cache/flutter_sdk.stamp
bin/cache/flutter_version_check.stamp
bin/cache/ios-sdk.stamp
bin/cache/engine-dart-sdk.stamp
bin/cache/flutter_tools.stamp
bin/cache/gradle_wrapper.stamp
bin/cache/material_fonts.stamp
其中android-sdk.stamp,flutter_sdk.stamp,os-sdk.stamp,engine-dart-sdk.stamp一般内容一致, 是${FLUTTER_ROOT}/bin/internal/engine.version中的字串, 相对来说sdk中的内容我们一般不会变更, 如果这几个stamp文件内空不一样改成一致即可.

最容易出问题的其实是flutter_tools.stamp, 我们有时在${FLUTTER_ROOT}/packages/flutter_tools/lib
中的文件添加了一些log, 结果运行时内容打印不出来, 这时只要删除flutter_tools.stamp即可, flutter脚本(${FLUTTER_ROOT}/bin/flutter)会自行生成stamp并重建snapshot(${FLUTTER_ROOT}/bin/cache/flutter_tools.snapshot), 而dart最终运行的是snapshot文件.

所以一般情况下删除flutter_tools.stamp即可解决问题

另外如果想让${FLUTTER_ROOT}/packages/flutter_tools/lib里更改的内容实时生效, 将${FLUTTER_ROOT}/bin/flutter中引用的$SNAPSHOT_PATH改成$SCRIPT_PATH就可以实时查看dart脚本怎样同步工程, 怎样诊断环境等等所有事情:
图片描述
这意味着一旦脚本运行出现难懂的错误,我们就可以很容易的定位问题了!


林鹿
21 声望5 粉丝