ANR 向可穿戴设备发送大文件

问题描述

考虑到使用 ChannelClient 类将文件从手机发送到可穿戴设备的最少文档,我已经开始使用它了。但是,我在发送较大的文件时收到 ANR 错误。我正在使用 Foreground Service 来处理我认为用于长时间运行任务的上传。奇怪的是 ANR 发生在用户选择要上传文件Activity 中。

服务

public class UploadFile extends Service {

    @Override
    public int onStartCommand(Intent intent,int flags,int startId) {
        createForegroundNotification();
        
        Uri fileUri = Uri.parse(intent.getExtras().getString("file"));
        String fileName = getFileName(fileUri);

        List<Node> nodes = Utilities.getNodesAsync();

        for (Node node : nodes) {
          ChannelClient channelClient = Wearable.getChannelClient(context);

                channelClient.openChannel(node.getId(),fileName).addOnSuccessListener(channel -> {

                Task<OutputStream> outputStreamTask = channelClient.getoutputStream(channel);

                outputStreamTask.addOnSuccessListener(outputStream -> {

                    try {
                        InputStream inputStream = context.getContentResolver().openInputStream(fileUri);
                        ByteArrayOutputStream byteBuffer = new ByteArrayOutputStream();

                        byte[] buffer = new byte[1024];

                        int len;
                        while ((len = inputStream.read(buffer)) > 0)
                            byteBuffer.write(buffer,len);

                        outputStream.write(byteBuffer.toByteArray());
                        outputStream.flush();
                        outputStream.close();
                        inputStream.close();
                    } catch (Exception e) {
                        e.printstacktrace();
                    } finally {
                        stopForeground(true);
                    }

                });
            });
        }   
    }
}

用户添加活动:

mFileUploadButton.setonClickListener(view -> mFileUpload.launch("*/*"));


final ActivityResultLauncher<String> mFileUpload = registerForActivityResult(new ActivityResultContracts.GetContent(),uri -> {

        final Intent serviceIntent = new Intent(this,UploadFile.class);
        final Bundle extrasService = new Bundle();
        extrasService.putString("file",uri.toString());
        serviceIntent.putExtras(extrasService);

        ContextCompat.startForegroundService(this,serviceIntent);

    });

错误

2021-07-26 09:26:56.391 1558-13178/? E/ActivityManager: ANR in com.my.app (com.my.app/.Activities.UserAddActivity)
PID: 13090
Reason: Input dispatching timed out (1c8d463 com.my.app/com.my.app.Activities.UserAddActivity (server) is not responding. Waited 5003ms for FocusEvent(hasFocus=false))
Parent: com.my.app/.Activities.UserAddActivity

ANR 只发生在大文件上。我正在测试的是 63MB。奇怪的是,文件确实传输到了​​可穿戴设备,但手机在完成之前就抛出了 ANR。

我什至尝试将代码放入 Service 中的异步任务中。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...