php获取掩码,如何在PHP中实现位掩码?
這很簡單。首先一點代碼演示如何實現(xiàn)。如果你不明白這個代碼是做什么或它的工作原理,請隨時在評論中提出其他問題:
const FLAG_1 = 0b0001; // 1
const FLAG_2 = 0b0010; // 2
const FLAG_3 = 0b0100; // 4
const FLAG_4 = 0b1000; // 8
// Can you see the pattern? ;-)
function show_flags ($flags) {
if ($flags & FLAG_1) {
echo "You passed flag 1!
\n";
}
if ($flags & FLAG_2) {
echo "You passed flag 2!
\n";
}
if ($flags & FLAG_3) {
echo "You passed flag 3!
\n";
}
if ($flags & FLAG_4) {
echo "You passed flag 4!
\n";
}
}
show_flags(FLAG_1 | FLAG_3);
由于標志是整數(shù),因此在32位平臺上最多可定義32個標志。在64位平臺上,它是64.也可以將標志定義為字符串,在這種情況下,可用標志的數(shù)量或多或少是無限的(當然在系統(tǒng)資源的范圍內(nèi))。這里是它的工作原理在二進制(簡化為8位整數(shù))。
FLAG_1
Dec: 1
Binary: 00000001
FLAG_2
Dec: 2
Binary: 00000010
FLAG_3
Dec: 4
Binary: 00000100
// And so on...
當你組合標志傳遞給函數(shù),你或他們在一起。讓我們來看看當我們通過FLAG_1 |時會發(fā)生什么FLAG_3
00000001
| 00000100
= 00000101
當你想看看設(shè)置了哪些標志,你和位掩碼與標志。所以,讓我們把上面的結(jié)果,看看FLAG_3是否設(shè)置:
00000101
& 00000100
= 00000100
…我們得到的標志的值,一個非零整數(shù) – 但如果我們看到如果FLAG_2被設(shè)置:
00000101
& 00000010
= 00000000
…我們得到零。這意味著,在檢查該值是否被傳遞時,您可以簡單地將AND運算的結(jié)果評估為布爾值。
總結(jié)
以上是生活随笔為你收集整理的php获取掩码,如何在PHP中实现位掩码?的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 迅捷 FW325R 无线路由器IP与MA
- 下一篇: 搜狗输入法如何设置键盘皮肤和透明度?