百科问答小站 logo
百科问答小站 font logo



JSON「最后不能加逗号」是不是错误设计? 第1页

  

user avatar   miloyip 网友的相关建议: 
      

JSON 现行标准 RFC7159 [1] 和 ECMA-404 [2] 明确地定义 JSON 的功能是数据互换格式(data interchange format)。作为互换格式,本身就应该尽量简单,避免一些可有可无的语法。我认为「最后可加逗号」算是可有可无的语法。

虽然如此,我觉得现在还是有一些可有可无的语法。例如字符串里的 (斜线符)可表示为 也可表示为转义形式 。另外,数字范围也是个比较大的问题,[1] 里说由实现决定,而又由于有些实现统一用双精度来表示数字,那么就不能处理很常见的 64 位整数。

身为 RapidJSON 的作者,希望这个库能提供最严格的 JSON 语法校验,但同时,不少使用者都想放宽限制,有不少相关讨论 [3],我简单翻译一些扩展语法需求:

  1. 根节点可以是任意类型。(JSON 原始标准 [4] 只容许 object 和 array 作为根节点,[1] 已放宽)
  2. 单行、多行注释
  3. 无引号的键(那么是否容许空格、冒号、转义符?)
  4. object、array 最后可加逗号
  5. 单引号字符串(JSON 标准只能用双引号)
  6. 小数点为首的数字(JSON 标准中,小数点前必须有最少一个数字)
  7. 小数点后没有数字(JSON 标准中,小数点后必须有最少一个数字)
  8. 十六进位数字(二进位、八进位呢)
  9. 无穷
  10. NaN

贫穷限制了我的想像力,甚至,曾经有使用者希望可以支持数字运算表达式⋯⋯

即使不考虑上述的扩展语法,许多开源的 JSON 解析器/生成器也不能完全符合标准。我在 [5] 测试开源库性能的同时,也测试了它们是否合符标准(有少部分测试高于标准要求,例如完美还原数字):

一些开源原生 JSON库的标准合符程度测试结果

因此,个人认为 JSON 标准还是尽量简单好一些,再复杂、再多可有可无的语法,只会令应用时出现更多问题。所以,我对题目是否定的,这不是错误设计,而是一个合理的设计。如果考虑把 JSON 扩展成适合用于人手编写的格式,或许可考虑 YAMLJSON5 等。


更新:看到有答案说输出 JSON 很麻烦。我只想回应:

不要手工编码输出 JSON!
不要手工编码输出 JSON!
不要手工编码输出 JSON!

你知道你用的语言/运行时所输出的数字必定合符 JSON 要求么?你有处理字符串里的字符转义么?

就算不使用 DOM,有些库(如 RapidJSON)还提供最简单的 SAX 风格 API:

       StringBuffer s; Writer<StringBuffer> writer(s);  writer.StartArray(); for (int i = 1; i <= 5; i++)     writer.Int(i); writer.EndArray();  std::cout << s.GetString(); // [1,2,3,4,5]      

让程序库处理逗号,不要每次都做轮子。


[1] The JavaScript Object Notation (JSON) Data Interchange Format

[2] Standard ECMA-404

[3] Strict/Relaxed JSON syntax · Issue #36 · Tencent/rapidjson

[4] The application/json Media Type for JavaScript Object Notation (JSON)

[5] miloyip/nativejson-benchmark


user avatar   Ivony 网友的相关建议: 
      

设不是设计错误,也不是parse的问题,完全就是为了规则简单,就像属性名必须加引号一样。

事实上很多解析器也是可以处理不规范格式的。




  

相关话题

  如何看待北大古生物「一个人的毕业照」主人公转行计算机?「冷转码」(冷门专业转码农)现象反映出哪些问题? 
  如何评价Jexus V5.8.0 发布被人砸场? 
  在业务需求完全一致,技术指标要求不一致时,是否应该为此提供使用不同优化算法的接口? 
  微软小冰测颜值是否比较准?为什么? 
  为什么很多人觉得计算机专业的会修电脑? 
  为什么苹果在各个方面都要另立门户? 
  计算机学院的学生该怎样提高自己的编程能力? 
  如果一定要在C++和JAVA中选择,是C++还是java? 
  如何向完全不懂编程的小伙伴解释「程序写死」? 
  AI 算法在芯片设计方法学和 EDA 工具中有哪些应用和潜力? 

前一个讨论
如何看待有赞“996”工作制遭劳动监察部调查,是否能改善互联网公司普遍超时加班的违法现象?
下一个讨论
如何看待 koa-router 作者公开售卖 npm 包?





© 2025-01-03 - tinynew.org. All Rights Reserved.
© 2025-01-03 - tinynew.org. 保留所有权利