首頁 > 後端開發 > php教程 > PHP中strpos函數的深入分析

PHP中strpos函數的深入分析

不言
發布: 2023-04-03 13:24:02
原創
2207 人瀏覽過

這篇文章跟大家分享的內容是關於PHP中strpos函數的深入分析,內容很詳細,有需要的朋友可以參考一下,希望可以幫助到你們。

概述

在php中經常用strpos 判斷字串是否在另一個字串中存在, 本文介紹strpos 函數及其實現。

strpos應用程式

<?php
/* strpos示例 */

// test
echo &#39;match:&#39;, strpos(&#39;xasfsdfbk&#39;, &#39;xasfsdfbk&#39;) !== false ? &#39;true&#39; : &#39;false&#39;, &#39;;&#39;, PHP_EOL;
echo &#39;match:&#39;, strpos(&#39;xasfsdfbk&#39;, &#39;fbk&#39;) !== false ? &#39;true&#39; : &#39;false&#39;, &#39;;&#39;, PHP_EOL;
echo &#39;match:&#39;, strpos(&#39;xasfsdfbk&#39;, &#39;xs&#39;) != false ? &#39;true&#39; : &#39;false&#39;, &#39;;&#39;, PHP_EOL;
echo &#39;match:&#39;, strpos(&#39;xasfsdfbk&#39;, &#39;sfs&#39;) !== false ? &#39;true&#39; : &#39;false&#39;, &#39;;&#39;, PHP_EOL;

// code
strpos(&#39;xasfsdfbk&#39;, &#39;sfs&#39;);
登入後複製
Warning: strpos 函數可能會傳回布林值FALSE,但也可能回傳等同於FALSE 的非布林值。請閱讀 布爾類型章節以獲取更多資訊。應使用 === 運算子來測試此函數的傳回值。

strpos系列函數

##找出字串的首次出現PHP 4, PHP 5, PHP 7#stristrstrstr() 函數的忽略大小寫版本# PHP 4, PHP 5, PHP 7substr_count#計算字串出現的次數mb* 相關的函數也可, 例如說mb_strpos是基於字元數執行一個多位元組安全的strpos() 運算。
PHP(strpos)原始碼

strpos(ext/standard/string.c)

    PHP原始碼位址
  • #
    PHP_FUNCTION(strpos)
    {
        zval *needle;
        zend_string *haystack;
        char *found = NULL;
        char  needle_char[2];
        zend_long  offset = 0;
    
    #ifndef FAST_ZPP
        if (zend_parse_parameters(ZEND_NUM_ARGS(), "Sz|l", &haystack, &needle, &offset) == FAILURE) {
            return;
        }
    #else
        ZEND_PARSE_PARAMETERS_START(2, 3)
            Z_PARAM_STR(haystack)
            Z_PARAM_ZVAL(needle)
            Z_PARAM_OPTIONAL
            Z_PARAM_LONG(offset)
        ZEND_PARSE_PARAMETERS_END();
    #endif
    
        if (offset < 0) {
            offset += (zend_long)ZSTR_LEN(haystack);
        }
        if (offset < 0 || (size_t)offset > ZSTR_LEN(haystack)) {
            php_error_docref(NULL, E_WARNING, "Offset not contained in string");
            RETURN_FALSE;
        }
    
        if (Z_TYPE_P(needle) == IS_STRING) {
            if (!Z_STRLEN_P(needle)) {
                php_error_docref(NULL, E_WARNING, "Empty needle");
                RETURN_FALSE;
            }
    
            found = (char*)php_memnstr(ZSTR_VAL(haystack) + offset,
                                Z_STRVAL_P(needle),
                                Z_STRLEN_P(needle),
                                ZSTR_VAL(haystack) + ZSTR_LEN(haystack));
        } else {
            if (php_needle_char(needle, needle_char) != SUCCESS) {
                RETURN_FALSE;
            }
            needle_char[1] = 0;
    
            found = (char*)php_memnstr(ZSTR_VAL(haystack) + offset,
                                needle_char,
                                1,
                                ZSTR_VAL(haystack) + ZSTR_LEN(haystack));
        }
    
        if (found) {
            RETURN_LONG(found - ZSTR_VAL(haystack));
        } else {
            RETURN_FALSE;
        }
    }
    登入後複製
  • php_memnstr(main/php.h)

    #PHP原始碼位址
  • #define php_memnstr zend_memnstr /* 338 line*/
    登入後複製
  • zend_memnstr(Zend/zend_operators.h)

    PHP原始碼位址
  • /*
     * 此函数的作用是在haystack中查找needle,如果不存在返回null,如果存在,返回指向haystack中needle头字符的指针
     */
    zend_memnstr(const char *haystack, const char *needle, size_t needle_len, const char *end)
    {
        const char *p = haystack;
        const char ne = needle[needle_len-1];
        ptrdiff_t off_p;
        size_t off_s;
    
        if (needle_len == 1) {
            return (const char *)memchr(p, *needle, (end-p));
        }
    
        off_p = end - haystack;
        off_s = (off_p > 0) ? (size_t)off_p : 0;
    
        if (needle_len > off_s) {
            return NULL;
        }
    
        if (EXPECTED(off_s < 1024 || needle_len < 3)) {
            // 第一个优化,只查找end - needle_len次
            end -= needle_len;
    
            while (p <= end) {
                // 第二个优化,先判断字符串的开头和结尾是否一样再判断整个字符串
                if ((p = (const char *)memchr(p, *needle, (end-p+1))) && ne == p[needle_len-1]) {
                    if (!memcmp(needle, p, needle_len-1)) {
                        return p;
                    }
                }
    
                if (p == NULL) {
                    return NULL;
                }
    
                p++;
            }
    
            return NULL;
        } else {
            return zend_memnstr_ex(haystack, needle, needle_len, end);
        }
    }
    登入後複製
  • memchr(string.h)

    Linux核心版-原始碼位址
  • /*
    头文件:#include <string.h>
    
    定义函数:void * memchr(const void *s, char c, size_t n);
    
    函数说明:memchr()从头开始搜寻s 所指的内存内容前n 个字节,直到发现第一个值为c 的字节,则返回指向该字节的指针。
    
    返回值:如果找到指定的字节则返回该字节的指针,否则返回0。
    */
    
    #ifndef __HAVE_ARCH_MEMCHR
    void *memchr(const void *s, int c, size_t n)
    {
        const unsigned char *p = s;
        while (n-- != 0) {
                if ((unsigned char)c == *p++) {
                return (void *)(p - 1);
            }
        }
        return NULL;
    }
    EXPORT_SYMBOL(memchr);
    #endif
    登入後複製
  • memcmp(string.h)

    #Linux核心版-原始碼位址
  • /* 字符串函数memcmp
       原型:extern int memcmp(void *buf1, void *buf2, unsigned int count); 
       功能:比较内存区域buf1和buf2的前count个字节
       说明:当buf1<buf2时,返回值<0  
             当buf1=buf2时,返回值=0   
             当buf1>buf2时,返回值>0                                        
    */
    #ifndef __HAVE_ARCH_MEMCMP
    #undef memcmp
    __visible int memcmp(const void *cs, const void *ct, size_t count)
    {
        const unsigned char *su1, *su2;
        int res = 0;
    
        for (su1 = cs, su2 = ct; 0 < count; ++su1, ++su2, count--)
            if ((res = *su1 - *su2) != 0)
                break;
        return res;
    }
    EXPORT_SYMBOL(memcmp);
    #endif
    登入後複製
  • 提示

strpos函數對大小寫敏感。

相關推薦:

PHP中鎖定機制的應用

如何實現將php的id加密的問題

以上是PHP中strpos函數的深入分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
最新問題
怎麼學好php
來自於 1970-01-01 08:00:00
0
0
0
PHP擴充intl
來自於 1970-01-01 08:00:00
0
0
0
php數據獲取?
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
函數#描述版本
strpos找出字串首次出現的位置PHP 4, PHP 5, PHP 7
stripos尋找字串首次出現的位置(不區分大小寫)PHP 5, PHP 7
strrpos計算指定字符串在目標字串中最後一次出現的位置PHP 4, PHP 5, PHP 7
strripos#計算字串在目標字串中最後一次出現的位置(不區分大小寫)PHP 5, PHP 7
#mb_strpos在另一個字串中首次出現的位置PHP 4 >= 4.0.6, PHP 5, PHP 7
strstr
##PHP 4, PHP 5, PHP 7