XML vs. JSON

Characteristic XML JSON
Data types Does not provide any notion of data types. One must rely on XML Schema for adding type information Provides scalar data types and the ability to express structured data through arrays and objects
Support for arrays Arrays have to be expressed by conventions, for example through the use of an outer placeholder element that models the arrays contents as inner elements. Typically, the outer element uses the plural form of the name used for inner elements Native array support
Support for objects Objects have to be expressed by conventions, often through a mixed use of attributes and elements Native object support
Null support Requires use of xsi:nil on elements in an XML instance document plus an import of the corresponding namespace Natively recognizes the null value
Comments Native support and usually available through APIs Not supported, althrough many JSON implementations are capable to read and write C/C++ comments
Namespaces Supports namespaces, which eliminates the risk of name collisions when combining documents. Namespaces also allow existing XML-based standards to be safely extended No concept of namespaces. Naming collisions are usually avoided by nesting objects or using a prefix in an object member name (the former is preferred in practice).
Formatting decisions Complex. Requires a greater effort to decide how to map application types to XML elements and attributes. Can create heated debates whether an element-centric or attribute-centric approach is better Simple. Provides a much more direct mapping for application data. The only exception may be the absence of date/time literal
Size Documents tend to be lengthy in size, especially when an element-centric approach to formatting is used. Syntax is very terse and yields formatted text where most of the space is consumed (rightly so) by the represented data.
Learning curve Generally tends to require use of several technologies in concert: XPath, XML Schema, XSLT, XML Namespaces, the DOM, and so on. Very simple technology stack that is already familiar to developers with a background in the C-like family of programming languages