PHP与UML类图: PHP and UML Class Diagram

UML(Unified Modeling Language, 统一建模语言)是一种通过图的方式表示软件的机制。本质上它允许我们通过画图来设计我们的程序,并且如果有相应的工具,我们甚至可以从图来直接产生代码。
类图(class diagram)只是PHP的一部分,下面将介绍PHP代码如何通过使用UML类图的方式表现出来的。

1. 描述类


1.1. 普通类

<?php
class ShopProduct {
}


1.2. 抽象类

<?php
abstract class ShopProduct {
}


抽象类有两种,约束定义或斜体类名,常用的是第二种,做笔记的话更倾向于第一种。

  

1.3. 接口

<?php
interface Chargeable {
}



2. 属性

属性前面的符号表示该属性可见性(visibility)的级别或者是访问控制

可见性符号

符号

可见性

说明

+

public

所有代码都可访问

-

private

只有当前类可以访问

#

protected

只有当前类和它的子类可以访问

可见性符号之后是属性名。下面的类图描述了ShopProduct::$price属性。冒号用于分隔属性名和它的类型及默认值(默认值为可选项,可以不提供)。


3. 操作

操作(operation)用于描述类方法,更准备地说,用于描述可以在类的实例上调用的操作。

操作和属性使用了相似的语法,可见性符号放在方法名之前。参数列表包含在括号之中。方法如果有返回类型的话,用冒号来描述。参数用逗号来分隔,并且遵守属性语法,参数名和它的数据类型间用冒号分隔。

4. 描述继承和实现

UML一般用“泛华”(generalization,也译为一般化)来描述继承关系。这个关系用从子类到父类的一条线来标识,线的顶端有一个空心闭合箭头。

<?php
class ShopProduct
{
}
class CdProduct extends ShopProduct
{
}
class BookProduct extends ShopProduct
{
}



UML用“实现”来描述接口和实现接口的类之间的关系。这个关系用从实现接口的类到接口类的一条虚线来标识,线的顶端是一个空心闭合箭头。

<?php
interface Chargeable
{
    public function getPrice();
}
class ShopProduct implements Chargeable
{
    // ...
    public function getPrice()
    {
        return $this->price - $this->discount;
    }
    // ...
}
class CDProduct extends ShopProduct
{
}
class BookProduct extends ShopProduct
{
}




5. 聚合

聚合是关联关系的一种特例,他体现的是整体与部分、拥有的关系,即has-a的关系,此时整体与部分之间是可分离的,他们可以具有各自的生命周期,部分可以属于多个整体对象,也可以为多个整体对象共享表现在代码层面,和关联关系是一致的,一般都是被关联对象以属性的方式出现在关联对象中,只能从语义级别来区分

<?php
/**
 * 学生类
 */
class Pupil
{
    public $name;
}
/**
 * 班级类
 */
class SchoolClass
{
    private $_students = array();

    /**
     * 添加学生
     */
    public function addPupil(Pupil $student)
    {
        $this->_students[] = $student;
    }
}



6. 组合

组合也是关联关系的一种特例,他体现的是一种contains-a的关系,这种关系比聚合更强,也称为强聚合;他同样体现整体与部分间的关系,但此时整体与部分是不可分的,整体的生命周期结束也就意味着部分的生命周期结束;比如你和你的大脑;表现在代码层面,和关联关系是一致的,一般都是被关联对象以属性的方式出现在关联对象中,只能从语义级别来区分。

<?php
/**
 * 社保数据
 */
class SocialSecurityData
{
}

/**
 * 自然人
 */
class Person
{
	public SocialSecurityData $p_social_security_data;

	/**
	 * 获取人的信息
	 */
	public function getPerson($person_id)
	{
		//...
		$p_social_security_data = new SocialSecurityData($person_id);
		// ...
	}
}


未完,待续。。。

发布了54 篇原创文章 · 获赞 10 · 访问量 12万+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章