php中的filesize
filesize — 取得文件大小
int filesize ( string $filename )
注意事项:
1> 对于路径中使用了“\”分隔上级目录与子目录的文件,或者是路径中包含中文字符都将会出现如下:
<?php
var_dump(filesize("E:\123.txt"));
?>
Warning: filesize() [function.filesize]: stat failed for........
2> $filename参数可以是绝对路径,也可是相对路径
3> 对于官方手册中提到的:
Note: 因为 PHP 的整数类型是有符号的,并且大多数平台使用 32 位整数,filesize() 函数在碰到大于 2GB 的文件时可能会返回非预期的结果。对于 2GB 到 4GB 之间的文件通常可以使用 sprintf("%u", filesize($file)) 来克服此问题。
ps : 这点初步测试结果是不会出错
htmlentities与htmlspecialchars的区别
php官方手册的解释:
htmlentities() 函数把字符转换为 HTML 实体。
htmlspecialchars() 函数把一些预定义的字符转换为 HTML 实体。
下面是作者的理解,如有差错,请您指明。
htmlentities 与 htmlspecialchars 在处理英文字符的时候完全一样,在处理中文字符的时候就有区别啦。
htmlentities 将会对几个特殊字符进行转换,但是遇到中文的时候,如果文件的编码与第三个参数不同就会出现乱码。
而htmlspecialchars 却只可能转换如下几个特殊字符:
& (和号) 成为 &
" (双引号) 成为 "
' (单引号) 成为 '
< (小于) 成为 <
> (大于) 成为 >
因此,对于中文不会出现乱码。请看以下代码对比:
<?php $str='<a href="test.html">测试页面</a>'; $str1 = htmlentities($str); echo $str1; //出现乱码 $str2 = htmlspecialchars($str); echo $str2; //显示正常 $str3 = htmlentities($str, ENT_COMPAT, 'utf-8'); echo $str3; //显示正常 ?>以上文件编码是:utf-8
在大多数情况下,我们都不需要对中文进行处理,所以在转换html代码的时候还是建议使用htmlspecialchars(),这样可以少些两个参数,呵呵!
PHP设计模式:单例模式
简单的说,一个对象(在学习设计模式之前,需要比较了解面向对象思想)只负责一个特定的任务;
使用类(class)来实现:
1、构造函数需要标记为private(访问控制:防止外部代码使用new操作符创建对象),单例类不能在其他类中实例化,只能被其自身实例化;
2、拥有一个保存类的实例的静态成员变量。
3、拥有一个访问这个实例的公共的静态方法(常用getInstance()方法进行实例化单例类,通过instanceof操作符可以检测到类是否已经被实例化)。
另外,需要创建__clone()方法防止对象被复制(克隆)。在其他语言比如Java中是没有这种方法,所以这时php的特别之处。
为什么要使用PHP单例模式?
1、一般情况下,php应用中会存在大量的数据库操作, 使用单例模式, 则可以避免大量的new 操作消耗的资源。
2、如果系统中需要有一个类来全局控制某些配置信息, 那么使用单例模式可以很方便的实现。
示例如下:
<?php
/**
* 服务器请求处理类
*
* TODO getSiteUrl
* @package Request
*/
class Typecho_Request
{
/**
* 单例句柄
*
* @access private
* @var Typecho_Request
*/
private static $_instance = NULL;
/**
* 构造方法
*
* @access private
*/
private function __construct() {
}
/**
* 构造方法
*
* @access private
*/
private function Typecho_Request() {
}
/**
* 获取单例句柄
*
* @access public
* @return Typecho_Request
*/
public static function getInstance()
{
if (NULL === self::$_instance) {
self::$_instance = new Typecho_Request();
}
return self::$_instance;
}
/**
* 在克隆方法中进行提示
*
* @access public
* @return void
*/
public function __clone() {
//这个根据需要进行
trigger_error("The class does't allows clone.", E_USER_ERROR);
}
}
$request = Typecho_Request::getInstance();
var_dump($request); //echo object(Typecho_Request)[1]
$request_new = new Typecho_Request();
var_dump($request_new); //error
$request_clone = clone $request;
var_dump($request_bak); //error
?>
