如果你不记得所有键的名称(即使只能打印键名也很酷),是否有一种简单的方法可以将Bundle
的内容打印到Logcat?
答案 0 :(得分:103)
Bundle#keySet()应该有用。
for (String key: bundle.keySet())
{
Log.d ("myApplication", key + " is a key in the bundle");
}
如果您想获取对象,可以使用Bundle#get(String key)
(which is also in the same documentation I linked at the top of my answer)。但是,请记住使用通用get()
调用:
toString()
,一切都会好的。但是,如果您确实想要使用密钥对,则需要进行instanceof
检查以避免调用错误的方法。答案 1 :(得分:33)
您可以通过按如下方式打印映射值来获得更具体的信息:
for (String key : bundle.keySet())
{
Log.d("Bundle Debug", key + " = \"" + bundle.get(key) + "\"");
}
答案 2 :(得分:20)
捆绑到字符串转换器:
public static String bundle2string(Bundle bundle) {
if (bundle == null) {
return null;
}
String string = "Bundle{";
for (String key : bundle.keySet()) {
string += " " + key + " => " + bundle.get(key) + ";";
}
string += " }Bundle";
return string;
}
使用示例:
Log.d(TAG,"details="+bundle2string(details));
并输出:
details=Bundle{ RESPONSE_CODE => 5; }Bundle
请注意,箭头=>
和分号;
可让您在键和值中提及空格。箭头前一个空格,箭头后面一个空格,分号前没有空格,分号后面有一个空格,{
后面有一个空格,}
前面有一个空格,所有其他空格是因为他们在关键或价值观中。
答案 3 :(得分:5)
意识到这并不能完全回答问题,但是我看到开发人员试图将内容转储到logcat /控制台,因为他们不知道他们可以在Android Studio调试器中设置以在调试时显示自定义对象渲染时间,当您达到断点时。对于Bundle,您可以采用此处其他答案中所示的代码类型,并将其用作自定义渲染器,这样就无需将转储通过管道传输到logcat和/或控制台。>
(这些说明来自Android Studio 3.1.3(2018年6月)...
StringBuilder builder = new StringBuilder(); for (String key : ((android.os.Bundle)this).keySet()) { Object value = ((android.os.Bundle)this).get(key); builder.append("["); builder.append(key); builder.append("]=["); builder.append(value); builder.append("]("); builder.append((value != null) ? value.getClass().getSimpleName() : "null"); builder.append("), "); } return builder.toString();
现在,当您运行应用程序时,遇到一个断点,该断点显示了一个类型为android.os.Bundle的变量,您将在调试器窗口的variables部分中看到以上代码生成的输出
答案 4 :(得分:3)
在Kotlin中,当它包含子包时递归:
/**
* Recursively logs the contents of a [Bundle] for debugging.
*/
fun Bundle.printDebugLog(parentKey: String = "") {
if (keySet().isEmpty()) {
Log.d("printDebugLog", "$parentKey is empty")
} else {
for (key in keySet()) {
val value = this[key]
when (value) {
is Bundle -> value.printDebugLog(key)
is Array<*> -> Log.d("printDebugLog", "$parentKey.$key : ${value.joinToString()}")
else -> Log.d("printDebugLog", "$parentKey.$key : $value")
}
}
}
}
用法:myBundle.printDebugLog()
答案 5 :(得分:0)
我开发了一个名为pretty-print
的库,它的注释处理器以漂亮的表格格式打印包的内容。
看看吧
https://github.com/NULLPointerGuy/pretty-print
答案 6 :(得分:0)
Kotlin解决方案:
val bundleFromNotifications: Bundle? = remoteMessage?.toIntent()?.extras
bundleFromNotifications?.keySet()?.forEach{
Log.d(LOG_TAG, it + "=> \"" + bundleFromNotifications.get(it) + "\"")
}
答案 7 :(得分:0)
科特林解决方案:
fun Bundle.toPrintableString(): String {
val sb = StringBuilder("{")
var isFirst = true
for (key in keySet()) {
if (!isFirst)
sb.append(',')
else
isFirst = false
when (val value = get(key)) {
is Bundle -> sb.append(key).append(':').append(value.toPrintableString())
else -> sb.append(key).append(':').append(value)
//TODO handle special cases if you wish
}
}
sb.append('}')
return sb.toString()
}
示例:
val bundle = Bundle()
bundle.putString("asd", "qwe")
bundle.putInt("zxc", 123)
Log.d("AppLog", "bundle:${bundle.toPrintableString()}")
请注意,它不能处理所有可能的值类型。您应该决定要显示哪些重要内容以及以哪种方式显示。
答案 8 :(得分:0)
在Kotlin中简单的Bundle to String实现:
val bundleToString = bundle.keySet()
.joinToString(", ", "{", "}") { key ->
"$key=${bundle[key]}"
}
结果示例{id=3, name="Jhon"}
答案 9 :(得分:0)
Java 8流一线:
bundle.keySet().stream().forEach(k -> Log.d(TAG, k + " = " + bundle.get(k)));