MemoryFile 使用demo

该代码示例展示了如何在Android中使用MemoryFile进行跨进程数据传输。A进程首先将AccessibilityNodeInfoTree转换为JSON对象,写入MemoryFile,生成ParcelFileDescriptor并通过AIDL传递给B进程。B进程接收后读取数据并反序列化回JSONObject。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 //A进程写数据

public static ParcelFileDescriptor writeNodeInfo(String name, AccessibilityNodeInfoTree rootNode, int[] outSize) {
        try {
            //from AccessibilityNodeInfoTree to json
            JSONObject root = new JSONObject();
            changeToJson(rootNode, root);
            //format data
            ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
            ObjectOutputStream objectOutputStream = new ObjectOutputStream(byteArrayOutputStream);
            objectOutputStream.writeObject(root.toString());
            byte[] bytes = byteArrayOutputStream.toByteArray();
            byteArrayOutputStream.close();
            objectOutputStream.close();
            outSize[0] = bytes.length;
            Log.e(TAG, "writeNodeInfo, size=" + outSize[0] + ", data:" + root.toString());
            // write data
            MemoryFile memoryFile = new MemoryFile(name, bytes.length);
            memoryFile.getOutputStream().write(bytes);
            Method method = MemoryFile.class.getDeclaredMethod("getFileDescriptor");
            FileDescriptor des = (FileDescriptor) method.invoke(memoryFile);
            ParcelFileDescriptor pfd = ParcelFileDescriptor.dup(des);
            return pfd;
        } catch (Exception e) {
            Log.e(TAG, "writeNodeInfo fail: " + e);
        }
        return null;
}

//B进程读数据

public static JSONObject readNodeInfo(ParcelFileDescriptor pfd, int size) {
        try {
            //read data
            if (pfd == null) return null;
            byte[] data = new byte[size];
            FileDescriptor descriptor = pfd.getFileDescriptor();
            FileInputStream fileInputStream = new FileInputStream(descriptor);
            fileInputStream.read(data);
            //format data
            final ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(data);
            final ObjectInputStream objectInputStream = new ObjectInputStream(byteArrayInputStream);
            final Object object = objectInputStream.readObject();
            final JSONObject rootNode = new JSONObject((String)object);
            byteArrayInputStream.close();
            objectInputStream.close();
            Log.e(TAG, "readNodeInfo, size=" + size + ", data:" + rootNode.toString());
            return rootNode;
        } catch (Exception e) {
            Log.e(TAG, "readNodeInfo fail: " + e);
        }
        return null;
}

A进程通过MemoryFile将数据(必须是Serializable类型数据,Parcelable不能序列化到本地)写入共享内存,然后创建对应的FileDescriptor,再将FileDescriptor转成可序列划的ParcelFileDescriptor,将此描述符通过aidl传递给B进程。B进程拿到ParcelFileDescriptor,再获取FileDescriptor,读取数据。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值