记录一次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()
        }
    }
相关推荐
ChoSeitaku19 小时前
Git分支|创建分支|切换分支|合并分支|删除分支|合并冲突分支|分支策略|bug分支|强制删除分支
bug
Lxinccode2 天前
BUG(23) : node版claude code启动报错Failed to connect to api.anthropic.com: ETIMEDOUT
bug·claude·claude启动报错
buyulian2 天前
Bug防御体系:技术方案的优与劣
java·经验分享·bug·软件工程
川石课堂软件测试3 天前
接口测试需要注意的一些BUG
网络·数据库·python·单元测试·bug·压力测试·tornado
深念Y3 天前
记一个BUG:Trae里MongoDB和MySQL MCP不能共存
数据库·mysql·mongodb·ai·bug·agent·mcp
测试_AI_一辰4 天前
AI系统测试实践:Tool执行与状态管理(Agent系统最容易出Bug的地方)
人工智能·ai·自动化·bug·ai编程
飞Link4 天前
告别盲目找Bug:深度解析 TSTD 异常检测中的预测模型(Python 实战版)
开发语言·python·算法·bug
小同志006 天前
软件测试周期 与 BUG
java·软件测试·bug·软件测试周期·bug等级
Reisentyan6 天前
edge的神秘搜索栏 暗广 bug
bug
为搬砖记录7 天前
杰理AC695N soundbox 3.1.2打开ble宏的编译bug
c语言·开发语言·单片机·bug