Can JSON numbers be quoted?
That will depend of the language that you use to get the integer, because if the programming language does not provide implicit conversion from string to int, you can have problems.
You should not to worry too much, since modern programming language nowadays can implicitly convert a string to a number without additional code. Something you should take into consideration is, when using programming languages like JavaScript, when you use ==
and ===
when comparing values, ===
takes into consideration the value's type while ==
not, so 6 === "6"
will return false
, while 6 == "6"
will return true
.
Answering your question, it will not throw an exception if you are using a programming language that provides implicit conversion from string to int.
In JSON, 6
is the number six. "6"
is a string containing the digit 6
. So the answer to the question "Can json numbers be quoted?" is basically "no," because if you put them in quotes, they're not numbers anymore.
But, should the parsers accept both
"attr" : 6
and"attr" : "6"
?
Yes, but they define different things. The first defines an attr
property with the value 6
(a number). The second defines an attr
property with the value "6"
(a string containing a single digit).
(The question originally asked about attr: "6"
, which is invalid because property names must be in double quotes in JSON.)
If MyParser has a method getInt to get a number given the key, should MyParser.getInt("attr") return 6 in both the cases or throw an exception in the latter case?
That's a design decision for the person providing the parser, basically the choice between getInt
being strict (throwing an exception if you try it on "attr": "6"
) or loose (coercing "6"
to 6
and returning that). JavaScript is usually loose, and so there could be an argument for being loose; conversely, the fact that JavaScript is loose sometimes causes trouble, which could be an argument for being strict.