yaml vs json
2016-06-05 11:49
906 查看
yaml vs json
我们知道yaml是json的超集,关于yaml和json的介绍我们可以看wiki yaml 和wiki jsonyaml scala
yaml scala语言没太好用的wrapper,最终使用的java提供的snakeyaml定义
由于将yml格式的文件转scala对象的时候需要符合JavaBean的规范,所以scala的对象定义的比较丑陋,最后就是这样了:package com.ximalaya.sparkcommon.model import scala.beans.BeanProperty /** * Created by todd.chen on 6/4/16. * email : todd.chen@ximalaya.com */ class EmailConfigYaml { @BeanProperty var host: String = _ @BeanProperty var username: String = _ @BeanProperty var password: String = _ @BeanProperty var auth: Boolean = _ @BeanProperty var fromEmail: String = _ override def toString = s"EmailConfig($host,$username,$password,$auth,$fromEmail)" }
读取和写入:
def getEmailConfigYaml = { val source = """ |--- !!com.ximalaya.sparkcommon.model.EmailConfigYaml |host : smtp.sina.cn |username : cjuexuan |password : password |auth : true |fromEmail: cjuexuan@sina.cn | """.stripMargin val yml = new Yaml() val email = yml.load(source).asInstanceOf[EmailConfigYaml] println(s"yaml2email:$email") val emailString = yml.dump(email) println(s"email2yaml:$emailString") }
json scala
现在我json最喜欢用的库在scala中是play-jso定义和读写也相当简单,简单过一下
定义
package com.ximalaya.sparkcommon.model import play.api.libs.json.Json /** * Created by todd.chen on 6/4/16. * email : todd.chen@ximalaya.com */ case class EmailConfigJson( host:String, username:String, password:String, auth:String, fromEmail:String ) object EmailConfigJson{ val format = Json.format[EmailConfigJson] }
读写
def getEmailConfigJson = { val source = """ |{ | "host" : "smtp.sina.cn", | "username" : "cjuexuan", | "password" : "password", | "auth" : "true", | "fromEmail" : "cjuexuan@sina.com" |} """.stripMargin val json = Json.parse(source) implicit val format = EmailConfigJson.format val email = json.as[EmailConfigJson] println(s"json2email:$email") val emailString = Json.toJson(email) println(s"email2json:$emailString") }
读写测试测试用例
def test(func: ⇒ Unit) = { val start = Instant.now() func val end = Instant.now() val duration = Duration.between(start, end) println(s"duration time :${duration.toNanos}}") } def main(args: Array[String]): Unit = { test(getEmailConfigYaml) test(getEmailConfigJson) }
结果和结论
json2email:EmailConfigJson(smtp.sina.cn,cjuexuan,password,true,cjuexuan@sina.com) email2json:{"host":"smtp.sina.cn","username":"cjuexuan","password":"password","auth":"true","fromEmail":"cjuexuan@sina.com"} duration time :1586000000} yaml2email:EmailConfig(smtp.sina.cn,cjuexuan,password,true,cjuexuan@sina.cn) email2yaml:!!com.ximalaya.sparkcommon.model.EmailConfigYaml {auth: true, fromEmail: cjuexuan@sina.cn, host: smtp.sina.cn, password: password, username: cjuexuan} duration time :253000000} Process finished with exit code 0
交换顺序进行测试
yaml2email:EmailConfig(smtp.sina.cn,cjuexuan,password,true,cjuexuan@sina.cn) email2yaml:!!com.ximalaya.sparkcommon.model.EmailConfigYaml {auth: true, fromEmail: cjuexuan@sina.cn, host: smtp.sina.cn, password: password, username: cjuexuan} duration time :676000000} json2email:EmailConfigJson(smtp.sina.cn,cjuexuan,password,true,cjuexuan@sina.com) email2json:{"host":"smtp.sina.cn","username":"cjuexuan","password":"password","auth":"true","fromEmail":"cjuexuan@sina.com"} duration time :994000000} Process finished with exit code 0
发现无论哪种方式下yaml的解析还是要快于json的,但使用bean对象的时候yaml的定义复杂于json,所以没啥明显性能问题的时候我还是倾向json
相关文章推荐
- java对世界各个时区(TimeZone)的通用转换处理方法(转载)
- java-注解annotation
- java-模拟tomcat服务器
- java-用HttpURLConnection发送Http请求.
- java-WEB中的监听器Lisener
- Android IPC进程间通讯机制
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- Python动态类型的学习---引用的理解
- 介绍一款信息管理系统的开源框架---jeecg
- 聚类算法之kmeans算法java版本
- java实现 PageRank算法
- PropertyChangeListener简单理解
- c++11 + SDL2 + ffmpeg +OpenAL + java = Android播放器
- 插入排序
- 冒泡排序
- 堆排序
- 快速排序