- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 usb-serial-for-android 库,我得到了一些奇怪的结果。连续2.5小时与串口通信,读写成功,出现如下异常:
exception in UsbManager.openDevice
android.os.TransactionTooLargeException
at android.os.BinderProxy.transact(Native Method)
at android.hardware.usb.IUsbManager$Stub$Proxy.openDevice(IUsbManager.java:339)
at android.hardware.usb.UsbManager.openDevice(UsbManager.java:255)
at com.hoho.android.usbserial.driver.UsbSerialProber$1.probe(UsbSerialProber.java:63)
at com.hoho.android.usbserial.driver.UsbSerialProber.probeSingleDevice(UsbSerialProber.java:174)
但是当我强制关闭我的应用程序然后重新启动它时,一切都很好,我的应用程序可以再次与端口通信。
在异常之前提到它可能有用,我得到了这个异常:
java.io.FileNotFoundException: /sdcard/log.txt: open failed: EMFILE (Too many open files)
at libcore.io.IoBridge.open(IoBridge.java:406)
at java.io.FileOutputStream.<init>(FileOutputStream.java:88)
at java.io.FileWriter.<init>(FileWriter.java:58)
at org.example.myapp.util.L.log(L.java:32)
我使用类 L
进行日志记录:
public class L {
public synchronized void log(String message){
File logFile = new File("sdcard/log.txt");
if (!logFile.exists())
{
try
{
logFile.createNewFile();
}
catch (IOException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
}
try
{
//BufferedWriter for performance, true to set append to file flag
BufferedWriter buf = new BufferedWriter(new FileWriter(logFile, true));
buf.append(new Date(DateProvider.getInstance().getCurrentDateAsMillisecs()).toString()+": "+message);
buf.newLine();
buf.close();
}
catch (IOException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
似乎某种缓冲区或缓存已满并阻止与设备通信。
如何摆脱异常?
更新:
写入日志文件永远不会失败,即使我收到异常也是如此。它只影响与 USB 设备的通信。
最佳答案
您打开的文件太多。我发现的问题:
- 你永远不会关闭 logFile
- 您在日志函数中打开文件,静态文件会更好并且可以在 log_init() 中初始化;功能。
或者,使 logFile 成为对象变量并在构造函数中对其进行初始化。
我认为解决这些将解决您的问题。
关于android - UsbHost 模式下的 TransactionTooLargeException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19877459/
Exception thrown launching activities in ProcessRecord{3c67ecf8080:com.example/u0a171} android.os.Tr
异常 05-12 15:42:45.791 11043-11043/ E/UncaughtException: java.lang.RuntimeException: android.os.Tran
val intent = Intent(Intent.ACTION_PICK) intent.type = "image/*" val mimeTypes = arrayOf("image/jpeg"
我正在开发一个 Android 项目,但当我需要从图库中拍照时,我遇到了困难。确实,当我拍摄第一张照片时,一切都很顺利。但是,如果我拍摄第二张照片,则会引发异常“TransactionTooLarge
我不知道在我的一个 Fragment Screens 上导致此异常的原因和位置。 我尝试用这个 TooLargeTool 调试它我有这样的输出: 2-19 18:20:24.317 25554 255
这个问题在这里已经有了答案: What to do on TransactionTooLargeException (43 个回答) 关闭 3 年前。 我正在尝试将 parse.com 与我的 an
这个问题在这里已经有了答案: android.os.TransactionTooLargeException on Nougat (13 个答案) 关闭 4 年前。 我开发了一款应用,该应用在 An
作为我的应用程序的一部分,我通过使用 ApplicationPackageManager.getInstalledApplications 获得了设备上安装的应用程序列表,但对于某些用户,我收到的崩溃
我正在使用正常 Intent 启动 Google map ,并启动覆盖按钮服务以返回我的应用程序。 Intent iconServiceIntent = new Intent(MainActivity
我遇到了 TransactionTooLargeException。不可重现。在文档中它说 The Binder transaction failed because it was too large
尝试共享图像文件时,我不断收到此错误: java.lang.RuntimeException:android.os.TransactionTooLargeException:数据包大小1085992字
我正在使用 usb-serial-for-android 库,我得到了一些奇怪的结果。连续2.5小时与串口通信,读写成功,出现如下异常: exception in UsbManager.openDev
我从我的一个实时应用程序中看到了很多错误报告,原因是这个异常: java.lang.RuntimeException: Adding window failed at android.view.
我的应用程序读取所有已安装 APK 文件的列表,然后循环遍历列表以读取 APK 信息,但它会抛出 TransactionTooLargeException 异常。 根据我在这里阅读的内容 http:/
我将 Nexus 5X 更新为 Android N,现在当我在其上安装应用程序(调试或发布)时,我在每个具有 Bundle in extras 的屏幕转换时都会收到 TransactionTooLar
我在Google Play商店中有一个Android游戏是使用Unity 2018.4.2f1和IL2CPP而不是Mono构建的。 使用的运行时版本.Net 3.5,我以ARMv7和ARM64为目标,
我有一个应用程序,用户可以在其中为他们的用户配置文件上传图像。在我的应用程序中,我允许用户使用 native 裁剪器裁剪图像。但是,当我尝试裁剪大图像时,我的 Logcat 中出现以下错误: !!!
我是第一次实现 ViewPager,我遇到了一些问题,因为我收到以下错误: 06-20 10:40:51.366 11377-11377/com.example.ruelas.elite E/Andr
我正在编写一个 Android 应用程序来跟踪用户的位置并在通知中显示行程的距离、时间和价格,所有这些都在 ForegroundService 中进行跟踪。该服务跟踪位置、价格和时间,我每秒更新一次通
我认为 Intent 的额外大小限制是 1MB,如 docs 上所报告的那样.无论如何,我在追逐这个可怕的 TransactionTooLargeException 时迷失了一天: E/JavaBi
我是一名优秀的程序员,十分优秀!