PHP设计模式-建造者模式

  • 建造者模式

    该模式定义了处理其它对象的复杂构建的对象设计。

    简述:是不是很晦涩?没错。现在我们管建造者模式叫榨汁机模式,举个栗子:

    想象现在你有一台榨汁机,榨汁机有十个放入橙子的管道(忽略为什么会有十个管道的梗,我想要一杯大大大橙汁不行么,其实这里类比的意思是:你有需要在十个地方构建同一个对象来使用),当你想得到“一杯橙汁”这个对象时,常规做法,你每次需要:

    1. 从十个入口放入橙子;
    2. 从十个口把去皮的橙子放进去;
    3. 放入一些调味品(比如浓缩橙汁);
    4. 把杯子对准出口,用杯子盛橙汁;
    5. 按动开关,榨汁,得到一杯橙汁.
    

    如果使用榨汁机模式呢?

    1. 从十个入口放入橙子;
    2. 按动开关,榨汁,得到一杯橙汁.
    

    把常规做法下的第2,3,4步全部放入了榨汁机内部,你不用在每个入口处给橙子去皮(这是最重要的),就像你在构建一个对象时,不用每次都给每个对象设置某个属性一样。

    那么问题来了,使用榨汁机模式除了节省了一些构建对象(做出一杯橙汁)步骤之外,还有什么好处呢?
    现在假设你买的橙子都有很多坚硬的籽,如果直接把这些橙子用来榨汁喝会非常影响口感,所以我们需要把籽给去掉,常规做法下:

    1. 给十个橙子去皮;
    2. 给十个橙子去籽(即使是自动去籽也需要在十个入口处加自动去籽机);
    ......
    

    榨汁机模式下,在榨汁机内部增加一个去籽机,然后:

    1. 从十个口放入橙子;
    2. 按动开关,榨汁,得到一杯橙汁.
    

    看出问题了吗?构建对象时,在常规做法下,如果有什么修改,那么在每个构建的地方,都需要去修改。但是在建造者模式下,有了修改,只需要去修改这个构建对象一次即可。

    这就是我理解的建造者模式,如果你有更好的理解,欢迎在下面评论区留言!

PHP设计模式-适配器模式

  • 适配器模式

    将某个对象的接口适配为另一个对象所期望的接口。

    简述:B类在使用A类里的方法,现在C类也需要使用到A类,但又有新特性,怎么办?有两种做法:

    1. 改造A类,增加新方法;
    2. 使用适配器模式,增加一个 A' 类继承A类,把新方法放在 A' 类里,这样C类就直接使用 A' 就好了。
    

    个人生活举例:比如,你有一辆车,你想听音乐(据说开车和听歌更配哟),但车的中控系统里只能播放音乐碟片,这就很尴尬了,手机里有无数好歌,却不能享受,就像你很饿,眼前有盘红烧肉,但吃不到嘴一样。(什么?你说为什么不直接用手机放歌?这是我的设定啊喂!)

    现在也有两个做法:

    1. 大刀阔斧改造中控(拆卸都很麻烦),让她既能播放碟片也能使用蓝牙连接手机;
    2. 买一个蓝牙连接器,通过连线(假设存在这样的线,类似于PHP的继承)连接中控,然后 done。
    

    这就是我理解的适配器模式,如果你有更好的理解,欢迎在下面评论区留言!

Git修改提交记录的提交信息

修改前提交历史记录如下图:
修改前

修改提交记录的提交信息有两种情况:

  • 修改最近一次提交的提交信息
    使用命令git commit --amend,进入到下图:
    改前
    修改提交信息,然后保存退出,
    使用命令git log,查看历史提交记录,可以发现最近一次提交信息已被修改,如下图:
    修改后提交信息

如果想要修改最近三次提交信息,或者那组提交中的任意一个提交信息呢?那就是我们要说的第二种情况了:

  • 修改多个提交信息
    使用命令git rebase -i 节点,节点即HEAD~2^HEAD~3或某一次的提交记录的哈希值;
    例:git rebase -i HEAD~3进入下图:
    进入rebase -i交互界面

注意:
1. 上面列出的历史提交记录信息正好和我们提交的时间是相反的,我们最近一次的提交反而在最下面;
2. 可以看到,这个文件相当于一个与Git的交互界面,你可以使用不同的命令达到后续不同的操作;
3. 上图中命令在附录1中说明.

第一方法,使用reword操作:
如果只需要修改提交历史信息,把pick修改为reword即可,在列出的记录里,需要修改哪个提交信息,就把这条记录前的pick修改为reword,保存退出后,Git就会弹出每个提交信息的编辑信息的编辑器,编辑完成退出后,就会弹出下一个,直到全部完成。

第二方法,使用edit操作,这个方法能使用所有git commit --amend的功能,比如修改提交者的邮箱信息等等:
这里我们只修改倒数第二次的提交信息,把第二个pick修改为edit,如果你要修改这三次所有的提交信息,可以都把pick都修改为edit,如下图:
修改你要使用的操作命令

保存并退出编辑器后如下图:
Git提示

接下来,使用命令git commit --amend来修改提交信息,你发现了么,是不是和上一种情况很像!
修改提交信息,然后退出编辑器。最后,运行git rebase --continue,这个命令将会自动地应用另外两个提交,然后就完成了。
如果需要将不止一处的pick改为edit,需要在每一个修改为edit的提交上重复这些步骤。每一次,Git都将会停止,让你修正提交,然后继续直到完成。

使用命令git log,查看历史提交记录,可以发现倒数第二次的提交信息已被修改,如下图:
修改后提交信息


警告:这是一个变基命令-在HEAD~3..HEAD范围内的每一个提交都会被重写,无论你是否修改信息。不要涉及任何已经推送到中央服务器的提交-这样做会产生一次变更的两个版本,因而会使他人困惑。

附录1

命令名称 说明
pick 使用提交,不做修改
reword 使用提交,但编辑提交信息
edit 使用提交,但会为了使用amend命令停止
squash 使用提交,但会把列表里后面的提交压缩到第一次合并成一次提交
fixup 和使用squash类似,但不会保留提交信息
exec 使用shell命令,待测试
drop 删除掉某一次提交,此次修改将全部消失(危险)

共享篮球架脑洞

背景:博主目前在北京工作,自己是一个业余篮球爱好者,很希望在周未休息时能找一个地方打打球,但这样的地方太少了。有篮球场的地方主要是在:学校,某些公园,极少数小区。
这些地方都有很大局限性:
1. 数量少;
2. 与自己住的地方相距甚远;
3. 很多学校不允许校外人员进入,有些公园也是收费的,小区有的也是封装型的。

基于以上这些情况,我设想,要是有共享篮球架就好了,这个篮球架应该有以下这些特性:
1. 可以太阳能充电,能抵抗轻微的自然灾害,比如:烈日暴晒,狂风和大雨等;
2. 篮球架有GPS定位功能,方便使用者寻找;
3. 有一个自动的盖子可以把篮框闭合(或者篮框在篮板后面),这样别人就不能使用;
4. 篮球架架身上有二维码,可以供使用者使用APP扫描支付使用费用,支付成功后闭合的盖子会自动打开(或者篮框自动会移动到篮板前);
5. 收费设置,比如 5RMB/H;
6. 计时结束后,盖子会自动闭合(自动移动到篮板后面),如要使用需要再次支付;
7. 篮球架允许运营方远程控制调节,比如,调节成每天上午9:00~12:00盖子自动打开,可以免费使用,其它时间需要扫码支付后使用。

优点:
1. 公共场合,方便寻找,每个爱好者都可以来玩;
2. 几个人一起玩,AA制付款就行,便宜;
3. 推广我国体育运动,强身健体:);

当然,它其实存在很多问题:
1. 场地问题,如果设计制作出了篮球架,但是却缺少能使用的场地,在一线城市,场地其实更稀缺,如果租赁场地的话,应该也很昂贵;
2. 篮球架的制作成本,我在网上搜了一下,一个普通的篮球架售价为1.8K RMB左右,造价也不便宜;
3. 受众少,相较其它共享项目(共享单车)来说,共享篮球架的使用者就少很多了。

其它思考:
1. 是否可以和共享篮球一起运作,运动者自己没有篮球可以现场使用共享篮球;
2. 是否可以和自动贩卖饮料机一起运作,运动者运动渴了可以直接买水喝解渴;
3. 篮球架本身是否有更好的设计,是否可以把支柱变宽而可以放显示屏播放广告。

补充:
1. 可以在篮球架的某个位置增加一个摄像头,防止架子被故意破坏,最重要的是可以录入用户打球视频,扫码付费的用户可以通过App观看,这个用户可以直播和分享这个视频给别人。他能够看自己或别人哪些投球很酷,很帅,也能够查看争议犯规的录像,知道是谁犯规。如果可以的话,还可以具有自动剪辑出五佳球等功能!
2. 还可以有很多玩法,比如,半场模式和全场模式,篮球架会自动录像,计时,计分,用户可以实时在手机APP上查看,还可以直播比赛。比如PK模式,两个人同时付费,结束后,输的一方会扣费,赢的一方会退款,再结合饮料自动贩卖机,加一瓶饮料的赌注,也是提前付费,比赛结束饮料会自动出来。
3. 更大的脑洞是,可以使用AR技术,用这个摄像头虚拟出几个人和用户一起打篮球!:)

自动化检测PHP语法和编程规范(Git pre-commit)

自动化检测PHP语法和编程规范

使用到的知识点:

  • 命令php -l检测文件语法,可以通过php -h查看PHP CLI支持哪些操作,如下:.
[:~]$ php -h
Usage: php [options] [-f] <file> [--] [args...]
   php [options] -r <code> [--] [args...]
   php [options] [-B <begin_code>] -R <code> [-E <end_code>] [--] [args...]
   php [options] [-B <begin_code>] -F <file> [-E <end_code>] [--] [args...]
   php [options] -S <addr>:<port> [-t docroot] [router]
   php [options] -- [args...]
   php [options] -a

  -a               Run interactively
  -c <path>|<file> Look for php.ini file in this directory
  -n               No configuration (ini) files will be used
  -d foo[=bar]     Define INI entry foo with value 'bar'
  -e               Generate extended information for debugger/profiler
  -f <file>        Parse and execute <file>.
  -h               This help
  -i               PHP information
  -l               Syntax check only (lint)
  -m               Show compiled in modules
  -r <code>        Run PHP <code> without using script tags <?..?>
  -B <begin_code>  Run PHP <begin_code> before processing input lines
  -R <code>        Run PHP <code> for every input line
  -F <file>        Parse and execute <file> for every input line
  -E <end_code>    Run PHP <end_code> after processing all input lines
  -H               Hide any passed arguments from external tools.
  -S <addr>:<port> Run with built-in web server.
  -t <docroot>     Specify document root <docroot> for built-in web server.
  -s               Output HTML syntax highlighted source.
  -v               Version number
  -w               Output source with stripped comments and whitespace.
  -z <file>        Load Zend extension <file>.

  args...          Arguments passed to script. Use -- args when first argument
                   starts with - or script is read from stdin

  --ini            Show configuration file names

  --rf <name>      Show information about function <name>.
  --rc <name>      Show information about class <name>.
  --re <name>      Show information about extension <name>.
  --rz <name>      Show information about Zend extension <name>.
  --ri <name>      Show configuration for extension <name>.


  • 安装PHP编程规范工具php-cs-fixer,可以在GitHub上查看详细信息.
    1. 下载:wget http://cs.sensiolabs.org/download/php-cs-fixer-v2.phar -O php-cs-fixer
    2. 给予执行权限:sudo chmod a+x php-cs-fixer
    3. 把文件移动到自己喜欢的目录,我一般是放在/usr/local/bin下:sudo mv php-cs-fixer /usr/local/bin/php-cs-fixer

  • 利用Git的钩子pre-commit达成commit前自动检测功能.
    这个钩子,顾名思意就是在git commit之前会触发,此钩子结合网上和朋友的写法,感谢他们.
    首先,点击查看这个文件,复制文件内容.
    然后,进入到自己的项目下git钩子目录:cd path/to/your/project/.git/hooks,复制pre-commit.sample文件并重命名:cp pre-commit.sample pre-commit,把文件内容替换为上一步复制的内容.
    最后,每次commit时就会先检测语法和规范是否正确,不正确会提示文件名和你需要规范代码格式的命令,简单测试如下图:.
    php-cs-fixer pre-commit