国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

PHP7在內存方面你是否知道都進行了哪些優化

冬至配餃子 ? 來源:開發內功修煉 ? 作者:張彥飛allen ? 2022-08-30 17:08 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

前面我們討論了內存的工作原理,也進行了一些性能相關的測試。那么今天開始我們來看幾個在實踐中的應用。首先我們先從PHP開始。2015年,PHP7的發布可以說是在技術圈里引起了不小的轟動,因為它的執行效率比PHP5直接翻了一倍。PHP7在內存方面,你是否知道作者都進行了哪些優化?幾個核心結構體的改進只是表面上看起來優化的幾個字節那么簡單?讓我們從幾個核心的數據結構改進開始看起。

1 PHP7zval的變化

1、php5.3中的zval:

pYYBAGMN0taADI7ZAACph_e53O8634.png

我們這里只討論64位操作系統下的情況。該zval_struct結構體中的由四個成員構成,其中zvalue_value稍微復雜一些,是一個聯合體。聯合體中最長的成員是一個指針加一個int,8+4=12字節。但是默認情況下,會進行內存對齊,故zval_struct會占用16字節。那么。

_zval_struct總的字節 = value(16)+ refcount__gc(4)+ type(1)+ is_ref__gc(1)= 占用22字節。

最后再考慮下內存對齊,實際占用24字節。(如果算的有點暈話,感興趣的同學可以寫段簡單的測試代碼,使用sizeof查看一下)

2、PHP7.2中的zval

poYBAGMN0uyAUol1AADs2EZskZs450.png

7.2中的zval_struct結構體里由3個成員構成,其中zend_value看起來比較復雜,實際上只是一個8字節的聯合體。u1也是一個聯合體,占用是4個字節。u2也一樣。這樣zval_struct就實際占用16個字節。

2 PHP7 HashTable的變化

1、PHP5.3里的HashTable:

pYYBAGMN0v-AGU2NAACNlGKBu8M639.png

在5.3里HashTable就是一個大struct, 有點小復雜,我們拆開了細說,

uint nTableSize 4字節

uint nTableMask 4字節

uint nNumOfElements 4字節,

ulong nNextFreeElement 8字節 注意這前面的4個字節會被浪費掉,因為nNextFreeElement的開始地址需要對齊

Bucket *pInternalPointer 8字節

Bucket *pListHead 8字節

Bucket *pListTail 8字節

Bucket **arBuckets 8字節

dtor_func_t pDestructor 8字節

zend_bool persistent 1字節

unsigned char nApplyCoun 1字節

zend_bool bApplyProtection 1字節

最終,總字節數 = 4+4+4+4(nNextFreeElement前面這四個字節會留空)+8+8+8+8+8+8+1+1+1 = 67字節。再加上結構體本身要對齊到8的整數倍,所以實際占用72字節。

2、PHP7.2里的HashTable:

pYYBAGMN0xKAQDrkAACWEr2NQKE768.png

在7.2里HashTable

zend_refcounted_h gc 看起來唬人,實際就是個long,占用8字節

union... u 占用4字節

uint32_t 占用4字節

Bucket* 指針占用8字節

uint32_t nNumUsed 占用4字節

uint32_t nNumOfElements 占用4字節

uint32_t nTableSize 占用4字節

uint32_t nInternalPointer 占用4字節

zend_long nNextFreeElement 占用8字節

dtor_func_t pDestructor 占用8字節

總占用

字節數 = 8+4+4+8+4+4+4+4+8+8 = 56字節,并且正好達到了內存對齊的狀態,沒有額外的浪費。

另外還有PHP源代碼里經常出鏡的Buckets也從72下降到了32字節,這里我就不翻源代碼了。

3 優化思想精髓

當當當,敲黑板,重點來了!我們看了兩個核心數據結構的結構體變化,這上面的優化都是什么含義呢?拿HashTable舉例,貌似從72字節優化到了56字節,這內存節約的也不是特別多嘛,才20%多而已!但這中間其實隱藏了兩個較深層次優化思路:

第一、你是否記得我們前面CPU在向內存要數據的時候是以Cache Line為單位進行的,而我們說過Cache Line的大小就是64字節。回過頭來看HashTable,在7.2里的56字節,只需要CPU向內存進行一次Cache Line大小的burst IO,就夠了。而在5.3里的72字節,雖然只比Cache Line大了那么一丟丟,但是對不起,必須得進行兩次burst IO才可以。所以,在計算機里,56字節相對72字節實際上是翻倍的性能提升!!

第二、CPU的L1、L2、L3的容量是固定的幾十K或者幾十M。假設Cache的都是HashTable,那么Cache容量不變的條件下,能Cache住的HashTable將會翻倍,緩存命中率提升一大截。要知道L1命中后只需要1ns多一點的耗時,而如果穿透到內存的話可能就需要40多納秒的延時了,整整差了幾十倍。

所以PHP內核的作者大牛深諳CPU與內存的工作原理,表面上看起來只是幾個字節的節約,但是實際上爆發出了巨大的性能提升!!



審核編輯:劉清

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • cpu
    cpu
    +關注

    關注

    68

    文章

    11279

    瀏覽量

    224964
  • 內存
    +關注

    關注

    9

    文章

    3210

    瀏覽量

    76361
  • 操作系統
    +關注

    關注

    37

    文章

    7402

    瀏覽量

    129288
  • PHP
    PHP
    +關注

    關注

    0

    文章

    462

    瀏覽量

    28622
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    容易造成單片機內存溢出的幾個陷阱介紹

    久了就極有可能會導致內存的泄露(重啟一下就能解決90%的問題根源),同時我們在釋放的時候也要注意釋放的內存只能釋放一次,不要重復的釋放,有的時候代碼量會比較大,所以有可能會在不止一處地方進行了代碼
    發表于 01-23 07:25

    keil中c語言的動態分配內存

    開辟,所以只用進行一次內存釋放;而第二種方法進行了兩次動態內存開辟,并且其中一次是對結構體內部成員進行的,如果我們的代碼是在一個給別人用的函
    發表于 01-21 06:04

    新思科技助力UCIe 3.0快速落地

    芯片已從單一整體式芯片發展為集成多個芯粒的 Multi-Die 設計,其中每個芯粒針對處理、內存和數據傳輸等特定功能進行了優化
    的頭像 發表于 11-30 10:01 ?702次閱讀

    請問Keil的優化等級到底該如何選擇?

    做任何優化。代碼的執行順序與源代碼完全一致,變量始終存儲在內存中(不進行寄存器優化),函數調用棧幀清晰。 -O1 (有限優化 / Opti
    發表于 11-20 07:51

    通過優化代碼來提高MCU運行效率

    內存訪問優化 充分利用緩存:如果MCU有Cache,盡量保證代碼和數據的局部性,即讓相關的數據在內存中連續存放。 避免內存碎片:在動態內存
    發表于 11-12 08:21

    蜂鳥E203內核優化方法

    對蜂鳥E203內核進行優化可以考慮以下幾個方面: 編譯器優化:使用適合蜂鳥E203的編譯器選項和指令集,優化編譯器的選項和參數,開啟對硬件的
    發表于 10-21 07:55

    知道板卡廠商參與芯片研發的α階段意味著什么?

    大家知道芯片很重要,但是否知道一顆芯片從設計構思到最終量產,需要經歷怎樣一個漫長的過程嗎?
    的頭像 發表于 09-24 17:08 ?7607次閱讀
    <b class='flag-5'>你</b><b class='flag-5'>知道</b>板卡廠商參與芯片研發的α階段意味著什么?

    SOLIDWORKS2025在性能和響應速度方面進行了大幅提升

    在工程設計領域,軟件的性能和響應速度是衡量其效率與用戶體驗的重要指標。SOLIDWORKS作為CAD軟件之一,始終致力于為用戶提供更有效、更穩定的設計平臺。隨著solidworks2025版本的發布,其在性能和響應速度方面實現了顯著提升,為全球設計師和工程師們帶來了流暢設計體驗。
    的頭像 發表于 08-06 10:25 ?1041次閱讀

    TPS62684 1600mA 高效降壓轉換器,針對小尺寸解決方案進行了優化數據手冊

    進行了優化, 支持高達 1600mA 的負載電流,并允許使用低成本的片式電感器和電容器。 該器件的輸入電壓范圍為 3.25V 至 5.5V,支持由鋰離子供電的應用 電池以及 5V 導軌。
    的頭像 發表于 06-25 13:41 ?646次閱讀
    TPS62684 1600mA 高效降壓轉換器,針對小尺寸解決方案<b class='flag-5'>進行了</b><b class='flag-5'>優化</b>數據手冊

    請問如何優化OpenVINO?工具套件中的內存使用?

    運行OpenVINO?推斷時找不到優化內存使用情況的方法。
    發表于 06-25 06:56

    鴻蒙5開發寶藏案例分享---內存優化實戰指南

    就是的 App變卡、變慢、甚至直接閃退 !想象一下手機后臺在瘋狂“打掃衛生”,的應用能不卡嗎? 優化內存的好處: 應用更流暢(絲滑!)、響應更快、系統資源占用少、設備續航更久(用戶
    發表于 06-12 17:15

    HarmonyOS優化應用內存占用問題性能優化

    一、使用purgeable優化C++內存 Purgeable Memory是HarmonyOS中native層常用的內存管理機制,可用于圖像處理的Bitmap、流媒體應用的一次性數據、圖片等
    發表于 05-24 17:20

    HarmonyOS優化應用內存占用問題性能優化

    一、 概述 用戶功能的不斷增強,應用越來越復雜,占用的內存也在不斷膨脹,而內存作為系統的稀缺資源比較有限,當應用程序占用過多內存時,系統可能會頻繁進行內存回收和重新分配,導致應用程序的
    發表于 05-21 11:27

    SOLIDWORKS?2025在電氣設計與仿真方面進行了優化

    隨著科技的飛速發展,工程設計領域對電氣設計與仿真工具的要求日益提高。SOLIDWORKS作為三維CAD設計和仿真分析軟件,始終致力于通過技術創新推動行業發展。2025年推出的SOLIDWORKS?2025版本,在電氣設計與仿真方面實現了諸多突破和優化,為用戶提供了更加有效
    的頭像 發表于 04-25 10:46 ?922次閱讀
    SOLIDWORKS?2025在電氣設計與仿真<b class='flag-5'>方面</b><b class='flag-5'>進行了</b><b class='flag-5'>優化</b>

    iMX8MPlus SoC M7核心是否需要單獨的RAM內存

    對于 iMX8MPlus SoC ,M7 核心是否需要單獨的 RAM 內存?或者是否有用于 M7內核的內部 SRAM?
    發表于 03-28 08:03