seft和static在php中有什么不同

seft和static返回的结果是否相同? 不尽然。但我不知道在php5.2中是怎么样的。 self指的是定义产生new操作的方法的那个类(定义那个方法的类)。 static在php5.3以后静态绑定指的是你在哪个层次中调用方法的类(实际调用的类)。 在下面的例子中,我们可以更好的理解。B从A继承两个方法。seft界定为A因为他是定义在A类的第一个方法的执行中的,然而 static 是界定在调用他的类的内的(查看get_called_class())。 class A {     public static function get_self() {         return new self();     }     public static function get_static() {         return new static();     } } class B extends A {} echo get_class(B::get_self());  // A echo get_class(B::get_static()); // B echo get_class(A::get_static()); // A ......

用php快速获取图片大小

用getimagesize函数获取图片大小(图片尺寸,宽和高),如果有上百个的话,那速度太慢了。 function ranger($url){     $headers = array(     "Range: bytes=0-32768"     );     $curl = curl_init($url);     curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);     curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);     $data = curl_exec($curl);     curl_close($curl);     return $data; } $start = microtime(true); $url = "http://news.softpedia.com/images/news2/Debian-Turns-15-2.jpeg"; $raw = ranger($url); $im = imagecreatefromstring($raw); $width = imagesx($im); $height = imagesy($im); $stop = round(microtime(true) - $start, 5); echo $width." x ".$height." ({$stop}s)";   测试 640 x 480 (0.20859s) 加载的数据量为32kb。 ......

用php的json_decode()检测json数据是否合法

要实现类似下面的功能 if(!json_decode($_POST)) {   echo "bad json data!";   exit; } 如果json格式不合法,给出提示,退出。但上面的代码可能给有下面的提示: Warning: json_decode() expects parameter 1 to be string, array given in C:\server\www\myserver.dev\public_html\rivrUI\public_home\index.php  on line 6 bad json data! 更好的解决方法是: $_POST = array(     'bad data' ); $data = @json_decode($_POST); 可能的情况是: 当格式是错误的,返回NULL,正确的话返回数据给$data。 当没有错误的情况下,也可能返回NULL,当JSON字符串包含null。 产生一个警告,用@抑制警告信息的输出。(实际上我不建议经常使用它,因为它使调试运行了很多困难......但在这里,没有多少选择的余地) 然后,你有必要测试,如果$data为空的情况,json_decode返回的信息,你可以检查json_last_error。   JSON解析发生返回最后一个错误(如果有的话) 这意味着你不得不使用下面的代码: if ($data === null     && json_last_error() !== JSON_ERROR_NONE) {     echo "incorrect data"; } ......

php三个等号

实例: $a===$b;//(相同)TRUE,如果$a等于$b,并且它们是同一类型的。(PHP 4引​​进) ===的含义是两个变量一仅值相等,而且他们的数据类型也是相同的。如果两个条件都符合,返回TRUE。 例如: 3===3 // true 3==="3" //false ......

unset和=null有什么不同

unset和=null两者最重要的不同是unset($a)会从实例表中删除$a;例如: $a = str_repeat('hello world ', 100); unset($a); var_dump($a); 输出: Notice: Undefined variable: a in xxx NULL 但当$a = null时: $a = str_repeat('hello world ', 100); $a = null; var_dump($a); 输出: NULL 通过对unset($a)和$a=null在同一基准下运行发现$a=null比unset($a)快大约6%。看来从实例表更新比从其中删除更快。 补充: 其他不同之处(如这段代码所示)观察每个调用后内存恢复的数量。 echo memory_get_usage(), PHP_EOL; $a = str_repeat('hello world ', 100); echo memory_get_usage(), PHP_EOL; // EITHER unset($a); OR $a = null; echo memory_get_usage(), PHP_EOL; 当用unset() 64 bytes的内存被返还。而$a=null;会释放内存272 bytes。我没有足够的知识,理解为什么有这两种方法会有208个字节的区别,但它仍然是一个差异。 ......
<<  1  2  3  4  5  6  >>
京ICP备14008139号-1