特定の文字または文字列に基づいて配列を配列に分割する必要がある場合、explode は非常に便利に使用できますが、~explode の仕組みをご存知ですか~~
まず第一に、explode がスペースも割り当てることは確実です。間違いない。
//ファイル1: ext/standard/string.c
//最初にexplodeのソースコードを見てみましょう
PHP_FUNCTION(explode)
{
char *str, * delim;
int str_len = 0, delim_len = 0; /* 制限なし */
zval zdelim, zstr; l", &delim, &delim_len, &str, &str_len, &limit) == FAILURE) {
return;
}
if (delim_len == 0) {
php_error_docref(NULL TSRMLS_CC, E_WARNING, "空の区切り文字");
RETURN_FALSE;
}
//ここで分割データを格納するための配列が開かれます
array_init(return_value);
//このため、explode('|', '') が有効になります
if (str_len == 0) {
if (limit >= 0) {
add_next_index_stringl(return_value, "", sizeof("") - 1, 1);
}
}
//次の 2 つは両方の元の文字列から構築されます。と区切り文字を _zval_struct 構造体に追加すると、
//ZVAL_STRINGL がスペースを割り当てます~~ソースコードは後で投稿します
ZVAL_STRINGL(&zstr, str, str_len, 0); /limit 値は、explode で渡すことができるexplodeの3番目のパラメータで、正と負を許可します
if (limit > 1) {
php_explode(&zdelim, &zstr, return_value, limit); else if (limit); php_explode_negative_limit (&zdelim, &zstr, return_value, limit);
add_index_stringl(return_value, 0, str, str_len, 1);
コード
コードは次のとおりです:
//ファイル 2: zend/zend_API.c
....
/ /_estrndup の実装: zend/zend_alloc.c
ZEND_API char *_estrndup(const char *s, uint length ZEND_FILE_LINE_DC ZEND_FILE_LINE_ORIG_DC)
{
char *p = (char *) _emalloc(length+1 ZEND_FILE_LINE_RELAY_CC; ZEND_FILE_LINE_ORIG_RELAY_CC); if (UNEXPECTED(p == NULL)) {
return p;
}
memcpy(p, s, length); // スペースを確保
p[length] = 0;
// , substr と strrchr strstr で使用される ZVAL_STRING も使用されます アピールの実装
以下は、explode の 3 番目のパラメータ制限に基づいて呼び出しを分析するものです: 条件は、explode の最後の 3 行に対応します。制限条件
注: 制限がデフォルトになっている (渡されていない) 場合、そのデフォルト値は LONG_MAX であり、これはブランチ 1 の場合です
1、limit > 1:
ext/standard にもある php_explode メソッドを呼び出します/string.c で、explode が表示されるすぐ上に実装されています (この関数でこのファイルからメソッドを検索するときに非常に便利です。ほとんどすべてのメソッドが関数のすぐ上にあります^_^)。
をコピーします。コード
コードは次のとおりです:
PHPAPI void php_explode(zval *delim, zval *str, zval *return_value, long limit)
{
char *p1, *p2, *endp;
//最初に取得するのは、 source string
endp = Z_STRVAL_P(str) + Z_STRLEN_P(str);
//レコード開始位置
p1 = Z_STRVAL_P(str); 以下は str 内の区切り文字の位置を取得するものです。 strrpos と strpos にもあります。このメソッドは
p2 = php_memnstr(Z_STRVAL_P(str), Z_STRVAL_P(delim), Z_STRLEN_P(delim), endp); を見つけるために使用されます。 、explore( '|', 'abc'); を呼び出すと、結果は array(0 => 'abc')
add_next_index_stringl(return_value, p1, Z_STRLEN_P(str), 1); になります。 else {
//次の区切り文字の位置を最後まで取得するシーケンスループ
do {
//取得される部分文字列(前の位置からこの位置までの中間部分、前の位置が初めて始まります
add_next_index_stringl(return_value, p1 , p2 - p1, 1);
//区切り文字の位置 p2 + 区切り文字の長さを見つけます
//たとえば、区切り文字 = '|'、元の文字列 = 'ab |c'、p2 = 2、p1=2+1=3
p1 = p2 + Z_STRLEN_P(delim)
} while ((p2 = php_memnstr(p1, Z_STRVAL_P(delim), Z_STRLEN_P(delim), endp)) != NULL &&
--limit > ;
//最後の区切り文字の後の文字列を結果の array
//explode('|', 'avc|sdf'); > 'avc' , 1= >
コードをコピーします
コードは次のとおりです:
PHPAPI void php_explode_negative_limit(zval *delim, zval *str, zval *return_value, long limit)
# EXPLODE_ALLOC_STEP 64 を定義します
char *p1, *p2, * endp ;
p1 = Z_STRVAL_P(str);
} else {
int assign = EXPLODE_ALLOC_STEP, found = 0 ;
long i, to_return;
char * *positions = emalloc(allocated * sizeof(char *));
//この配列は、すべての部分文字列の読み取り位置を保存するために使用されます。 [found++] = p1; //もちろん、開始位置を保存する必要があります
//次の 2 つのループ、最初のループは、文字列内に出現するすべての区切り文字の位置をループし、次の部分文字列の読み取り位置を保存します
do {
if (found >=割り当てられました) {
allocated = found + EXPLODE_ALLOC_STEP;/* 十分なメモリがあることを確認します */
positions = erealloc(positions, allowed*sizeof(char *));
positions[ found++] = p1 = p2 + Z_STRLEN_P(delim);
} while ((p2 = php_memnstr(p1, Z_STRVAL_P(delim), Z_STRLEN_P(delim), endp)) != NULL);返された結果は配列から取得されます 文字列の読み取りが開始されます
to_return = limit + found;
/* 限界は少なくとも -1 であるため、境界チェックの必要はありません : i は常に found より小さくなります */
for (i = 0) ;i 0 もチェックします */
add_next_index_stringl(return_value, 位置[i],
(位置[i+1] - Z_STRLEN_P(delim)) - 位置[i] ,
1
);
}
efree(positions);//非常に重要です、メモリを解放します
}
#undef EXPLODE_ALLOC_STEP
}
3. 最初と 2 番目の条件がすべて満たされている場合満たされていない場合は、Return array(0 => 'avc|sd'); のこのブランチを入力します。
コードをコピー
コードは次のとおりです:
//add_index_stringl ソース コード
//ファイル 4: zend/zend_API.c
ZEND_API int add_next_index_stringl(zval *arg, const char *str, uint length, int dedicated) /* {{{ */
{
MAKE_STD_ZVAL(tmp);
ZVAL_STRINGL(tmp, str、長さ、重複);
//zend_hash_next_index_insert
//zend/zend_hash.h
#define zend_hash_next_index_insert (ht、pData、 nDataSize, pDest)
それはわかります(割り当てられたスペースを除く)、
limit>1の場合、効率はO(N) [Nは限界値]、
limitlimit=1 または limit=0 の場合、効率は O(1)

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

php判断有没有小数点的方法:1、使用“strpos(数字字符串,'.')”语法,如果返回小数点在字符串中第一次出现的位置,则有小数点;2、使用“strrpos(数字字符串,'.')”语句,如果返回小数点在字符串中最后一次出现的位置,则有。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。

在PHP中,可以利用implode()函数的第一个参数来设置没有分隔符,该函数的第一个参数用于规定数组元素之间放置的内容,默认是空字符串,也可将第一个参数设置为空,语法为“implode(数组)”或者“implode("",数组)”。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

SublimeText3 中国語版
中国語版、とても使いやすい

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

メモ帳++7.3.1
使いやすく無料のコードエディター

ドリームウィーバー CS6
ビジュアル Web 開発ツール
