摘要:應使用運算符來測試此函數的返回值。返回值如果找到指定的字節則返回該字節的指針,否則返回。內核版源碼地址字符串函數原型功能比較內存區域和的前個字節說明當時,返回值當時,返回值當時,返回值提示函數對大小寫敏感。
概述
在php中經常用 strpos 判斷字符串是否在另一個字符串中存在, 本文介紹 strpos 函數及其實現。
strpos應用Warning: strpos 函數可能返回布爾值 FALSE,但也可能返回等同于 FALSE 的非布爾值。請閱讀 布爾類型章節以獲取更多信息。應使用 === 運算符來測試此函數的返回值。strpos系列函數
函數 | 描述 | 版本 |
---|---|---|
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 |
stristr | strstr() 函數的忽略大小寫版本 | PHP 4, PHP 5, PHP 7 |
substr_count | 計算字串出現的次數 | PHP 4, PHP 5, PHP 7 |
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內核版-源碼地址
/* 頭文件:#includememcmp(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
Linux內核版-源碼地址
/* 字符串函數memcmp 原型:extern int memcmp(void *buf1, void *buf2, unsigned int count); 功能:比較內存區域buf1和buf2的前count個字節 說明:當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 strpos官方文檔
字符串查找算法
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/29105.html
摘要:第一個字符的位置是,第二個字符的位置是,以此類推。和不同的是,數字的值不會被當做字符的順序值。搜索位置的偏移。如果沒有提供該參數,將會使用。負數的會從字符串尾部開始統計。如果省略,則使用內部字符編碼。返回的中首次出現位置的數值。 mb_strpos (PHP 4 >= 4.0.6, PHP 5, PHP 7) mb_strpos — Find position of first oc...
摘要:文章來自原文歡迎來到給開發者的源碼系列的第二部分。是在內部代表任意一個變量的定義。這種情況下函數會拋出警告,而此函數馬上返回會返回給的用戶層代碼。原因是,是少數通過而不是擴展定義的函數。下一部分下一部分會再次發表在。 文章來自:http://www.hoohack.me/2016/02/10/understanding-phps-internal-function-definitio...
摘要:規定要檢查的字符串。遇到這種情況時可以使用函數進行檢測。輸出反引用一個引用字符串函數示例反引用一個引用字符串輸出連接分割字符串使用一個字符串分割另一個字符串邊界上的分隔字符。應使用運算符來測試返回值函數示例輸出返回字符串的子串輸入字符串。 轉自我的github函數示例源碼 字符串的格式化 rtrim(),除字符串右端的空白字符或其他預定義字符 ltrim(),刪除字符串開頭空格或...
摘要:例子的值是,因此核心源碼調用函數查找如果不是字符串,轉換成數字并賦值為該數字的字符。設置結束字符有一點要注意的是,如果不是字符串的話,會調用函數將轉成整型數字并轉換為其值。變量就是調用函數時傳遞的變量。核心源碼拷貝一份調用函數找出的值。 我在github有對PHP源碼更詳細的注解。感興趣的可以圍觀一下,給個star。PHP5.4源碼注解。可以通過commit記錄查看已添加的注解。 st...
摘要:返回給定字符串中的元音數。使用正則表達式來計算字符串中元音的數量。對字符串的第一個字母進行無頭化,然后將其與字符串的其他部分相加。使用查找字符串中第一個出現的子字符串的位置。相關文章秒的代碼片段數組秒的代碼片段數學 本文來自GitHub開源項目 點我跳轉 30秒的PHP代碼片段 showImg(https://segmentfault.com/img/bVbnR1I?w=2800&h=...
閱讀 844·2023-04-25 21:21
閱讀 3226·2021-11-24 09:39
閱讀 3067·2021-09-02 15:41
閱讀 1995·2021-08-26 14:13
閱讀 1827·2019-08-30 11:18
閱讀 2768·2019-08-29 16:25
閱讀 507·2019-08-28 18:27
閱讀 1580·2019-08-28 18:17