您的陈述是正确的。
从技术上讲,根据规范,这是 无效的 JSON,但是所有浏览器和某些JSON框架(包括Json.NET)都支持它。
因此,
JConstructor在解析严格符合当前IETF提议的标准或原始JSON提议的
JSON时不会出现。
JRaw使用解析JSON时将
永远不会
出现
JToken.Parse(string)。它主要用于促进从
JToken层次结构编写预格式化的JSON文字。通过使用
JRaw,可以避免只是为了发出它而对已经格式化的JSON进行解析,例如:
var root = new JObject(new JProperty("response", new JRaw(jsonLiteral))); var rootJson = root.ToString();
可以代替效率较低的方法来完成:
var root = new JObject(new JProperty("response", JToken.Parse(jsonLiteral)));
还可以反序列化以
JRaw将JSON层次结构捕获为单个字符串文字,尽管我认为这样做没有太大用处。例如,给定类:
public class RootObject{ public JRaw response { get; set; }}
一个可以做:
var rootDeserialized = JsonConvert.DeserializeObject<RootObject>(rootJson); var jsonLiteralDeserialized = (string)rootDeserialized.response;
但是,这不一定比反序列化为更有效
JToken。
- 正如你猜想,只是
JArray
,JObject
,JProperty
并且JValue
将解析严格有效的JSON时出现。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)