Scrum敏捷项目管理读书笔记

Scrum敏捷项目管理读书笔记
由于最近的工作从开发转到了项目管理,所以需要了解一些项目管理的知识。
然后去公司的图书馆借了这本《Scrum敏捷项目管理》,并花了一周的工作之余的时间把它看完了。
总体觉得书有较多的案例,对一些知识点的解释比较到位,也容易理解。只是在工作中用不太到,因为整个公司的项目管理环境是CMMI,最多在本部门小范围的实施一些带点敏捷思想的东东。
【读书摘抄】
不同的项目可能需要不同的管理方法
应以项目成果为导向而非过程为导向
衡量项目成功与否,要看项目成果的商业价值与投资回报,而非仅仅看其有没有超支、延时或按原定计划行事
20/80法则,最大可能满足利益关系人的核心需要
尽可能让核心关系 人参与 并及早展示项目的进展和成果,及时作出必要的调整,以确保更高商业价值的交易。
Scrum只定义了高层次的信息系统开发项目的管理流程,并不涉及具体开发方法或者人员的有效沟通技巧。
其管理文化植根于“帮助他人完成目标”这一概念
Scrum是经验性过程控制
Scrum是围绕着一个迭代、增量的过程骨架展开
Scrum方法中有3个角色:产品负责人(Product Owner)、团队和ScrumMaster
产品负责人代表项目中每位利益相关者的权益,并为项目产出的软件系统负责
团队的责任是开发软件功能,实现自我管理
ScrumMaster对Scrum过程负责,确保所有项目相关人员遵守Scrum规则
项目成员==草场上的羊
ScrumMaster==牧羊犬
产品负责人的职责是提升项目的投资回报
Scrum使项目事项具有可视性
自管理 、涌现机制、可视性和检查/适应循环的根本原则
三个问题:
1、自上次Scrum简会后的一天里我做了什么?
2、从现在到下次Scrum简会的一天时间里我准备做什么?
3、在工作中遇到了哪些障碍?
Scrum是可能的艺术
ScrumMaster的职责:
1、排除产品开发和产品负责人之间的障碍,确保产品负责人直接推动开发工作
2、教授产品负责人如何实现投资回报最大化,以及如何利用Scrum达成目标
3、激发创造力和放权,从而改善开发团队的环境
4、千方百计提高开发团队的生产力
5、改善工程实践和工具,确保每个功能增量都具备潜在可交付性。
6、向各方面确保团队工作进展实时更新并高度可视
“限定时间”可向团队灌输“可能”的艺术,避免过分追求完美;
“增量交货”的举措可改进工程实践;
“放权”和“自组织”能够激发创造力,提升员工满意度
Scrum计划涉及3个问题的解答:
1、项目投资人希望项目结束时能取得哪些成果?
2、每个sprint应做出哪些进展?
3、如何使项目投资人相信该项目是有价值的投资,以及项目申报者有能力将会艰苦收益?
给客户做选择题,给领导做选择题
成功的开发需要不断的检查和调整
只有在全部事项对频繁检查和调整可视的情况下,Scrum才能有效运作。
Scrum的生产力源于:首先选择正确事项,然后高效完成选定事项。在Scrum中,团队自行寻找生产力最大化的方法,计划和执行任务完全由团队完成。
两个或以上Scrum团队同时开发的项目称作“扩展项目”,协调这些团队工作的机制称作“扩展机制”
Sprint计划会议限时8小时,分为两部分,各4小时。第一部分挑选产品Backlog;第二部分准备Sprint Backlog。
Sprint限期为30个连续日历日。
Sprint评审会议限时4小时
评审会议开始后,全体团队成员回答两个问题:
1、上一个Sprint有哪些成功方面?
2、下一个Sprint应做哪些改进?

Scrum敏捷项目管理读书笔记

由于最近的工作从开发转到了项目管理,所以需要了解一些项目管理的知识。

然后去公司的图书馆借了这本《Scrum敏捷项目管理》,并花了一周的工作之余的时间把它看完了。

总体觉得书有较多的案例,对一些知识点的解释比较到位,也容易理解。只是在工作中用不太到,因为整个公司的项目管理环境是CMMI,最多在本部门小范围的实施一些带点敏捷思想的东东。

【读书摘抄】

不同的项目可能需要不同的管理方法

应以项目成果为导向而非过程为导向

衡量项目成功与否,要看项目成果的商业价值与投资回报,而非仅仅看其有没有超支、延时或按原定计划行事

20/80法则,最大可能满足利益关系人的核心需要

尽可能让核心关系 人参与 并及早展示项目的进展和成果,及时作出必要的调整,以确保更高商业价值的交易。

Scrum只定义了高层次的信息系统开发项目的管理流程,并不涉及具体开发方法或者人员的有效沟通技巧。

其管理文化植根于“帮助他人完成目标”这一概念

Scrum是经验性过程控制

Scrum是围绕着一个迭代、增量的过程骨架展开

Scrum方法中有3个角色:产品负责人(Product Owner)、团队和ScrumMaster

产品负责人代表项目中每位利益相关者的权益,并为项目产出的软件系统负责

团队的责任是开发软件功能,实现自我管理

ScrumMaster对Scrum过程负责,确保所有项目相关人员遵守Scrum规则

项目成员==草场上的羊

ScrumMaster==牧羊犬

产品负责人的职责是提升项目的投资回报

Scrum使项目事项具有可视性

自管理 、涌现机制、可视性和检查/适应循环的根本原则

三个问题:

1、自上次Scrum简会后的一天里我做了什么?

2、从现在到下次Scrum简会的一天时间里我准备做什么?

3、在工作中遇到了哪些障碍?

Scrum是可能的艺术

ScrumMaster的职责:

1、排除产品开发和产品负责人之间的障碍,确保产品负责人直接推动开发工作

2、教授产品负责人如何实现投资回报最大化,以及如何利用Scrum达成目标

3、激发创造力和放权,从而改善开发团队的环境

4、千方百计提高开发团队的生产力

5、改善工程实践和工具,确保每个功能增量都具备潜在可交付性。

6、向各方面确保团队工作进展实时更新并高度可视

“限定时间”可向团队灌输“可能”的艺术,避免过分追求完美;

“增量交货”的举措可改进工程实践;

“放权”和“自组织”能够激发创造力,提升员工满意度

Scrum计划涉及3个问题的解答:

1、项目投资人希望项目结束时能取得哪些成果?

2、每个sprint应做出哪些进展?

3、如何使项目投资人相信该项目是有价值的投资,以及项目申报者有能力将会艰苦收益?

给客户做选择题,给领导做选择题

成功的开发需要不断的检查和调整

只有在全部事项对频繁检查和调整可视的情况下,Scrum才能有效运作。

Scrum的生产力源于:首先选择正确事项,然后高效完成选定事项。在Scrum中,团队自行寻找生产力最大化的方法,计划和执行任务完全由团队完成。

两个或以上Scrum团队同时开发的项目称作“扩展项目”,协调这些团队工作的机制称作“扩展机制”

Sprint计划会议限时8小时,分为两部分,各4小时。第一部分挑选产品Backlog;第二部分准备Sprint Backlog。

Sprint限期为30个连续日历日。

Sprint评审会议限时4小时

评审会议开始后,全体团队成员回答两个问题:

1、上一个Sprint有哪些成功方面?

2、下一个Sprint应做哪些改进?

舒服而慌乱的早晨

今天是周六,一直觉得睡眠不足的我,今天早上睡得特别舒服。直到有人叫我的名字我还觉得奇怪,这么早干嘛叫我呢。

答应以后,看看手机,8点半。该死的调休,周六周天要上班,手机是定的工作日闹钟。平时7点45起床的老公和8点钟起床的我都忙坏了。

老公用了大概5分钟洗涮,冲下楼去拦到一辆车,我用了10 分钟下楼,冲到公司 8 点 50。

发现:
早上好像没有刷牙;
没有擦香香;
昨天晚上锁在抽屉的苹果电脑的键盘和鼠标,由于今早匆忙忘带钥匙,今天的苹果机不能使用;
……

工作两年没有迟到的我们,终于还是保持了这个记录。
不过和老公都一致觉得,昨晚睡得真香呀~

最近养的孩子

最近养的孩子

PHP设计模式笔记:使用PHP实现单例模式

PHP设计模式笔记:使用PHP实现单例模式

【意图】
保证一个类仅有一个实例,并且提供一个访问它的全局访问点【GOF95】
单例模式有三个特点:
1、一个类只有一个实例
2、它必须自行创建这个实例
3、必须自行向整个系统提供这个实例

【单例模式结构图】

单例模式

单例模式

【单例模式中主要角色】
Singleton 定义一个Instance操作,允许客户访问它的唯一实例。Instance是一个类方法。负责创建它的唯一的实例。

【单例模式的优点】
1、对唯一实例的受控访问
2、缩小命名空间 单例模式是对全局变量的一种改进。它避免了那些存储唯一实例的全局变量污染命名空间
3、允许对操作和表示的精华 单例类可以有子类。而且用这个扩展类的实例来配置一个应用是很容易的。你可以用你所需要的类的实例在运行时刻配置应用。
4、允许可变数目的实例(多例模式)
5、比类操作更灵活

【单例模式适用场景】
1、当类只能有一个实例而且客户可以从一个众所周知的访问点访问它时
2、当这个唯一实例应该是通过子类化可扩展的。并且用户应该无需更改代码就能使用一个扩展的实例时。

【单例模式与其它模式】
工厂方法模式(factory method模式):单例模式使用工厂模式来提供自己的实例。
抽象工厂模式(abstract factory模式):抽象工厂模式可以使用单例模式,将具体工厂类设计成单例类。
建造者模式(Builder模式):建造模式可以将具体建造类设计成单例模式。
……

【单例模式PHP示例】

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
<?php
/**
 * 单例模式 2010-06-06 sz
 * @author phppan.p#gmail.com  http://www.phppan.com
 * 哥学社成员(http://www.blog-brother.com/)
 * @package design pattern
 */
 
/**
 * 懒汉式单例类
 */
class Singleton {
 
    /**
     * 静态成品变量 保存全局实例
     */
    private static  $_instance = NULL;
 
    /**
     * 私有化默认构造方法,保证外界无法直接实例化
     */
    private function __construct() {
    }
 
    /**
     * 静态工厂方法,返还此类的唯一实例
     */
    public static function getInstance() {
        if (is_null(self::$_instance)) {
            self::$_instance = new Singleton();
        }
 
        return self::$_instance;
    }
 
    /**
     * 防止用户克隆实例
     */
    public function __clone(){
        die('Clone is not allowed.' . E_USER_ERROR);
    }
 
    /**
     * 测试用方法
     */
    public function test() {
        echo 'Singleton Test!';
    }
 
}
 
/**
 * 客户端
 */
class Client {
 
     /**
     * Main program.
     */
    public static function main() {
        $instance = Singleton::getInstance();
        $instance->test();
    }
}
 
Client::main();
?>

PHP中不支持饿汉式的单例模式
因为PHP不支持在类定义时给类的成员变量赋予非基本类型的值。如表达式,new操作等等