敢肯定你的JSON代码的格式存在问题,已经使用JSON在这里超过20,000值是2000阵列的一个简单的脚本
$string = "Sample String Data ¶";
$string = preg_replace('/[^[:print:]]/', '',$string); // remove all values that can affect JSON
$array = array();
for($i = 0 ; $i < 2000; $i++)
{
if(mt_rand(0, 1))
{
$array[] = $string ;
}
else
{
$array[] = array($string,1,$string) ;
}
}
$json = json_encode($array);
$decodeArray = json_decode($json);
switch (json_last_error()) {
case JSON_ERROR_NONE:
echo ' - No errors';
break;
case JSON_ERROR_DEPTH:
echo ' - Maximum stack depth exceeded';
break;
case JSON_ERROR_STATE_MISMATCH:
echo ' - Underflow or the modes mismatch';
break;
case JSON_ERROR_CTRL_CHAR:
echo ' - Unexpected control character found';
break;
case JSON_ERROR_SYNTAX:
echo ' - Syntax error, malformed JSON';
break;
case JSON_ERROR_UTF8:
echo ' - Malformed UTF-8 characters, possibly incorrectly encoded';
break;
default:
echo ' - Unknown error';
break;
}
echo "<br />" ;
foreach ($decodeArray as $key => $value) {
print_r($value) ;
flush();
}
编辑2
我很感兴趣知道是否有任何限制..只测试它与250,000(二十五万的价值观,它工作正常)
谢谢 Oleku
是什么'的var_dump($解码)'给你? – 2012-03-28 13:24:02
我不认为它的限制。它没有限制。尝试'var_dump($ decode)'来查看类型 – safarov 2012-03-28 13:24:45
它可能不是因为元素的数量,而是因为无法解码的特定元素。在PHP 5.3中有json_last_error()函数。还要注意深度限制(默认512) – 2012-03-28 13:24:58