欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

记录一次老Android项目迁移过程

程序员文章站 2022-07-13 08:51:19
...

前言

项目最早是我三年前写的, 后来转去别的项目组做新项目, 交接给了新同事. 大半年后公司大面积裁员, 紧急交接给我了. 由于项目处于将死状态也就不管了. 后来试着跑了下, 好像没能跑起来. 就大概看了下代码.

印象较深的是, 原本项目, 数据库就一个表, 我用sql语句写的. 他需求多了个收藏, 然后就引用了greendao. 略感烦躁. 然后该升级的其它库没有做相应升级. 还停留在我第一次交接过去的状态. 所以说代码快3年没维护. 而且他那边迭代的版本还没做完, 也是头大.

开始迁移

原本工程直接修改(失败).

在迁移前, 我先将Android Stuio升级到了3.2. 然后将原有工程copy的一份, 然后用as打开project. 修改了几下, 实在无从下. 最重要项目结构无法很好识别. 在这之前也升级过4年的老项目, 稍微改了下也就跑起来了. 这个怎么改都不行. 当初我接手就已经不能跑成功, 另一个可能3.2比之前变化较大. copy打开了几次都不行. 这样不行的话, 只能多费力气新建工程导入代码了.

新建工程导入(成功)

首先建好空项目和主要的module. 那种只有几个.java文件的module. 打算最后并到主项目, 能省点事, 毕竟最主要的是先跑起来. 保持项目名称包名一致. 然后从依赖性最小的moudle开始, 将原module下的libs和src目录copy过去. 然后手动修改build.gradle. 除了support包, 其它的库先按原来的版本. 然后主项目加入该依赖, build, 修改问题, 通过. 再弄下一个module. 最后将主项目的代码copy过来. 再build. 挨个修改问题.

问题记录

  • Cannot resolve symbol 'CLIP_SAVE_FLAG'
    canvas里已经将这些flag标记移除了, 改用save()就可以了.

  • Program type already present: android.support.v4.app.FragmentTransitionCompat21
    这个是不同版本support包冲突
    在Terminal中输入指令 gradlew -q app:dependencies
    可以看到fresco:0.6.1依赖了android-support-v4:23.2.1, 升级到fresco:1.11.0解决.

  • nineoldandroids
    这个好早以前支持2.x加入的, 现在不需要了
    import改为android自带的.
    ViewHelper.setX(view, value)改为view.setX(value)
    ViewHelper.getX(view)改为view.getX()

  • ViewHolder views must not be attached when created. Ensure that you are not passing 'true' to the attachToRoot parameter of LayoutInflater.inflate(..., boolean attachToRoot)
    这个报错说的很明显, 直接去对应adapter.
    找到

 public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
            mLikesLayout.setId(R.id.layout_other_like);
            parent.addView(mLikesLayout, ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT);
            root = mLikesLayout;
        return new RecyclerView.ViewHolder(root) {
        };
}

改为

 public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
            mLikesLayout.setId(R.id.layout_other_like);
            mLikesLayout.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT));
            root = mLikesLayout;
        return new RecyclerView.ViewHolder(root) {
        };
}
  • 列表里一些item高度会铺满屏幕.
    这个是因为某个版本后, recyclerview改了行为, item根节点android:layout_height写match_parent会铺满屏幕, 好在xml按照命名规范, 列表item布局以lvi_开头, 直接挨个检查, 修改对应xml根节点改为android:layout_height="wrap_content".

结束

到此为止, 大概大半天时间, 项目已经能正常跑起来, 也顺手解决了几个bug. 像一些库, 还停留在旧版本上, 可能还存在一些bug. 升级版本改动较大.

  • 如我封装的http底层还是使用的apache HttpClient. 而现在基本okhttp一统天下.
  • EventBus 2.x/到3.x, 关键词变更
  • butterknife 7.x到9.x, 关键词变更
  • 一些国内的sdk.
    由于一开始该项目仓促, 总是追赶需求, 当时功力也不够. 虽然项目跑起来没事, 但现在的眼光来看, 项目很啰嗦重复. 想加东西感觉也是费劲, 所以还得后面再找点时间将这些重构.