记录一次session安装应用recyclerview更新数据的bug

首先抛出异常日志,在

先说结论:因为session安装监听是在点击事件里面,所以会保留旧的对象数据

直接上代码,原有的逻辑是点击时执行session安装,并注册监听回调

Kotlin 复制代码
  private fun installApk(position: Int) {
        val packageInstaller = packageManager.packageInstaller
        val params =
            PackageInstaller.SessionParams(PackageInstaller.SessionParams.MODE_FULL_INSTALL)
        params.setSize(File(itemList[position].path).length())

        val sessionId = packageInstaller.createSession(params)
        val session = packageInstaller.openSession(sessionId)

        // 注册安装进度监听器
        val sessionCallback = object : PackageInstaller.SessionCallback() {
            override fun onCreated(sessionId: Int) {
                // 安装会话创建成功
                Log.i("InstallProgress", "Session created: $sessionId")
            }

            override fun onProgressChanged(sessionId: Int, progress: Float) {
                // 安装进度更新
                itemList[mPosition].installed = 1
                itemList[mPosition].progress = progress * 100
                adapter.notifyItemChanged(mPosition)
                Log.d(
                    "install",
                    "onProgressChanged: $mPosition ${itemList[mPosition].installed} $progress"
                )
            }

            override fun onFinished(sessionId: Int, success: Boolean) {
                if (success) {
                    // 安装成功
                    itemList[mPosition].installed = 2
                } else {
                    // 安装失败
                    itemList[mPosition].installed = 3
                }
                adapter.notifyItemChanged(mPosition)
                Log.d(
                    "install",
                    "onProgressChanged: $mPosition ${itemList[mPosition].installed} $success"
                )
            }

            override fun onActiveChanged(sessionId: Int, active: Boolean) {
                // 安装会话激活状态发生变化
            }

            override fun onBadgingChanged(sessionId: Int) {
                // 应用图标发生变化
            }
        }
        // 注册监听器
        packageManager.packageInstaller.registerSessionCallback(sessionCallback)

        try {
            val inputStream = FileInputStream(itemList[position].path)
            val outputStream = session.openWrite("base.apk", 0, -1) // -1 表示自动计算大小
            inputStream.copyTo(outputStream)
            session.fsync(outputStream)
            inputStream.close()
            outputStream.close()

            val intent = Intent(context, PackageInstallReceiver::class.java).apply {
                action = itemList[position].pkg
                putExtra(PackageInstaller.EXTRA_PACKAGE_NAME, itemList[position].pkg)
            }

            val pendingIntent = PendingIntent.getBroadcast(
                context,
                0,
                intent,
                PendingIntent.FLAG_UPDATE_CURRENT
            )
            session.commit(pendingIntent.intentSender)
        } catch (e: IOException) {
            session.abandon()
            e.printStackTrace()
        }
    }

修改后,将监听注册到onCreate中,并

Kotlin 复制代码
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        // 注册监听器
        packageManager.packageInstaller.registerSessionCallback(sessionCallback)
    }

    // 注册安装进度监听器
    private val sessionCallback = object : PackageInstaller.SessionCallback() {
        override fun onCreated(sessionId: Int) {
            // 安装会话创建成功
            Log.i("InstallProgress", "Session created: $sessionId")
        }

        override fun onProgressChanged(sessionId: Int, progress: Float) {
            // 安装进度更新
            itemList[mPosition].installed = 1
            itemList[mPosition].progress = progress * 100
            adapter.notifyItemChanged(mPosition)
            Log.d("installApk", "onProgressChanged: $mPosition ${itemList[mPosition].installed} $progress")
        }

        override fun onFinished(sessionId: Int, success: Boolean) {
            if (success) {
                // 安装成功
                itemList[mPosition].installed = 2
            } else {
                // 安装失败
                itemList[mPosition].installed = 3
            }
            adapter.notifyItemChanged(mPosition)
            Log.d("installApk", "onProgressChanged: $mPosition ${itemList[mPosition].installed} $success")
        }

        override fun onActiveChanged(sessionId: Int, active: Boolean) {
            // 安装会话激活状态发生变化
        }

        override fun onBadgingChanged(sessionId: Int) {
            // 应用图标发生变化
        }
    }



    private fun installApk(position: Int) {
        val packageInstaller = packageManager.packageInstaller
        val params =
            PackageInstaller.SessionParams(PackageInstaller.SessionParams.MODE_FULL_INSTALL)
        params.setSize(File(itemList[position].path).length())

        val sessionId = packageInstaller.createSession(params)
        val session = packageInstaller.openSession(sessionId)

        try {
            val inputStream = FileInputStream(itemList[position].path)
            val outputStream = session.openWrite("base.apk", 0, -1) // -1 表示自动计算大小
            inputStream.copyTo(outputStream)
            session.fsync(outputStream)
            inputStream.close()
            outputStream.close()

            val intent = Intent(context, PackageInstallReceiver::class.java).apply {
                action = itemList[position].pkg
                putExtra(PackageInstaller.EXTRA_PACKAGE_NAME, itemList[position].pkg)
            }

            val pendingIntent = PendingIntent.getBroadcast(
                context,
                0,
                intent,
                PendingIntent.FLAG_UPDATE_CURRENT
            )
            session.commit(pendingIntent.intentSender)
        } catch (e: IOException) {
            session.abandon()
            e.printStackTrace()
        }
    }
相关推荐
城下秋草11 小时前
趣谈Bug -500英里邮件问题
bug
初圣魔门首席弟子13 小时前
c++中this指针使用bug
前端·c++·bug
张较瘦_1 天前
[论文阅读] AI + 软件工程(Debug)| 告别 “猜 bug”:TreeMind 用 LLM+MCTS 破解 Android 不完整报告复现难题
论文阅读·人工智能·bug
数字芯片实验室1 天前
芯片验证:发现BUG是件好事
bug
南方者1 天前
【JAVA】【BUG】经常出现的典型 bug 及解决办法
java·oracle·bug
十铭忘2 天前
Bug——PaddleX人脸识别报错:Process finished with exit code -1073741819 (0xC0000005)
学习·bug
一勺-_-3 天前
疑问:hfish的一个bug,很奇怪
bug
闲人编程3 天前
告别Print: Python调试入门,用PDB高效找Bug
开发语言·python·bug·调试·pdb·断点设置
史上最菜开发4 天前
a-input输入框,苹果电脑(MAC)输入法的输入Bug
vue.js·macos·bug
wdfk_prog4 天前
[Linux]学习笔记系列 -- lib/sort.c 通用的排序库(Generic Sorting Library) 为内核提供标准的、高效的排序功能
linux·运维·c语言·笔记·stm32·学习·bug