php内置函数分析之str_pad()

php内置函数分析之str_pad()

PHP_FUNCTION(str_pad)
{
    /* Input arguments */
    zend_string *input;                /* Input string 输入字符串*/
    zend_long pad_length;            /* Length to pad to 填充到多长.*/

    /* Helper variables */
    size_t num_pad_chars;        /* Number of padding characters (total - input size) 要填充进去的字符个数*/
    char *pad_str = " "; /* Pointer to padding string */
    size_t pad_str_len = 1; // 填充字符的个数 
    zend_long   pad_type_val = STR_PAD_RIGHT; /* The padding type value 填充类型,左填充、右填充、左右填充。默认右填充*/
    size_t       i, left_pad=0, right_pad=0;
    zend_string *result = NULL;    /* Resulting string 返回值*/

    if (zend_parse_parameters(ZEND_NUM_ARGS(), "Sl|sl", &input, &pad_length, &pad_str, &pad_str_len, &pad_type_val) == FAILURE) {
        return;
    }

    /* If resulting string turns out to be shorter than input string,
       we simply copy the input and return. */
    /* 如果pad_length(参数2)小于等于输入字符串的长度,则返回原始的输入字符串。*/
    if (pad_length < 0  || (size_t)pad_length <= ZSTR_LEN(input)) {
        RETURN_STRINGL(ZSTR_VAL(input), ZSTR_LEN(input));
    }

    /* 填充字符串长度为0,如:str_pad("abc", 10, ""),则Warning级别的错误。
       填充字符串的默认长度为1,即str_pad("abc", 10),的情况下pad_str_len=1。*/
    if (pad_str_len == 0) {
        php_error_docref(NULL, E_WARNING, "Padding string cannot be empty");
        return;
    }

    /*pad_type只能为STR_PAD_LEFT, STR_PAD_RIGHT, or STR_PAD_BOTH 或 0, 1, 2*/
    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;
    }

    num_pad_chars = pad_length - ZSTR_LEN(input); // 需要被填充进去的字符的数量
    if (num_pad_chars >= INT_MAX) { // num_pad_chars的最大值是2147483647。#define INT_MAX 2147483647
        php_error_docref(NULL, E_WARNING, "Padding length is too long");
        return;
    }

    result = zend_string_safe_alloc(1, ZSTR_LEN(input), num_pad_chars, 0);
    ZSTR_LEN(result) = 0;

    /* We need to figure out the left/right padding lengths. */
    switch (pad_type_val) {
        case STR_PAD_RIGHT:
            left_pad = 0;
            right_pad = num_pad_chars;
            break;

        case STR_PAD_LEFT:
            left_pad = num_pad_chars;
            right_pad = 0;
            break;

        // 左填充数量小于右,left_pad <= right_pad
        case STR_PAD_BOTH:
            left_pad = num_pad_chars / 2;
            right_pad = num_pad_chars - left_pad;
            break;
    }

    /* First we pad on the left. */
    /* 左填充:循环添加字符 */
    for (i = 0; i < left_pad; i++)
        ZSTR_VAL(result)[ZSTR_LEN(result)++] = pad_str[i % pad_str_len];

    /* Then we copy the input string. */
    /* 左填充完成后,附加输入字符串 */
    memcpy(ZSTR_VAL(result) + ZSTR_LEN(result), ZSTR_VAL(input), ZSTR_LEN(input));
    ZSTR_LEN(result) += ZSTR_LEN(input);

    /* Finally, we pad on the right. */
    /* 右填充:循环添加字符串 */
    for (i = 0; i < right_pad; i++)
        ZSTR_VAL(result)[ZSTR_LEN(result)++] = pad_str[i % pad_str_len];

    // 添加字符串结束标志'\0'
    ZSTR_VAL(result)[ZSTR_LEN(result)] = '\0';

    // 返回新字符串
    RETURN_NEW_STR(result);
}

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/112494.html原文链接:https://javaforall.net

(0)
上一篇 2021年11月6日 下午6:00
下一篇 2021年11月6日 下午7:00


相关推荐

  • html css制作404页面,一款纯css3实现的漂亮的404页面

    html css制作404页面,一款纯css3实现的漂亮的404页面实现的代码。html代码:404ERRORLost?MaybeIcanhelp.required/>SearchMySuggestions.HomePortfoliocss3代码:body{background-color:#0A7189;color:#fff;font:100%”Lato”,sans-serif;font-size:1.8r…

    2022年7月27日
    14
  • 人工智能猴子摘香蕉问题状态过程_人工智能原理猴子吃香蕉问题

    人工智能猴子摘香蕉问题状态过程_人工智能原理猴子吃香蕉问题题目:利用一阶谓词逻辑求解猴子摘香蕉问题:房内有一个猴子,一个箱子,天花板上挂了一串香蕉,其位置如图1所示,猴子为了拿到香蕉,它必须把箱子搬到香蕉下面,然后再爬到箱子上。请定义必要的谓词,列出问题的初始化状态(即下图所示状态),目标状态(猴子拿到了香蕉,站在箱子上,箱子位于位置b)。(附加:从初始状态到目标状态的谓词演算过程。)1.定义描述环境状态的谓词。AT(x,w):x在w处,个体域:x?{monkey},w?{a,b,c,box};HOLD(x,t):x手中拿着t,个体域:t?{box,ba

    2026年4月14日
    8
  • 电商后台管理系统项目实例

    电商后台管理系统项目实例电商后台管理系统项目实例1.D2admin开源地址:https://github.com/d2-projects/d2-admin文档地址:https://d2.pub/zh/doc/d2-admin/效果预览:https://d2.pub/d2-admin/preview/#/index开源协议:MIT2.vue-element-admin开源地址:https://github.com/PanJiaChen/vue-element-admin文档地址:https://panjiachen

    2022年6月6日
    77
  • Java经典设计模式之十一种行为型模式(附实例和详解)

    Java经典设计模式之十一种行为型模式(附实例和详解)

    2020年11月12日
    166
  • Java truelicense 实现License授权许可和验证

    Java truelicense 实现License授权许可和验证文章目录前言一 场景二 truelicense 是什么三 原理四 使用步骤五 实现代码六 执行代码期间遇到的问题参考资料前言一 场景二 truelicense 是什么三 原理四 使用步骤在接触代码前 我们先来大概熟悉下密钥生成的流程吧 1 首先要用 KeyTool 工具来生成私匙库 alias 别名 validity3650 表示 10 年有效 keytool genkey aliasprivate keystorepriv store validity3650 这

    2026年3月17日
    2
  • Go string 转map

    Go string 转map最近用 go 重构 python 项目 遇见一些问题 简单记录一下 1 string 转 map 为什么要想到这个转换方式呢 主要是 python 项目中用到的是 string 转字典 比如 前端传过来的 book python 基础教程 用 python 简单接收之后 用 json load 很简单转为字典 用 go 的话 最简单的方式是 string 转 map class detail

    2026年3月18日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号