讲IOC非常好的一篇文章--初步弄懂DI
http://jinnianshilongnian.iteye.com/blog/1413846
http://jinnianshilongnian.iteye.com/blog/pdf
之后又看了类与类之间关系:
下面这篇文章是来自:
http://jinnianshilongnian.iteye.com/blog/1415277
类与类之间的关系-依赖,关联,聚合,组合,继承泛化的区别
1)依赖
依赖关系是类与类之间的联接。一个类依赖于另一个类的定义。如,一个人(Person)可以买车(Car)和房子(House),Person类依赖于Car和House的定义,因为Person引入了Car和House。与关联不同的是,Person类中没有Car和House的属性,Car和House的实例是以参量的方式传入到buy()方法中的。一般而言,依赖关系在Java语言中体现为局部变量,方法形参,或者对静态方法的调用。

2)关联
关联是类与类之间的联接,使一个类知道另一个类的属性和方法。关联可以是双向,也可以是单向的。一般使用成员变量来实现。

3)聚合
聚合是一种强的关联关系。是整体和个体之间的关系。例如,汽车类与引擎类,轮胎类之间的关系就是整体与个体之间的关系。与关联关系一样,聚合关系也是通过实例变量实现的。但是关联关系涉及的两个类在同一层次,而聚合关系中两个类处在不平等的层次上,一个代表整体,一个代表部分。

4)组合
组合也是关联关系的一种,一种比聚合关系强的关系。组合关系中的部分类不能独立于整体类存在。整体类和部分类有相同的生命周期。如Person类和Leg类。

5)继承/泛化
泛化和继承其实是一个逆过程 泛化就是有子类抽象出一个父类 而继承就是由父类具体化一个子类 例如足球比联赛跟什么西甲 意甲 英超之间就是泛化/继承的关系

6)组合和聚合的区别
组合和聚合都属于关联,所以它们之间难免有相似之处,区别举例来说明:
程老师的《大话》里举大那个大雁的例子很贴切 在此我就借用一下 大雁喜欢热闹害怕孤独 所以它们一直过着群居的生活 这样就有了雁群 每一只大雁都有自己的雁群 每个雁群都有好多大雁 大雁与雁群的这种关系就可以称之为聚合 另外每只大雁都有两只翅膀 大雁与雁翅的关系就叫做组合 有此可见 聚合的关系明显没有组合紧密 大雁不会因为它们的群主将雁群解散而无法生存 而雁翅就无法脱离大雁而单独生存——组合关系的类具有相同的生命周期
聚合关系图:

聚合关系图:

雁群类:

public class GooseGroup
{
publi Goose goose;
public GooseGroup(Goose goose){
this.goose=goose;
}
}

大雁类:

public class Goose{
    public Wings wings;
    public Goose()
    {
        wings=new Wings();
    }
}    

从构造函数来看,GooseGroup的构造函数要用到Goose作为参数把值传进来,Goose可以脱离GooseGroup独立存在。
组合关系中整体类含有部分类的实例化,Goose在实例化之前,一定要先实例化Wings,两个类紧密耦合在一起,它们有相同的生命周期,Wings不能独立于Goose存在。
从信息封装来看,聚合关系中,客户端同时了解GooseGroup和Goose,因为它们是独立的。
而在组合关系中,客户端只认识大雁类,根本不知道翅膀类的存在,因为翅膀类被严密封装在大雁类中。
讲IOC非常好的一篇文章--初步弄懂DI的更多相关文章
- 一篇文章彻底弄懂Android-MVVM
		转: 一篇文章彻底弄懂Android-MVVM 在学习一个技术之前,我们首先要搞清为什么要用它.用它以后会有什么好处,这样我们才能有兴趣的学习下去. 一.为什么要用MVVM? 我为什么要用这个什么MV ... 
- 一篇文章彻底弄懂Base64编码原理
		在互联网中的每一刻,你可能都在享受着Base64带来的便捷,但对于Base64的基础原理又了解多少?今天这篇博文带领大家了解一下Base64的底层实现. Base64的由来 目前Base64已经成为网 ... 
- 一篇文章彻底弄懂Base64编码原理(转载)
		在互联网中的每一刻,你可能都在享受着Base64带来的便捷,但对于Base64的基础原理又了解多少?今天这篇博文带领大家了解一下Base64的底层实现. Base64的由来 目前Base64已经成为网 ... 
- 知识扩展——(转)一篇文章彻底弄懂Base64编码原理
		在互联网中的每一刻,你可能都在享受着Base64带来的便捷,但对于Base64的基础原理又了解多少?今天这篇博文带领大家了解一下Base64的底层实现. 一.Base64的由来 目前Base64已经成 ... 
- 一篇文章彻底弄懂CAS实现SSO单点登录原理
		1. CAS 简介 1.1. What is CAS ? CAS ( Central Authentication Service ) 是 Yale 大学发起的一个企业级的.开源的项目,旨在为 Web ... 
- 一篇文章彻底搞懂Java的大Class到底是什么
		作者在之前工作中,面试过很多求职者,发现有很多面试者对Java的 Class 搞不明白,理解的不到位,一知半解,一到用的时候,就不太会用. 因为自己本身以前刚学安卓的时候,甚至做安卓2,3年后,也是对 ... 
- 一篇文章彻底搞懂es6 Promise
		前言 Promise,用于解决回调地狱带来的问题,将异步操作以同步的操作编程表达出来,避免了层层嵌套的回调函数. 既然是用来解决回调地狱的问题,那首先来看下什么是回调地狱 var sayhello = ... 
- 一篇文章彻底搞懂snowflake算法及百度美团的最佳实践
		写在前面的话 一提到分布式ID自动生成方案,大家肯定都非常熟悉,并且立即能说出自家拿手的几种方案,确实,ID作为系统数据的重要标识,重要性不言而喻,而各种方案也是历经多代优化,请允许我用这个视角对分布 ... 
- 一篇文章彻底搞懂base64编码原理
		开始 在互联网中的每一刻,你可能都在享受着Base64带来的便捷,但对于Base64的基础原理又了解多少?今天这篇文章带领大家了解一下Base64的底层实现. base64是什么东东呢? Base64 ... 
随机推荐
- [NOI2017]蔬菜——时光倒流+贪心
			题目链接 题解: 貌似一眼看过去是一个贪心. 其他的算法要记录的东西就太多了. 部分分其实很高.但是没有什么提示. 想一些套路:二分?不行还要贪心判断. 分治?前后取法是有影响的. 时光倒流? 也许可 ... 
- Java并发编程学习笔记
			Java编程思想,并发编程学习笔记. 一.基本的线程机制 1.定义任务:Runnable接口 线程可以驱动任务,因此需要一种描述任务的方式,这可以由Runnable接口来提供.要想定义任务,只需实现R ... 
- apt-get update的hit和ign含义
			How do Ign and Hit affect apt-get update? From what I can see in the apt source code, "Ign" ... 
- [技巧篇]10.那些年我们一起优化过的MyEclipse8.6
			这里里面是针对于四海的给位学生预留的视频,请自行下载,我希望对大家有所帮助 我这里使用了百度网盘,这里的东西还是比较多的!如果喜欢请关注我,当好胖先生的粉丝 链接:http://pan.baidu.c ... 
- Python爬虫学习笔记之模拟登陆并爬去GitHub
			(1)环境准备: 请确保已经安装了requests和lxml库 (2)分析登陆过程: 首先要分析登陆的过程,需要探究后台的登陆请求是怎样发送的,登陆之后又有怎样的处理过程. 如果已经 ... 
- maven工程pom.xml报Missing artifact net.sf.jasperreports:jasperreports:jar:6.2.0
			有时maven工程的pom.xml报以下类型错误: Description Resource Path Location TypeMissing artifact net.sf.jasperrepor ... 
- Beagleboneblack的MLO文件干了些啥
			Beagleboneblack在启动linux之前还有三个启动阶段: ROM code --> MLO --> u-boot --> kernel 先看看ROM code干了 ... 
- 【BZOJ】1914: [Usaco2010 OPen]Triangle Counting 数三角形
			[题意]给定坐标系上n个点,求能构成的包含原点的三角形个数,n<=10^5. [算法]极角排序 [题解]补集思想,三角形个数为C(n,3)-不含原点三角形. 将所有点极角排序. 对于一个点和原点 ... 
- 【BZOJ】1710: [Usaco2007 Open]Cheappal 廉价回文
			[算法]区间DP [题解]回文问题的套路做法:区间DP. f[i][j]表示区间i~j回文的最小代价,则有f[i][j]=min{①②③}. ①f[i+1][j]+min(a[s[i]],b[s[i] ... 
- 【比赛】STSRM 09
			第一题 题意:n个点,每个点坐标pi属性ai,从右往左将遇到的点向左ai范围内的点消除,后继续扫描. 现可以在扫描开始前提前消除从右往左任意点,问最少消除数(提前+扫描). n,pi,ai<=1 ... 
