周末梳理了下这段时间看书的一些知识点,进步的过程不仅要实践,还要安排多看书、思考、总结。
只针对知识点进行了罗列和简单说明,很多细节还未整理好,待后面再专门详细写。
基础易忽略概念
php是一个支持面向对象开发的语言,而不是一个纯面向对象的语言
php5中保留了对var的支持,但会将var自动转换为public
类型检查函数:
is_bool()is_integer()is_double()is_string()is_object()is_array()is_resource()is_null()
php魔术方法:
__call()__callstatic() (必须是static属性)__set()__get()__isset()__clone()__tostring()
字符串false在比较操作时会解析为true,因为php在测试变量时会转换一个非空字符串值为bool值true
静态方法是以类作用域的函数。静态方法不能访问这个类中的普通属性,因为那些属性属于一个对象,但可以访问静态属性(不能在静态方法中使用伪变量$this)
常量属性只包含基本数据类型的值,不能将一个对象指派给常量
抽象类(abstract class)不能被直接实例化,只定义(或部分实现)子类需要的方法
抽象类至少包含一个抽象方法
static类似于self,但它指的是被调用的类而不是包含类
return new static()
复制对象(设计模式中的原型模式):
$first = new classname();$second = $first;//在php5以后的版本中,$second 和 $fitst指向同一个对象 $third = clone $first; //使用clone进行值复制//在php5以后的版本中,$third和$first是两个不同的对象/*控制复制什么: 可以实现一个__clone()方法 比如待复制的对象中有个$id=1,可我们希望此id唯一,不希望clone此id,可以在类中自己实现clone方法*/
回调、匿名函数:
is_callable();call_user_func($funcname,$param); //单个参数call_user_func_array($funcname,$arrparam); //参数是数组的形式
命名空间namespace:
命名空间是一个容器,在命名空间之外,必须导入或引用命名空间才能访问它所包含的项。
namespace com\name\test1;class debug{ static function test();}
namespace test2;//调用test1命名空间中的test方法\com\name\test1\debug::test(); //最前面必须加上 / 否则会在test2下寻找此命名空间 use com\name\test1;test1\debug::test();
解决类命名冲突:
use com\name\test1\debug as udebug;class debug{...}udebug::test(); __namespace__ //输出当前的命名空间
命名空间加大括号形式:
namespace com\name\test1{ class debug1{...} class debug2{...}}
require()调用文件发生错误时,将会停止整个程序,
调用include()时遇到相同的错误,会生成警告并停止执行包含文件,跳出调用代码然后继续执行。
require()和require_once()用于包含库文件时更加安全,include()和include_once()适用于加载模板等操作
相对require()函数,require_once()需要额外的开销
自动加载autoload:
当php引擎遇到试图实例化未知类的操作时,会调用__autoload()方法(需提前定义),并将类名当作字符串参数传递
例如:
function __autoload($classname){ //将$classname中的下划线转换为目录分割 $path = str_replace('_',directory_separator,$classname); require_once($path.php);}
__autoload方法是一种根据类和文件的结构,管理类库文件包含的有效方法。
类函数:
class_exists();get_declared_classes(); //获得脚本进程中定义的所有类的数组get_class($obj); //检查对象的类,检查对象所属的类$obj instalceof classname; //检查对象 get_class_methods(); //获取一个类中所有的方法列表 is_callable()、method_exists() //检查类方法是否存在且可被调用#一个方法存在并不以为着可调用,对private、protected、public方法,method_exists()都返回true get_class_vars($classname); //获取类中定义的属性get_parent_class($classna,e); //获取一个类的父类is_subclass_of($classname , 'classstrname'); //检查类是否是另一个类的派生类class_implements($classname); //返回一个由接口名组成的数组
反射api
根据到达地找到出发地和来源,反射指在php运行状态中扩展分析php程序,导出或提取出关于类、方法、属性、参数等的详细信息,包括注释。这种动态获取信息以及动态调用对象方法的功能称为反射api
使用反射api可以对文件里的类进行扫描,逐个生成描述文件
面向对象设计的五大原则:
单一职责原则接口隔离原则开放-封闭原则替换原则依赖-倒置原则
sql优化的10个原则:
不要在列上进行函数运算,导致索引失败使用join时,应用小结果集驱动大结果集。把复杂的join查询拆分为多条sql使用like模糊查询时,避免%%,可替换为=select后仅列出需要的字段,对速度不会有明显影响,主要考虑节省内存使用批量插入语句,比依次执行单个插入节省交互limit的技术比较大时考虑使用between不要使用rand函数获取多条随机记录避免使用null不要使用count(id),而是count(*)尽可能在索引中完成排序缓存的三个要素:
命中率缓存更新策略缓存最大数据量通常缓存更新策略有:
fifo(先进先出)lru(最近最少淘汰策略)lfu(最少使用淘汰策略)mysql 的 query cache使用的是fifo策略
缓存的最大数据量是在缓存中能够处理元素的最大数或所能使用的最大存储空间
超过缓存机制允许的最大数据量系统会进行相应的处理,一般处理方式有:
停止缓存服务器,清空所有缓存数据拒绝写入,不再对缓存数据进行更新根据缓存更新策略清除旧数据基于3的方式,对淘汰的数据进行备份opcode缓存:
虚拟机把php代码编译成一种中间码的结果缓存起来,下次php运行此页面时,只要直接解释这些代码就行了。
eaccelerator工具能起到常驻内存的作用
客户端缓存、http缓存(待记录)
h5中的application cache:
用来处理离线应用中的问题,用户不能联网时依然能浏览整个站点
需要在html中指定页面是否需要此缓存:
memcached
使用memcached:
对数据库的高并发读写对海量数据处理memcached是高性能的分布式内存缓存服务器,通过缓存数据库查询结果,减少数据库访问次数。
memcached特点:
协议简单基于libevent的事件处理内置内存存储方式采用不互相通信的分布式以守护进程方式运行与一个或多个服务器中memcached使用lru算法淘汰数据缓存不支持数据持久化memcached把数据存储在内存中,所以重启memcached或者操作系统会导致数据全部消失
安装memcached:
apt-get install memcached
启动memcached:
memcached -d -m 128 -u root -p 11211
-d:守护进程方式运行
-m:设置memcached可使用的内存大小,单位是mb
-l:设置监听的ip地址,本机可默认不设置
-u:指定用户
-p:设置监听的端口,默认为11211
安装php的memcached扩展:
sudo apt-get install php5-memcache
memcached扩展的一些方法:
memcache::connect(string $host [, int $port [ , int $timeout]]); //连接mem服务器 $timeout为连接持续时间,默认为1秒。过长的时间会倒置失去所有缓存的优势
memcache::addserver(string $host [ , $port [ , $bool $persistent [ , $weight [, int $timeout [, int $retry_interval [ , bool $status [ , callback $failure_callback]]]]]]]); //向对象添加一个服务器memcache::add(string $key,$mixed $var [, int $flag[ , int $expire]]); //添加缓存数据key长度不能超过250字节,var 值最大为1mb$flag 是否使用zlib压缩,设置为memache_compressed使用压缩$expire缓存过期时间,0表示不过期。设置不能大于2592000(30天)memcache::replace(string $key, mixed $var [ , int $flag [, int $expire]]); //替换一个已存在的keymemcache::set(string $key ,mixed $vsar [ , $flag [ , $expire]]) //add和replace的集合体memcache::get(string $key [ , int &flags]); //获取key的缓存内容$flags 如果给定此参数(引用方式传递),该参数会被写入一些与key对应的信息memcache::delete(string $key [ , $timeout]); //删除key的缓存memcache::flush(void); //立即使所有已经存在的缓存失效不真正释放任何资源,仅标记为失效memcache::getserverstatus(string $host [ , $port]); //获取一个服务器的在线/离线状态memcache::getstats([ string $type [ , $slabid [ , int $limit = 100]]]); //获取服务器的统计信息memcache::close(void); //关闭与memcache服务器的连接memcached使用多路复用i/o模型(如epoll、select),传统阻塞io中 系统可能会因为某个用户连接还没做好io准备而一直等待,直到这个连接做好准备,如果此时游其他用户连接到服务器,可能会因为系统阻塞而得不到相应。
多路复用i/o是一种消息通知模式,用户连接做好io准备后,系统会通知这个连接可进行io操作,这样就不会阻塞在某个用户连接。
memcached使用slab分配算法保存数据
slab分配算法的原理是,把固定大小(mem默认为1m)的内存划分为n块,每1m大小的内存块称为一个slab页,每次向系统申请一个slab页,然后通过分割算法把这个slab页分成若个小块的chunk,然后把这些chunk分配给用户使用。
memcached多线程模型:
主线程:接受客户端连接,并把连接分配给工作线程处理工作线程:处理客户端连接的请求memcached分布式布置方案:
普通hash分布一致性hash分布redis
redis把整个数据库全加载到内存中进行操作,通过异步操作定期把数据库数据flush到硬盘保存
reids特点:
支持丰富的数据类型:string、list、sort、sorted set、hash支持数据持久化方式:内存快照、日志追加支持主从复制安装redis:
http://www.cnblogs.com/fslnet/p/3759284.html
安装php扩展redis:
sudo apt-get install php5-redis
redis默认端口为:6379
redis配置文件(待整理)
redis key相关命令:
exits key //key是否存在,返回0/1
del key1 key2.. //删除指定key,返回删除key的数目,0表示key都不存在
type key //返回给定key的value类型,none表示不存在key
types pattern //返回匹配指定模式的所有key
expire key seconds //设置指定key的过期时间
randomkey //返回当前数据库中随机的一个key,如果数据库为空,返回空字符串
rename oldkey newkey //重命名key
renamenx oldkey newkey //重命名key,如果newkey存在返回失败
ttl key //返回设置过期时间key的剩余秒数,-1表示key不存在或没有设置过期时间
move key db-index //将key从当前数据库移动到指定的数据库,返回1成功,0表示不存在或已在指定数据库
未完待续……
