我不确定位掩码是否是正确的术语。让我解释一下:
在php中,可以通过多种方式调用error_reporting
函数:
// Report simple running errors
error_reporting(E_ERROR | E_WARNING | E_PARSE);
// Reporting E_NOTICE can be good too (to report uninitialized
// variables or catch variable name misspellings ...)
error_reporting(E_ERROR | E_WARNING | E_PARSE | E_NOTICE);
// Report all errors except E_NOTICE
// This is the default value set in php.ini
error_reporting(E_ALL ^ E_NOTICE);
我从php.net页面here获得了术语位掩码
无论如何,重点是,我已经实现了一个名为ls
的简单方法,它返回目录的内容。
此函数需要3个参数...( $include_hidden = false,$return_absolute = false,$ext = false )
因此,当我调用函数时,我设置了我想要的结果。我是否想让结果返回隐藏目录,是否只想要基本名称等。
因此,当我调用我正在编写的函数时
ls(true, false, true)
ls(false, false, true)
ls(true, true, true)
etc...
我想如果我能标记出我想要的数据返回方式,它会更具可读性。
所以就像这样:
ls( INCLUDE_HIDDEN | HIDE_EXTS );
ls( SHOW_ABSOLUTE_PATHS | HIDE_EXTS );
等等。
在测试调用了哪些标志时,我该如何实现这一点?
发布于 2012-08-09 17:30:15
实际上,这很简单。首先用一些代码来演示它是如何实现的。如果您对这段代码的功能或工作原理一无所知,可以在评论中提出其他问题:
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!<br>\n";
}
if ($flags & FLAG_2) {
echo "You passed flag 2!<br>\n";
}
if ($flags & FLAG_3) {
echo "You passed flag 3!<br>\n";
}
if ($flags & FLAG_4) {
echo "You passed flag 4!<br>\n";
}
}
show_flags(FLAG_1 | FLAG_3);
因为标志是整数,所以在32位平台上最多可以定义32个标志。在64位平台上,它是64。也可以将标志定义为字符串,在这种情况下,可用标志的数量或多或少是无限的(当然,在系统资源的范围内)。以下是它在二进制中的工作方式(为简单起见,减少到8位整数)。
FLAG_1
Dec: 1
Binary: 00000001
FLAG_2
Dec: 2
Binary: 00000010
FLAG_3
Dec: 4
Binary: 00000100
// And so on...
当您组合这些标志以将它们传递给函数时,您将它们一起进行OR运算。让我们来看看当我们传递FLAG_1 | FLAG_3
时会发生什么
00000001
| 00000100
= 00000101
当您想要查看设置了哪些标志时,您可以将位掩码与标志一起使用。因此,让我们看看上面的结果是否设置了FLAG_3
:
00000101
& 00000100
= 00000100
...we获取标志的值,一个非零整数-但如果我们查看是否设置了FLAG_2
:
00000101
& 00000010
= 00000000
...we得到零。这意味着在检查是否传递了值时,您可以简单地将AND运算的结果作为布尔值进行计算。
发布于 2012-08-09 17:29:24
define( "INCLUDE_HIDDEN", 0x1 );
define( "HIDE_EXTS", 0x2 );
define( "SHOW_ABSOLUTE_PATHS", 0x4 );
//And so on, 0x8, 0x10, 0x20, 0x40, 0x80, 0x100, 0x200, 0x400, 0x800 etc..
然后,您可以检查ls
函数中的各个标志:
if( $flags & INCLUDE_HIDDEN ) { //<-- note just a single &, bitwise and
//$flags have INCLUDE_HIDDEN
}
https://stackoverflow.com/questions/11880360
复制相似问题