上一篇文章中我們了解了使用「自然」演算法知道字串異同的方法,有需要的請看《php一招搞定「自然」演算法比較字串的異同(區分大小寫) 》。這次我們向大家介紹取得字串的長度的方法,有需要的可以參考參考。
在php中,我們需要了解字串的長度,方便去做一些事情,也方便了解字串。那我們話不多說,這就來看看取得字串函數的方法吧。
首先我們來看一個小例子。
<?php echo strlen("World grand, welcome home!"); ?>
這個小例子的結果是
#看到這個答案的時候,不知道小夥伴們有沒有把這個字串從頭到尾數一遍。我先說,一定要數一遍啊,萬一這個函數錯了呢?那我多有成就感。但是我從頭到尾,發現這個函數的長度還真是26。
這個函數沒有問題,那我們就來說這個函數吧。
strlen() 函數傳回字串的長度(位元組數)。 strlen() 常常用在迴圈和其他函數中,因為那時確定字串何時結束是很重要的。 (例如,在循環中,我們需要在字串中的最後一個字元之後結束循環)
那我們再來看一個例子。
<?php echo strlen("世界盛大,欢迎回家!"); ?>
結果是
發現和上面例子的答案不一樣了,對不對。一個參數是中文,一個參數是英文,有這麼大的差別嗎?中文的加上標點符號明明才10個字,為什麼這個的長度確實是30,大家想過嗎?
中文單字和英文單字差別當然很大。而在各種編碼下每個字母佔的位元組也不一樣
在ASCII碼下,一個英文字母(不分大小寫)佔一個位元組的空間,一個中文漢字佔兩個位元組的空間。一個二進制數字序列,在計算機中作為一個數字單元,一般為8位二進制數,換算為十進制。最小值-128,最大值127。如一個ASCII碼就是一個位元組。
在UTF-8編碼下,一個英文字元等於一個位元組,一個中文(含繁體)等於三個位元組。中文標點佔三個字節,英文標點佔一個位元組。
在Unicode編碼下,一個英文等於兩個位元組,一個中文(含繁體)等於兩個位元組。中文標點佔兩個字節,英文標點佔兩個位元組。
我們例子上所用的編碼都是utf-8的,所以一個中文佔三個位元組。因此10個中文的長度高達30。
就說到這裡了,有其他想知道的,可以點選這個喔。 → →php影片教學
#以上是php如何了解字串的長度的詳細內容。更多資訊請關注PHP中文網其他相關文章!