Home > Backend Development > PHP Tutorial > Do you know the difference between strlen and mb_strlen in php?

Do you know the difference between strlen and mb_strlen in php?

怪我咯
Release: 2023-03-13 20:42:01
Original
1681 people have browsed it

Commonly used functions in php to calculate string length are: strlen and mb_strlen. When the characters are all English characters, the two are Same. Here we mainly compare the two calculation results when Chinese and English are mixed.

In PHP, strlen and mb_strlen are functions to find the length of a string.

strlen() function returns the length of the string. If successful, it returns the length of the string. If the string is If empty, 0 is returned.

mb_strlen - Get the length of the string,

Syntax

mb_strlen ($str, $encoding)
Copy after login

str The string to check the length.

encoding The parameter is character encoding. If omitted, the internal character encoding is used.

Return value

Returns the number of characters contained in the string str with encoding encoding. Multibyte characters are counted as 1.

Returns FALSE if the given encoding is invalid.

The following is an example of the difference between the two.

Look at the example first:

<?php 
//测试时文件的编码方式要是UTF8 
$str=&#39;中文a字1符&#39;; 
echo strlen($str).&#39;<br>&#39;;//14 
echo mb_strlen($str,&#39;utf8&#39;).&#39;<br>&#39;;//6 
echo mb_strlen($str,&#39;gbk&#39;).&#39;<br>&#39;;//8 
echo mb_strlen($str,&#39;gb2312&#39;).&#39;<br>&#39;;//10 
?>
Copy after login

Result analysis: When calculating strlen, a UTF8 Chinese character is treated as 3 lengths, so the length of "Chinese a character 1 character" is 3 *4+2=14. When calculating mb_strlen, if the internal code is selected as UTF8, a Chinese character will be calculated as a length of 1, so the length of "Chinese a character 1 character" is 6.

Using these two functions, you can jointly calculate the occupancy of a mixed Chinese and English string (the occupancy of a Chinese character is 2, and the occupancy of an English character is 1)

echo (strlen($str) + mb_strlen($str,&#39;UTF8&#39;)) / 2;
Copy after login

For example, "Chinese a character 1 The strlen($str) value of "character" is 14, and the value of mb_strlen($str) is 6. It can be calculated that the placeholder of "Chinese a character 1 character" is 10.

echo mb_internal_encoding();
Copy after login

PHP built-in string The length function strlen cannot handle Chinese strings correctly, it only gets the number of bytes occupied by the string. For GB2312 Chinese encoding, the value obtained by strlen is twice the number of Chinese characters, while for UTF-8 encoded Chinese, the difference is three times (under UTF-8 encoding, one Chinese character occupies 3 bytes).

Using the mb_strlen function can better solve this problem. The usage of mb_strlen is similar to strlen, except that it has a second optional parameter to specify the character encoding. For example, to get the UTF-8 string $str length, you can use mb_strlen($str,'UTF-8'). If the second parameter is omitted, PHP's internal encoding will be used. The internal encoding can be obtained through the mb_internal_encoding() function.

It should be noted that mb_strlen is not a core function of PHP. Before using it, you need to make sure that php_mbstring.dll is loaded in php.ini, that is, make sure that "extension=php_mbstring.dll" A line exists and is not commented, otherwise an undefined function problem will occur.

The above is the detailed content of Do you know the difference between strlen and mb_strlen in php?. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template