為什麼這篇unicode utf-8差異鄉民發文收入到精華區:因為在unicode utf-8差異這個討論話題中,有許多相關的文章在討論,這篇最有參考價值!作者LPH66 (1597463007)看板Web_Design標題Re: [請益] Unicode...
※ 引述《x2006 (冬眠)》之銘言:
: Unicode的檔案是不是只分為底下五類?
: 00 00 fe ff : UTF-32, Big Endian
: fe ff 00 00 : UTF-32, Little Endian
ff fe 00 00
: fe ff : UTF-16, Big Endian
: ff fe : UTF-16, Little Endian
: ef bb bf : UTF-8
其實名字以 UTF 開頭的編碼還不只這些, 只是這些相對常用而已
其中最常用的是 UTF-8
UTF-16 也不少見
UTF-32 則比較沒什麼看到, 主要還是浪費空間
(一個字佔 4 byte, 如果全是英文則有 3/4 的 byte 是 0,
如果是常用中文則有一半是 0,
然後由於 Unicode 只到 U+10FFFF 的關係, 永遠至少有 1/4 的 byte 是 0)
: Notepad打開分為底下四類:
: ANSI
: Unicode (就是UTF-16, Little Endian?)
: Unicode big endian (就是UTF-16, Big Endian?)
: UTF-8
以上正確
另外要講的是 Notepad 所存成的 Unicode 檔案都會有 BOM
(就是你上面列的那些 byte)
這會造成一些判斷檔案開頭有沒有東西的程式失效或出問題
例如 PHP 程式如果有 BOM 則會先行輸出以致於無法更改 header 資訊
: 記得早期在寫網頁的時候,只用ANSI. XD
: 現在大部分的網頁好像都是用UTF-8.
: 有人用UTF-16或UTF-32來寫網頁的嗎?(什麼情況下會用到?)
UTF-32 如上所說比較沒什麼在用
UTF-8 勝過 UTF-16 的一點是:
對於純英文的文字 (也就是只使用 ASCII < 127 的字元的文字)
它自動就是一個正確的 UTF-8 編碼文字
這才使得 UTF-8 比 UTF-16 來得常見
在其他方面我覺得其實兩者沒什麼差就是
---
來搬個前輩的文章出來壓陣(?)好了:
每個軟體開發者都絕對一定要會的Unicode及字元集必備知識(沒有藉口!)
by Joel Spolsky
http://tinyurl.com/cvultt
個人覺得這篇十年前的文章依然有不少地方值得現在的人參考
--
有人喜歡邊玩遊戲邊上逼;
也有人喜歡邊聽歌邊打字。
但是,我有個請求,
選字的時候請專心好嗎?
-- 改編自「古 火田 任三郎」之開場白
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 123.195.39.85
※ 文章網址: http://www.ptt.cc/bbs/Web_Design/M.1396101057.A.7DE.html