str_pad
是 PHP 中的一个字符串处理函数,用于将字符串填充到指定长度
/* {{{ proto string str_pad(string input, int pad_length[, string pad_string[, int pad_type]]) Pad a string to a certain length with another string */ PHP_FUNCTION(str_pad) { zend_string *input; // 输入字符串 zend_long pad_length; // 需要填充到的长度 zend_string *pad_string = NULL; // 填充字符串,默认为空格 zend_long pad_type_val = STR_PAD_RIGHT; // 填充类型,默认为右侧填充 zend_long left_pad = 0, right_pad = 0; // 左侧和右侧需要填充的长度 zend_string *result = NULL; // 结果字符串 // 解析参数 ZEND_PARSE_PARAMETERS_START(2, 4) Z_PARAM_STR(input) Z_PARAM_LONG(pad_length) Z_PARAM_OPTIONAL Z_PARAM_STR(pad_string) Z_PARAM_LONG(pad_type_val) ZEND_PARSE_PARAMETERS_END(); // 检查填充字符串是否为空,如果为空则使用空格作为填充字符串 if (!pad_string) { pad_string = ZSTR_EMPTY_ALLOC(); } // 检查填充类型是否合法 if (pad_type_val < STR_PAD_LEFT || pad_type_val > STR_PAD_BOTH) { php_error_docref(NULL, E_WARNING, "Padding type has to be STR_PAD_LEFT, STR_PAD_RIGHT, or STR_PAD_BOTH"); RETURN_FALSE; } // 计算需要填充的长度 if (pad_length < 0 || (size_t)pad_length <= ZSTR_LEN(input)) { RETURN_STR_COPY(input); } // 计算左侧和右侧需要填充的长度 if (pad_type_val == STR_PAD_BOTH) { left_pad = (pad_length - ZSTR_LEN(input)) / 2; right_pad = (pad_length - ZSTR_LEN(input)) - left_pad; } else { right_pad = pad_length - ZSTR_LEN(input); if (pad_type_val == STR_PAD_LEFT) { left_pad = right_pad; right_pad = 0; } } // 分配足够的内存空间来存储结果字符串 result = zend_string_alloc(ZSTR_LEN(input) + left_pad + right_pad, 0); // 填充左侧 memset(ZSTR_VAL(result), ' ', left_pad); // 复制原始字符串到结果字符串 memcpy(ZSTR_VAL(result) + left_pad, ZSTR_VAL(input), ZSTR_LEN(input)); // 填充右侧 memset(ZSTR_VAL(result) + left_pad + ZSTR_LEN(input), ' ', right_pad); // 设置结果字符串的长度并返回 ZSTR_VAL(result)[ZSTR_LEN(result)] = '\0'; RETURN_NEW_STR(result); } /* }}} */
这段代码首先解析了传入的参数,然后根据填充类型计算出左侧和右侧需要填充的长度。接着,它会分配足够的内存空间来存储结果字符串,并将原始字符串复制到结果字符串中。最后,它会在左侧和右侧添加填充字符串,并返回结果字符串。