2014-03-04 17 views
1

我有一个名为RDV的情况下类:如何保存的情况下类的列表中阶

case class Rdv(
    id: Option[Int], 
    nom: String, 
    prénom: String, 
    sexe: Int, 
    telPortable: String, 
    telBureau: String, 
    telPrivé: String, 
    siteRDV: String, 
    typeRDV: String, 
    libelléRDV: String, 
    numRDV: String, 
    étape: String, 
    dateRDV: Long, 
    heureRDVString: String, 
    statut: String, 
    orderId: String) 

,我想保存在磁盘上的这些元素的列表,并重新加载它们。 我试图用Java类(ObjectOutputStream的,FileOutputStream中,ObjectInputStream的,的FileInputStream),但我在检索步骤的错误:语句

val n2 = ois.readObject().asInstanceOf[List[Rdv]] 

总是得到一个错误(ClassNotFound的:RDV),但正确的路径给出在进口地方。

您知道解决方法来保存这样的对象吗? 请提供一小段代码!

感谢

奥利弗

PS:我有相同的错误,同时使用马歇尔类,如在此代码:在带箭头的线

object Application extends Controller { 

def index = Action { 

//implicit val Rdv2Writes = Json.writes[rdv2] 

def rdvTordv2(rdv: Rdv): rdv2 = new rdv2(
    rdv.nom, 
    rdv.prénom, 
    rdv.dateRDV, 
    rdv.heureRDVString, 
    rdv.telPortable, 
    rdv.telBureau, 
    rdv.telPrivé, 
    rdv.siteRDV, 
    rdv.typeRDV, 
    rdv.libelléRDV, 
    rdv.orderId, 
    rdv.statut) 




val n = variables.manager.liste_locale 
val out = new FileOutputStream("out") 
out.write(Marshal.dump(n)) 
out.close 

val in = new FileInputStream("out") 
val bytes = Stream.continually(in.read).takeWhile(-1 !=).map(_.toByte).toArray 
val bar: List[Rdv] = Marshal.load[List[Rdv]](bytes)  <-------------- 

val n3 = bar.map(rdv => 
    rdvTordv2(rdv)) 
println("n3:" + n3.size) 




Ok(views.html.Application.olivier2(n3)) 

} 

}, 

。 似乎转换为List [Rdv]类型遇到问题,但为什么?这是一个戏剧!链接问题?


OK,有一个与播放一个问题: 我创建了一个新的Scala的项目,此代码:

object Test1 extends App { 

//pour des fins de test 
case class Person(name:String,age:Int) 
val liste_locale=List(new Person("paul",18)) 

val n = liste_locale 
val out = new FileOutputStream("out") 
out.write(Marshal.dump(n)) 
out.close 

val in = new FileInputStream("out") 
val bytes = Stream.continually(in.read).takeWhile(-1 !=).map(_.toByte).toArray 
val bar: List[Person] = Marshal.load[List[Person]](bytes) 
println(s"bar:size=${bar.size}") 
} 

和显示效果还是不错( “栏:大小= 1”)。

然后,我修改了上面的代码在剧中的项目,在控制类,比如这个:

object Application extends Controller { 

def index = Action { 

//pour des fins de test 
case class Person(name:String,age:Int) 
val liste_locale=List(new Person("paul",18)) 

val n = liste_locale 
val out = new FileOutputStream("out") 
out.write(Marshal.dump(n)) 
out.close 

val in = new FileInputStream("out") 
val bytes = Stream.continually(in.read).takeWhile(-1 !=).map(_.toByte).toArray 
val bar: List[Person] = Marshal.load[List[Person]](bytes) 
println(s"bar:size=${bar.size}") 


Ok(views.html.Application.olivier2(Nil)) 

} 

} 

,我有一个错误说:

play.api.Application$$anon$1: Execution exception[[ClassNotFoundException: controllers.Application$$anonfun$index$1$Person$3]] 

有任何人有答案?

编辑:我认为错误可能来自SBT,所以我修改build.scala像这样:

import sbt._ 
import Keys._ 
import play.Project._ 

object ApplicationBuild extends Build { 

val appName = "sms_play_2" 
val appVersion = "1.0-SNAPSHOT" 

val appDependencies = Seq(
// Add your project dependencies here, 
jdbc, 
anorm, 
"com.typesafe.slick" % "slick_2.10" % "2.0.0", 
"com.github.nscala-time" %% "nscala-time" % "0.6.0", 
"org.xerial" % "sqlite-jdbc" % "3.7.2", 
"org.quartz-scheduler" % "quartz" % "2.2.1", 
"com.esotericsoftware.kryo" % "kryo" % "2.22", 
"io.argonaut" %% "argonaut" % "6.0.2") 

val mySettings = Seq(
(javaOptions in run) ++= Seq("-Dconfig.file=conf/dev.conf")) 

val playCommonSettings = Seq(

Keys.fork := true) 

val main = play.Project(appName, appVersion, appDependencies).settings(

    Keys.fork in run := true, 
resolvers += Resolver.sonatypeRepo("snapshots")).settings(mySettings: _*) 
.settings(playCommonSettings: _*) 

} 

但没有成功,错误仍然存​​在(类人未找到)

你能帮助我吗?

+0

你可以序列化成一些可解析的非二进制格式,比如JSON,这通常是更好的选择(并不总是)。 –

+0

我不相信“给出正确的道路”。路径必须包含您正在反序列化的类。 –

+0

@ som-snytt:我已经在Marshall的版本中导入了metier.Objets.Rdv !!! help! – lolveley

回答

0

Scala Pickling有合理的势头,这种方法有很多优点(很多繁重的工作都是在编译时完成的)。有一个可插入的序列化机制,支持json等格式。

相关问题