在常规 Java 中,您可以通过将 PrintWriter 传递给 printStackTrace 来获取堆栈跟踪的文本。我有一种感觉我知道这个问题的答案(即“不是,但,

有没有办法以字符串形式获取 JavaME 中的堆栈跟踪文本?

更新:

我应该提到我仅限于 CLDC 1.0

有帮助吗?

解决方案

AFAIK除非特定平台提供覆盖默认System.err流的方法,否则无法将堆栈跟踪作为字符串值。在BlackBerry平台上,它会抛出 catch(Exception)上的堆栈跟踪以节省内存,但是它不会在 catch(Throwable)上执行此操作并给出通过设备事件日志访问堆栈跟踪。

我最终做的是在最后一刻抓住Throwable而不是Exception并从那里打印堆栈跟踪。这当然有一个危险,你也抓住 java.lang.Error ,这不是很好,特别是如果它的 OutOfMemoryError ,虽然调用在打印堆栈跟踪之前的System.gc()似乎可以降低风险,我们没有遇到任何问题。

我会查看您所定位的平台,看看他们是否可以在某处访问System.err。你总是可以连接一个调试器,它应该出现在控制台输出上,虽然听起来就像你在字段中获得堆栈跟踪后的那样。

其他提示

两种解决方案:

  • 在模拟器上重现异常。无线工具包和 Netbeans 将在您的计算机上打印堆栈跟踪。

  • 使用 Symbian 设备。

在Series 60 第三版的Feature Pack 2 之前,Symbian 手机使用Sun Hotspot java 虚拟机。它通过将其链接到 C 标准库的部分实现来适应 Symbian 操作系统。

这使得 Symbian 能够创建一个名为“redirector”的 C++ 程序,该程序能够捕获 VM 标准输出和标准错误,包括 java 异常堆栈跟踪。

Symbian 操作系统版本 9 的 C++ 重定向器从未升级。相反,VM 中引入了“redirect://”GCF 协议,

从单独的 MIDlet,从 Connector.open("redirect://", Connector.READ) 返回的连接打开一个 InputStream;然后您可以捕获 Symbian 手机上的异常堆栈跟踪。

编辑 :“redirect://”回到 Series60 第 5 版,“redirect://test”应该适用于 Series60 第 3 版功能包 2

我不知道在CLDC 1.0中有办法做到这一点。但是,在某些设备/操作系统上,底层的Exception类可能提供了一种访问堆栈跟踪的方法(想想更新的CLDC版本)。只需在运行时使用反射检查异常实例,以查看它在目标平台上公开的成员。然后,您可以编写一些代码,以便能够在提供此类信息的平台上安全地提取堆栈跟踪。

我已经创建了一个工具,可用于在CLDC中记录正确的堆栈跟踪。请访问 http://jarrut.sourceforge.net 查看。它仍然是非常新的,它可能有一些粗糙的边缘,但它适用于我,我无法想象没有它开发MIDlet。最好的方法是将它与microlog结合使用。

不幸的是,该工具目前需要CLDC 1.1,因此它可能无法解决原始海报的问题。

您可以让PrintWriter写入ByteArrayOutputStream并从字节重构String。

try{
    throw new Exception("Message");     
} catch (Exception ex){
    ByteArrayOutputStream out = new ByteArrayOutputStream();
    ex.printStackTrace(new PrintStream(out));
    System.out.println(new String(out.toByteArray()));
}

它并不漂亮,但它应该在各处工作。在您尝试上述操作之前,请确保您无权访问[Throwable#getStackTrace]( http://java.sun.com/j2se/1.4.2/docs/api/java/lang/Throwable.html#getStackTrace()),Eclipse声称它可以在CDC / Foundation 1.1中使用,但这并没有说明其他配置文件。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top