這篇文章帶給大家的內容是關於php中small記憶體規格的計算(程式碼範例),有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。
small記憶體分配計算bin_num
在PHP原始碼中,有一段對small記憶體規格的計算,具體在Zend/zend_alloc.c的zend_mm_small_size_to_bin函數中,其目的是傳入一個size ,計算對應的規格。見程式碼:
if (size > 3; } else { t1 = size - 1; t2 = zend_mm_small_size_to_bit(t1) - 3; t1 = t1 >> t2; t2 = t2 - 3; t2 = t2 <p>可以看出,這段程式碼中分為兩種情況來討論:</p>
-
1、size小於等於64的情況;
2、size大於64的情況;
在下面我們對這兩種情況詳細分析下。
對於size小於等於64的情況
看
ZEND_MM_BINS_INFO
這個巨集知道當size小於等於64的情況是等差數列,遞增8,所以使用size除以8就行(源碼中是右移3位)size >> 3
但是要考慮到size等於8、 16等的情況,所以為
(size - 1) >> 3
然後要考慮到為0的情況,所以原始碼中對於
-1
的處理是!!size
,當size為0的情況!!0 = 0
。所以當size為0的情況就把-1
轉換成了-0
,最後有了原始碼中的表達式(size - !!size) >> ; 3
對於size大於64的情況
t1 = size - 1; t2 = zend_mm_small_size_to_bit(t1) - 3; t1 = t1 >> t2; t2 = t2 - 3; t2 = t2 <h4 id="初始懵逼">初始懵逼</h4>
- ##初看這個程式碼,容易一臉懵逼,這些t1 t2 都是啥啊
- #不過不用怕,我們一點點來分析 ##步驟分析
/* num, size, count, pages */ #define ZEND_MM_BINS_INFO(_, x, y) \ _( 0, 8, 512, 1, x, y) \ _( 1, 16, 256, 1, x, y) \ _( 2, 24, 170, 1, x, y) \ _( 3, 32, 128, 1, x, y) \ _( 4, 40, 102, 1, x, y) \ _( 5, 48, 85, 1, x, y) \ _( 6, 56, 73, 1, x, y) \ _( 7, 64, 64, 1, x, y) \ _( 8, 80, 51, 1, x, y) \ _( 9, 96, 42, 1, x, y) \ _(10, 112, 36, 1, x, y) \ _(11, 128, 32, 1, x, y) \ _(12, 160, 25, 1, x, y) \ _(13, 192, 21, 1, x, y) \ _(14, 224, 18, 1, x, y) \ _(15, 256, 16, 1, x, y) \ _(16, 320, 64, 5, x, y) \ _(17, 384, 32, 3, x, y) \ _(18, 448, 9, 1, x, y) \ _(19, 512, 8, 1, x, y) \ _(20, 640, 32, 5, x, y) \ _(21, 768, 16, 3, x, y) \ _(22, 896, 9, 2, x, y) \ _(23, 1024, 8, 2, x, y) \ _(24, 1280, 16, 5, x, y) \ _(25, 1536, 8, 3, x, y) \ _(26, 1792, 16, 7, x, y) \ _(27, 2048, 8, 4, x, y) \ _(28, 2560, 8, 5, x, y) \ _(29, 3072, 4, 3, x, y) #endif /* ZEND_ALLOC_SIZES_H */
- size = size - 1;
這個是邊界情況,跟前面一樣,後面出現的size暫且都認為已近減一了
#假設不看這個原始碼,我們要實作在 - ZEND_MM_BINS_INFO
中找到對應的bin_num
##由 ZEND_MM_BINS_INFO - 得知後續的增加4個為一組,分別為
2^4, 2^5, 2^6...
- 找到這個size屬於哪一組
- 並且size在群組內的偏移量是多少
- 計算組的起始位置
- 那現在問題轉換成了上面3個小問題,我們一個一個來解決
- 找到size屬於哪一組
- 我們看十進位看不出來什麼名堂,就把這些值轉成二進位看看吧
-
64 | 100 0000 80 | 101 0000 96 | 110 0000 112 | 111 0000 128 | 1000 0000 160 | 1010 0000 192 | 1100 0000 224 | 1110 0000 256 | 1 0000 0000 320 | 1 0100 0000 384 | 1 1000 0000 448 | 1 1100 0000 .....
- 那就是說我們可以計算二進制的長度來決定它的分組,那麼二進制的長度又是啥呢,其實就是當前二進制的最高位為 1
- 的位數
1##那麼問題又轉換成了求二進位中最高位元的
的位元數 -
1下面給出php原始碼的解法,這裡暫時不對其解析,只要知道它傳回的是二進位中最高位的
的位數 <pre class="brush:php;toolbar:false">int n = 16; if (size </pre>
#假設我們申請的size為65,那麼這裡的n回傳7
計算size在群組內的偏移量
這個簡單,直接用size減去每組的起始siez大小然後除以目前群組內的差值(16、32、64...)即可,也就是
(size-64)/16 (size-128)/32 (size-256)/64-
#現在來看看上一個步驟中的回傳的值,每個組分別是
,那我們現在來看看這樣的資料怎麼計算組內的偏移量 <pre class="brush:php;toolbar:false">(size - 2^4 * 4) / 16 = size / 2^4 - 4 (size - 2^5 * 4) / 32 = size / 2^5 - 4 (size - 2^6 * 4) / 64 = szie / 2^6 - 4</pre>
那是不是可以用
- 減去
- 3
得到
4、5、6
,這樣我們就可以根據它在哪一組的資訊來得到目前組的差值(16、32、64...) -
(64-64) / 2^4 = 0
計算群組的起始位置
現在我們有了偏移量的信息,假定我們分組是1、2、3
-
那是不是就是用最高位的
1 的位數減去 - 6
就可以得到分組資訊了
得到分組資訊之後,怎麼知道每組的起始位置呢
- ##我們知道起始位置分別是
8、12、16...
它也是一個等差數列,就是 4n 4 我們在看看size=65的那個例子
计算的偏移量是0
计算的起始位置是
4*1 + 4 = 8
所以当size=65的bin_num就是起始位置加上偏移量
8 + 0 = 8
我们再看一个size=129的例子
二进制中最高位的
1
的位数为8然后用8减去3得到5
(129 - 1 - 32 * 4) / 64 = 0
偏移量是
计算起始位置是
4 * 2 + 4 = 12
两者相加就是
12 + 0 = 0
size=193
二进制中最高位的
1
的位数为8(193 - 1 - 32 * 4) / 64 = 2
偏移量是
计算起始位置是
4 * 2 + 4 = 12
两者相加就是
12 + 2 = 14
size=1793
二进制中最高位的
1
的位数为11(1793 - 1 - 256 * 4) / 256 = 3
偏移量是
计算起始位置是
4 * 5 + 4 = 24
两者相加就是
24 + 3 = 27
代码分析
php实现代码
1 t1 = size - 1; 2 t2 = zend_mm_small_size_to_bit(t1) - 3; 3 t1 = t1 >> t2; 4 t2 = t2 - 3; 5 t2 = t2 <h4 id="第一行">第一行</h4>
t1 = size - 1;
是为了考虑size为64、128...这些边界情况
第二行
t2 = zend_mm_small_size_to_bit(t1) - 3;
这里调用了
zend_mm_small_size_to_bit
这个函数,我们看看这个函数
/* higher set bit number (0->N/A, 1->1, 2->2, 4->3, 8->4, 127->7, 128->8 etc) */ int n = 16; if (size
看注释我们就知道这个函数是用来返回当前size二进制中最高位1的位数,具体的做法呢其实就是二分法
-
我们通过
zend_mm_small_size_to_bit
这个函数获取了size二进制中最高位1的位数,那么这个-3
是什么神奇的操作呢(size - 2^4 * 4) / 16 = size / 2^4 - 4 (size - 2^5 * 4) / 32 = size / 2^5 - 4 (size - 2^6 * 4) / 64 = szie / 2^6 - 4
这里获取二进制的位数是7、8、9...通过
-3
的操作来获取相应的 4、5、6...上问的分析中提到,我们计算size在组内的偏移量的公式
第三行
t1 = t1 >> t2;
把t1右移t2位,这又是什么神奇的操作?
这里我们把最后计算bin_num的数学公式给写出来,它是等于每组的起始位置加上组内的偏移量
binnum = (4n + 4) + (size / 2^n - 4) binnum = 4n + size / 2^n
所以第三行的意思我们就知道了,就是size右移2^n次方为
第四行
t2 = t2 - 3;
这个好理解,可以参照上文得到每组的起始位置的方法
第五行
t2 = t2
我们再看看bin_num的计算公式
binnum = (4n + 4) + (size / 2^n - 4) binnum = 4n + size / 2^n
那么这行就好理解了,就是计算每组的起始位置
4n
对吧,左移两位就是乘以4
第六行
return (int)(t1 + t2);
这行没啥说的,就是返回了一个int类型的bin_num
以上是php中small記憶體規格的計算(程式碼範例)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

使用數據庫存儲會話的主要優勢包括持久性、可擴展性和安全性。 1.持久性:即使服務器重啟,會話數據也能保持不變。 2.可擴展性:適用於分佈式系統,確保會話數據在多服務器間同步。 3.安全性:數據庫提供加密存儲,保護敏感信息。

在PHP中實現自定義會話處理可以通過實現SessionHandlerInterface接口來完成。具體步驟包括:1)創建實現SessionHandlerInterface的類,如CustomSessionHandler;2)重寫接口中的方法(如open,close,read,write,destroy,gc)來定義會話數據的生命週期和存儲方式;3)在PHP腳本中註冊自定義會話處理器並啟動會話。這樣可以將數據存儲在MySQL、Redis等介質中,提升性能、安全性和可擴展性。

SessionID是網絡應用程序中用來跟踪用戶會話狀態的機制。 1.它是一個隨機生成的字符串,用於在用戶與服務器之間的多次交互中保持用戶的身份信息。 2.服務器生成並通過cookie或URL參數發送給客戶端,幫助在用戶的多次請求中識別和關聯這些請求。 3.生成通常使用隨機算法保證唯一性和不可預測性。 4.在實際開發中,可以使用內存數據庫如Redis來存儲session數據,提升性能和安全性。

在無狀態環境如API中管理會話可以通過使用JWT或cookies來實現。 1.JWT適合無狀態和可擴展性,但大數據時體積大。 2.Cookies更傳統且易實現,但需謹慎配置以確保安全性。

要保護應用免受與會話相關的XSS攻擊,需採取以下措施:1.設置HttpOnly和Secure標誌保護會話cookie。 2.對所有用戶輸入進行輸出編碼。 3.實施內容安全策略(CSP)限制腳本來源。通過這些策略,可以有效防護會話相關的XSS攻擊,確保用戶數據安全。

优化PHP会话性能的方法包括:1.延迟会话启动,2.使用数据库存储会话,3.压缩会话数据,4.管理会话生命周期,5.实现会话共享。这些策略能显著提升应用在高并发环境下的效率。

theSession.gc_maxlifetimesettinginphpdeterminesthelifespanofsessiondata,setInSeconds.1)它'sconfiguredinphp.iniorviaini_set().2)abalanceisesneededeededeedeedeededto toavoidperformance andunununununexpectedLogOgouts.3)

在PHP中,可以使用session_name()函數配置會話名稱。具體步驟如下:1.使用session_name()函數設置會話名稱,例如session_name("my_session")。 2.在設置會話名稱後,調用session_start()啟動會話。配置會話名稱可以避免多應用間的會話數據衝突,並增強安全性,但需注意會話名稱的唯一性、安全性、長度和設置時機。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)