Code For Colorful Life
TSRM 线程安全资源管理器
学习自:第三节 PHP中的线程安全 和 深入研究PHP及Zend Engine的线程安全模型 和 究竟什么是TSRMLS_CC?
综合以上三篇文章,再看一下 PHP 源码才明白 TSRM 是怎么回事,这里做个学习记录。
线程安全
当PHP运行于多线程服务器时,处理请求的生命周期如下图:
在没有 TSRM 的时候,将会存在非线程安全问题,线程安全问题都是由全局变量及静态变量引起的。若每个线程中对全局变量、静态变量只有读操作,而无写操作,一般来说,这个全局变量是线程安全的;若有多个线程同时执行写操作,一般都需要考虑线程同步,否则的话就可能影响线程安全。
在PHP的进程中,存在许多全局变量,比如许多符号表。
Read more...
UML类图关系:继承、实现、依赖、关联、聚合、组合
学习自:UML中几种类间关系:继承、实现、依赖、关联、聚合、组合的联系与区别 和 《UML和模式应用》
继承
一个类继承另外一个类,或者一个接口继承了其他接口。
1
2
3
@startuml
ClassA <|-- ClassB
@enduml
Read more...
JSONP是如何实现跨域请求的?
学习自:说说JSON和JSONP,也许你会豁然开朗,含jQuery用例
条件
- 由于JS的同源策略限制,无法通过AJAX向其他域发送请求;
- 凡是拥有”src”这个属性的标签都拥有跨域的能力,比如
<script>
、<img>
、<iframe>
; - JS可动态为当前DOM结构增加和删除节点;
- 当浏览器请求一个JS文件时,会执行请求返回的内容。
Read more...
MySQL查询优化学习
学习自《高性能MySQL 第三版》和网络资源
一张图了解MySQL执行SQL语句过程:
是否向数据库请求了不需要的数据
- 查询了不需要的记录
- 多表关联时返回全部列
- 总是取出全部列
解决方案:1、使用 LIMIT;2、避免使用 *,从而有机会使用索引覆盖查询。
Read more...
MySQL EXPLAIN学习
参考自:Mysql Explain 详解和EXPLAIN Output Format
EXPLAIN 列输出解析:
id
SELECT 标识,是执行 SELECT 的顺序。该值可以为 NULL ,如果是引用了 union 的结果。在这种情况下,table 列的值应该像<unionM,N>
,表示被 union 的行的id值为 M 和 N。
Read more...
MySQL Index学习
学习自《高性能MySQL 第三版》和网络资源
索引是存储引擎用于快速找到记录的一种数据结构。
在MySQL中,索引是在存储引擎层而不是服务器层实现的。因此,不同存储引擎的索引的工作方式不一样,所支持的索引类型也不同。
Read more...
进程调度算法
非抢占方式
批处理系统:
先来先服务(FCFS)
基于时间片的轮转调度算法
将就绪进程按先来先服务的原则排成一个队列,每次调度时,把CPU分配给队首进程,并令其执行一个时间片(从几ms到几百ms)。当执行时间片用完时,由一个计数器发出时钟中断请求,调度进程便根据此信号来停止该进程的执行,并将它送往就绪队列的末尾;然后,再把处理机分配给就绪队列中新的队首进程,同时也让它执行一个时间片。
Read more...