
我从lift-Json自述文件中得到了一个简单的例子,但每当我尝试从JsON-String中提取值时,我在调用Activity时会得到一个net.liftweb.Json.MapPingException.似乎没有传递给“提取”的args.
这是我的活动:
import _root_.androID.app.Activityimport _root_.androID.os.Bundleimport net.liftweb.Json._class JsonTest extends Activity { overrIDe def onCreate(savedInstanceState: Bundle) { super.onCreate(savedInstanceState) setContentVIEw(R.layout.mainactivity) implicit val formats = DefaultFormats case class NumList(numbers: List[Int]) val Json = parse(""" { "numbers" : [1,2,3,4] } """) Json.extract[NumList] }} 这是我得到的例外:
06-29 12:09:31.548: ERROR/AndroIDRuntime(405): FATAL EXCEPTION: main java.lang.RuntimeException: Unable to start activity ComponentInfo{de.fhs.spirit/de.fhs.spirit.JsonTest}: net.liftweb.Json.MapPingException: Parsed JsON values do not match with class constructor args= arg types= constructor=public de.fhs.spirit.JsonTest$NumList(de.fhs.spirit.JsonTest,scala.collection.immutable.List) at androID.app.ActivityThread.performlaunchActivity(ActivityThread.java:2663) at androID.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679) at androID.app.ActivityThread.access00(ActivityThread.java:125) at androID.app.ActivityThread$H.handleMessage(ActivityThread.java:2033) at androID.os.Handler.dispatchMessage(Handler.java:99) at androID.os.Looper.loop(Looper.java:123) at androID.app.ActivityThread.main(ActivityThread.java:4627) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:521) at com.androID.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868) at com.androID.internal.os.ZygoteInit.main(ZygoteInit.java:626) at dalvik.system.NativeStart.main(Native Method) Caused by: net.liftweb.Json.MapPingException: Parsed JsON values do not match with class constructor args= arg types= constructor=public de.fhs.spirit.JsonTest$NumList(de.fhs.spirit.JsonTest,scala.collection.immutable.List) at net.liftweb.Json.Meta$.fail(Meta.scala:185) at net.liftweb.Json.Extraction$.instantiate(Extraction.scala:257) at net.liftweb.Json.Extraction$.newInstance(Extraction.scala:280) at net.liftweb.Json.Extraction$.build(Extraction.scala:298) at net.liftweb.Json.Extraction$.extract0(Extraction.scala:345) at net.liftweb.Json.Extraction$.net$liftweb$Json$Extraction$$extract0(Extraction.scala:194) at net.liftweb.Json.Extraction$.extract(Extraction.scala:42) at net.liftweb.Json.JsonAST$JValue.extract(JsonAST.scala:290) at de.fhs.spirit.JsonTest.onCreate(JsonTest.scala:16) at androID.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) at androID.app.ActivityThread.performlaunchActivity(ActivityThread.java:2627) ... 11 more 如果你有一个想法如何解决我的问题会很棒.
谢谢!
问候,
Illaz
另见this question – 我的怀疑来自于它在REPL上不起作用的说法.并非REPL没有反射,但其包结构可能会使lift库混乱.
总结以上是内存溢出为你收集整理的问题:在Android(Scala)应用程序中使用lift-json“提取”JSON全部内容,希望文章能够帮你解决问题:在Android(Scala)应用程序中使用lift-json“提取”JSON所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)