成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

PHP四種序列化方案

Wildcard / 2050人閱讀

摘要:這里序列化的概念可能更為廣泛和籠統(tǒng)一些,包括傳統(tǒng)的等。就目前來看,等二進制序列化無論是速度上還是數(shù)據(jù)大小上,都要比文本序列化更好。,反序列化方法。用法,序列化方法。

原文地址:https://t.ti-node.com/thread/...

數(shù)據(jù)的序列化是一個非常有用的功能,然而目測很多人跟我一樣,在剛接觸這玩意的時候壓根就不理解這貨色到底是干啥用的,反正老師說了,實在理解不了就先背過再說。

“啥犢子玩意啊,又是序列化、又是反序列化。。。”(圖片來自于《我的團長我的團》之國軍二道販子兼二人轉(zhuǎn)演員迷龍同學(xué))。

其實將數(shù)據(jù)序列化的作用無外乎有兩個:

方便傳輸

方便存儲

方便存儲如何理解呢?比如我們有個PHP對象或者一個PHP數(shù)組需要存儲到數(shù)據(jù)庫甚至文件中,這顯然是不可能的,這個時候必須要將PHP對象或者PHP數(shù)組序列化后再執(zhí)行存儲操作。不過這將PHP數(shù)組序列化后存起來還能理解,這對象也能存儲啊?這操作是否過于風(fēng)騷?少年,這一點兒都不風(fēng)騷。有些時候?qū)ο笾苯哟鎯ζ饋?,用的時候只需要簡單的反序列化后就可以投產(chǎn)使用了,避免了new一次帶來的性能耗費。

方便傳輸如何理解呢?其實序列化在傳輸中應(yīng)用的相對更多更常見些許。最簡單的一個例子,一個碼前端的碼了一個ajax找你給TA提供一個API,那么這個時候你倆得商量返回什么數(shù)據(jù),比如json或者xml,甚至你倆自己作死約定私有數(shù)據(jù)格式。比如在一個比較典型的服務(wù)架構(gòu)中,網(wǎng)關(guān)服務(wù)器和內(nèi)部RPC服務(wù)器之間通過msgpack傳遞數(shù)據(jù)。這都是典型的序列化為了傳輸?shù)牡湫蛻?yīng)用案例。

這里序列化的概念可能更為廣泛和籠統(tǒng)一些,包括傳統(tǒng)的serialize、json、msgpack、protobuf等。( 如果你覺得序列化這個稱呼不太嚴謹?shù)脑?,可以用encode來代替;反序列化則用decode來代替。反正我就用統(tǒng)統(tǒng)用序列化和反序列化來稱呼了,如果你覺得實在不舒服,可以順著網(wǎng)線來砍我!)。

實際上,從更高的層面看,數(shù)據(jù)的序列化可以分為兩種:

文本序列化,常見如json、serialize、xml等

二進制序列化,常見如msgpack、protobuf、thrift等

一般說來,考驗序列化技術(shù)的性能指標(biāo)一共有兩個,一個是序列化的速度,一個是序列化后數(shù)據(jù)的大小,自然是序列化速度越快、序列化后的數(shù)據(jù)越小為佳。就目前來看,protobuf、msgpack等二進制序列化無論是速度上還是數(shù)據(jù)大小上,都要比文本序列化更好。不過話說回來,文本序列化有更好的可讀性,一眼就能瞪出來數(shù)據(jù)內(nèi)容大概是啥玩意。

今天帶到這里的這里的有四個具體的方案,這四種方案都是簡單粗暴、開箱即用類型的,我們分別測試感受下,看哪個更適合我們。

參會的四個哥們:PHP內(nèi)置的serialize、PHP內(nèi)置的JSON解析器、PHP擴展JSOND、PHP擴展msgpack。其中前三個都是文本類型的,msgpack則是二進制類型的。

JSOND作為PHP內(nèi)置的JSON解析器的高級版本,坊間一直傳聞速度上要比內(nèi)置的更牛X一些,作為擴展,這貨需要額外安裝,附送地址:https://pecl.php.net/get/json...。

msgpack是一個鳥哥等人搞的一套二進制序列化工具,slogan就是“It"s like JSON.but fast and small.”,附送地址:https://pecl.php.net/get/msgp...

serialize用法
serialize(),序列化方法。
unserialize(),反序列化方法。

json用法
json_encode(),沒啥好說的吧?
json_decode(),沒啥好說的吧?

jsond用法
jsond_encode(),和json_encode()一樣,后面多個字母d而已。
jsond_decode(),和json_decode()一樣,后面多個字母d而已。

msgpack用法
msgpack_pack(),序列化方法。
msgpack_unpack(),反序列化方法。

測試代碼如下:

 22193123,
    "gender" => "famale",
    "username" => "elarity",
    "password" => md5("www123"),
    "relation" => array(
      array(
        "uid" => 22193123,
        "gender" => "famale",
        "username" => "elarity",
        "password" => md5("www123"),
      ),
      array(
        "uid" => 22193123,
        "gender" => "famale",
        "username" => "elarity",
        "password" => md5("www123"),
      ),
      array(
        "uid" => 22193123,
        "gender" => "famale",
        "username" => "elarity",
        "password" => md5("www123"),
      ),
      array(
        "uid" => 22193123,
        "gender" => "famale",
        "username" => "elarity",
        "password" => md5("www123"),
      ),
      array(
        "uid" => 22193123,
        "gender" => "famale",
        "username" => "elarity",
        "password" => md5("www123"),
      ),
      array(
        "uid" => 22193123,
        "gender" => "famale",
        "username" => "elarity",
        "password" => md5("www123"),
      ),
      array(
        "uid" => 22193123,
        "gender" => "famale",
        "username" => "elarity",
        "password" => md5("www123"),
      ),
      array(
        "uid" => 22193123,
        "gender" => "famale",
        "username" => "elarity",
        "password" => md5("www123"),
      ),
      array(
        "uid" => 22193123,
        "gender" => "famale",
        "username" => "elarity",
        "password" => md5("www123"),
      ),
    ),
  )
);

// 每種序列化方案都執(zhí)行100000次
$counter = 100000;

// json序列化方案,執(zhí)行100000次
echo PHP_EOL.PHP_EOL;
$start = microtime( true );
for( $i = 1; $i <= $counter; $i++ ){
  $json = json_encode( $arr ); 
}
$size = strlen( $json );
$end = microtime( true );
$cost_time = $end - $start;
echo "json_encode : 耗費時間為{$cost_time} , 數(shù)據(jù)體積為{$size}".PHP_EOL;

// jsond序列化方案,執(zhí)行100000次
$start = microtime( true );
for( $i = 1; $i <= $counter; $i++ ){
  $jsond = jsond_encode( $arr ); 
}
$size = strlen( $jsond );
$end = microtime( true );
$cost_time = $end - $start;
echo "jsond_encode : 耗費時間為{$cost_time} , 數(shù)據(jù)體積為{$size}".PHP_EOL;

// serialize序列化方案,執(zhí)行100000次
$start = microtime( true );
for( $i = 1; $i <= $counter; $i++ ){
  $serialize = serialize( $arr ); 
}
$size = strlen( $serialize );
$end = microtime( true );
$cost_time = $end - $start;
echo "serialize : 耗費時間為{$cost_time} , 數(shù)據(jù)體積為{$size}".PHP_EOL;

// msgpack序列化方案,執(zhí)行100000次
$start = microtime( true );
for( $i = 1; $i <= $counter; $i++ ){
  $msgpack = msgpack_pack( $arr );
}
$size = strlen( $msgpack );
$end = microtime( true );
$cost_time = $end - $start;
echo "msgpack耗費時間為 : {$cost_time} , 數(shù)據(jù)體積為{$size}".PHP_EOL;
echo PHP_EOL.PHP_EOL;

將文件保存為test.php,然后php test.php執(zhí)行,結(jié)果如下圖所示:

總結(jié)一下:

jsond確實是要比json快一些的

總有刁民張嘴就來json要比serialize()快

serialize()數(shù)據(jù)體積確實大(因為還保留了數(shù)據(jù)類型說明)

msgpack最佳???不知道昂,你們自己感受


補充:評論里有一條補充的很好,指出了我這里一些比較片面的內(nèi)容,大家可以補充觀看:

“可以看看我的測試:https://blog.yurunsoft.com/a/...
我選擇的數(shù)據(jù)類別相對較多,有數(shù)組有對象,有小數(shù)據(jù)有較多的數(shù)據(jù),其實固定地說哪個更好更快,沒有意義,要根據(jù)實際場景選擇合適的才好”

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/29699.html

相關(guān)文章

  • JS基礎(chǔ)篇--JS之表單提交時編碼類型enctype詳解

    摘要:格式支持比鍵值對復(fù)雜得多的結(jié)構(gòu)化數(shù)據(jù),這一點也很有用。例如下面這段代碼最終發(fā)送的請求是這種方案,可以方便的提交復(fù)雜的結(jié)構(gòu)化數(shù)據(jù),特別適合的接口。 簡介 form的enctype屬性為編碼方式,常用有兩種:application/x-www-form-urlencoded和multipart/form-data,默認為application/x-www-form-urlencoded。 ...

    ad6623 評論0 收藏0
  • PHP - Pimple 源碼筆記(上)

    摘要:也就是閑時為了寫文章而寫的一篇關(guān)于源碼的閱讀筆記。是標(biāo)準(zhǔn)庫的縮寫,一組旨在解決標(biāo)準(zhǔn)問題的接口和類的集合。提供了一套標(biāo)準(zhǔn)的數(shù)據(jù)結(jié)構(gòu),一組遍歷對象的迭代器,一組接口,一組標(biāo)準(zhǔn)的異常,一系列用于處理文件的類,提供了一組函數(shù),具體可以查看文檔。 也就是閑時為了寫文章而寫的一篇關(guān)于 Pimple 源碼的閱讀筆記。Pimple 代碼有兩種編碼方式,一種是以 PHP 編寫的,另一種是以 C 擴展編寫...

    cfanr 評論0 收藏0
  • PHP 實現(xiàn)插入排序

    摘要:插入排序插入排序英語是一種簡單直觀的排序算法。插入排序在實現(xiàn)上,通常采用排序即只需用到的額外空間的排序,因而在從后向前掃描過程中,需要反復(fù)把已排序元素逐步向后挪位,為最新元素提供插入空間。一般來說,插入排序都采用在數(shù)組上實現(xiàn)。 導(dǎo)語 關(guān)于排序的算法,就此告一段落。冒泡排序、快速排序、選擇排序、加上本篇的插入排序,這四種算法都是相對簡單,容易理解的。更復(fù)雜的算法,就不獻丑了,以免誤人子弟...

    DoINsiSt 評論0 收藏0
  • PHP面試之一:PHP基礎(chǔ)知識點

    摘要:之前,第三方編譯是管理器,是解釋器之后,官方自帶,與模式。又是解釋器,又是管理器以模塊模式運行常見配置數(shù)組排序 PHP引用變量 什么是引用變量?如何定義引用變量? 引用意味著用不同的名字訪問同一個內(nèi)容定義引用變量:使用& 引用變量的工作原理 普通變量的工作原理 $a = range(0,10000); var_dump(memory_get_usage()); //int(7420...

    waterc 評論0 收藏0

發(fā)表評論

0條評論

Wildcard

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<