PHP字符串充当一个数组


PHP String act as an array?

PHP字符串充当如下数组,

$string='test string'; 
echo $string[0];  // print t

但当我使用带有字符串变量的count函数时,它只打印1

echo count($string); // print 1

有人能解释为什么吗?

$string[offset]只是语法糖,可以让您轻松访问字符串的特定字节。尽管语法与访问数组索引的语法相同,但这并不意味着字符串以任何方式充当数组。count是一个作用于数组而非字符串的函数。

当您以数组的形式访问字符串组件时,运行时会检测您正在做什么,并在给定位置拾取字符。这与其他语言的做法一致,是一种常见的快捷方式。

当您调用"count"时,PHP实际做的是将其强制转换为数组(除非它实现了countable

var_dump( (array)$string);

有关计数,请参阅文档:http://us1.php.net/count

如果您正在寻找替代方案,strlen将以字节为单位提供长度,mb_strlen将以字符数为单位(在多字节字符集的情况下不相同)

原因是..好吧,让我把你链接到count函数的实际实现:https://github.com/php/php-src/blob/master/ext/standard/array.c(请注意,它包含在逻辑位置:array.c中,因为它实际上是用于数组/可计数的,而不是字符串)。

PHP_FUNCTION(count)
{   
        zval *array;
        long mode = COUNT_NORMAL;
        if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z|l", &array, &mode) == FAILURE) {
                return;
        }   
        switch (Z_TYPE_P(array)) {
                case IS_NULL:
                        RETURN_LONG(0);
                        break;
                case IS_ARRAY:
                        RETURN_LONG (php_count_recursive (array, mode TSRMLS_CC));
                        break;
                case IS_OBJECT: {
#ifdef HAVE_SPL
                        zval *retval;
#endif
                        /* first, we check if the handler is defined */
                        if (Z_OBJ_HT_P(array)->count_elements) {
                                RETVAL_LONG(1);
                                if (SUCCESS == Z_OBJ_HT(*array)->count_elements(array, &Z_LVAL_P(return_value) TSRMLS_CC)) {
                                        return;
                                }   
                        }   
#ifdef HAVE_SPL
                        /* if not and the object implements Countable we call its count() method */
                        if (Z_OBJ_HT_P(array)->get_class_entry && instanceof_function(Z_OBJCE_P(array), spl_ce_Countable TSRMLS_CC)) {
                                zend_call_method_with_0_params(&array, NULL, NULL, "count", &retval);
                                if (retval) {
                                        convert_to_long_ex(&retval);
                                        RETVAL_LONG(Z_LVAL_P(retval));
                                        zval_ptr_dtor(&retval);
                                }   
                                return;
                        }   
#endif
                }   
                default:
                        RETURN_LONG(1);
                        break;
        }   
}   

如你所见。。count函数实际上只针对数组、spl可计数项和NULL(返回0)实现。其他任何操作都将返回int值:1。