记录一次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()
        }
    }
相关推荐
一只自律的鸡3 小时前
【Linux驱动】bug处理 ens33找不到IP
linux·运维·bug
Lichenpar2 天前
Springboot采用FastJson2作为MessageConverter时,配置的全局日期类型序列化转换BUG
java·开发语言·bug
Irene19912 天前
AI 找 bug 的局限性 和 Deepseek 优势明显
bug
癫狂的兔子3 天前
【bug】【Python】pandas中的DataFrame.to_excel()和ExcelWriter的区别
python·bug
癫狂的兔子3 天前
【BUG】【Python】【Spider】Compound class names are not allowed.
开发语言·python·bug
netkiller-BG7NYT4 天前
阿里云语音合成CosyVoice重大BUG被我发现了
bug
马猴烧酒.4 天前
【Mybatis出现bug】应为 <statement> 或 DELIMITER,得到 ‘id‘
java·bug·mybatis
请叫我大虾4 天前
发现一个jdk中ArrayList的小BUG
android·java·bug
离离茶4 天前
【笔记1-10】Qt bug记录:dockwidget通过raise在最前面显示,toolbar的拓展菜单失效
笔记·qt·bug
测试_AI_一辰4 天前
Agent & RAG 测试工程笔记 01:Tool Calling 跑通 + 本地 PDF 接入(智谱 GLM)
人工智能·笔记·功能测试·自动化·bug