/**
* 接口应用
*/
public class Main {
public static void main(String[] args) {
Person p = new Person("fish7");
p.setIsay(new BeforeGong());
p.say();
p.setIsay(new AfterGong());
p.say();
}
} class Person{ //只有在运行期才和say行为关联起来,这就叫面向接口编程
private String name;
private Isay isay; //把接口作为类中的一个属性(组合) public Person(String name){
this.name = name;
}
public void setIsay(Isay isay){ //可以传BeforeGong也可以传AfterGong
this.isay = isay;
}
public void say(){
isay.say();
}
}
interface Isay{ //把说话的行为抽象出一个接口
public void say(); //把可变化的行为抽象出来,定义成接口,并提供不同的实现
}
class BeforeGong implements Isay{
public void say(){
System.out.println("I'm a man.");
}
}
class AfterGong implements Isay{
public void say(){
System.out.println("I'm a woman~");
}
} /**
* 策略设计模式:定义了一系列的算法,将每一种算法封装起来并可以相互替换使用
* 策略模式让算法独立于使用它的客户应用而独立变化
* OO设计原则:
* 1.面向接口编程(面向抽象编程)
* 2.封装变化
* 3.多用组合,少用继承
*/
/**
* Object类:所有类的父类
*/
public class Main {
public static void main(String[] args) {
A a = new A("a");
System.out.println(a);
A b = new A("a");
A c = new A("b");
System.out.println(a.equals(b)); //输出true
System.out.println(a.equals(c)); //输出false
method(a);
}
public static void method(Object obj){
if(obj instanceof A){
A t1 = (A)obj;
t1.eat();
}
}
} class A{
String name;
A(String name){
this.name = name;
}
public String toString(){ //重写Obejct类中的toString()方法
return "fuck u";
}
public boolean equals(Object obj){ //重写Obejct类中的equals()方法,判断两个对象值是否相等
if(obj instanceof A){
A a = (A)obj;
if(this.name.equals(a.name))
return true;
else
return false;
}else{
return false;
}
}
void eat(){
System.out.println("I'm eating....");
}
}
/**
* 简单工厂模式:由一个工厂对象决定创建出哪一种产品类的实例
* 如果clothDoll或barbieDoll发生了改动,只需在DollFactory改就行了,而不需要客户端也改
*/
public class Main { //客户端
public static void main(String[] args) {
Doll r1 = DollFactory.getInstance("cloth");
System.out.println(r1.info());
Doll r2 = DollFactory.getInstance("barbie");
System.out.println(r2.info());
}
} class DollFactory{ //服务器
public static Doll getInstance(String name){
if("cloth".equals(name))
return new clothDoll();
if("barbie".equals(name))
return new barbieDoll();
return null;
}
}
interface Doll{
public String info();
}
class clothDoll implements Doll{
public String info(){
return "I'm a clothDoll...";
}
}
class barbieDoll implements Doll{
public String info(){
return "I'm a barbieDoll...";
}
}
/**
* 静态代理模式:为其他对象提供一种代理以控制对这个对象的访问
*
*/
public class Main {
public static void main(String[] args) {
Person p1 = new Person("fish7");
Proxyer m = new Proxyer(p1); //创建代理人,并传入被代理人
m.date(); //相亲
}
} interface subject{ //“主题”接口
public void date(); //相亲
}
class Person implements subject{ //被代理人
private String name;
Person(String name){
this.name = name;
}
public void date(){
System.out.println("I'm "+name+", I'm dating....");
}
}
class Proxyer implements subject{
private subject target; //代理目标对象
Proxyer(subject target){
this.target = target;
}
private void before(){ //相亲前要做的事
System.out.println("为代理人找到匹配人");
}
private void after(){ //相亲后要做的事
System.out.println("本次相亲结束");
}
public void date(){
before();
target.date();
after();
}
}
/**
* 适配器模式:将一个类的接口转换成客户希望的另外一个接口
* 适配器模式使得原本因为接口不兼容而不能在一起工作的那些类可以一起工作
*
*/
public class Main {
public static void main(String[] args) {
//System.out.println();
PowerA a = new plugA();
start(a);
PowerB b = new plugB();
PowerAdapter pa = new PowerAdapter(b); //适配器
start(pa);
}
public static void start(PowerA s){
s.Insert();
}
} class PowerAdapter implements PowerA{ //适配器,把B口“变成”A口
private PowerB b; //要进行适配的接口
public PowerAdapter(PowerB b){
this.b = b;
}
public void Insert(){
b.Connect();
}
}
interface PowerA{ //电源A接口
public void Insert();
}
interface PowerB{ //电源B接口
public void Connect();
}
class plugA implements PowerA{
public void Insert(){
System.out.println("电源A接口已经插入插头,开始工作....");
}
}
class plugB implements PowerB{
public void Connect(){
System.out.println("电源B接口已经插入插头,开始工作....");
}
}

JAVA笔记7__接口应用/Object类/简单工厂模式/静态代理模式/适配器模式的更多相关文章

  1. Java模式—静态代理模式

        静态代理模式(Proxy):为其他对象提供一种代理以控制对这个对象的访问,提供“真实对象”的代表,在访问对象时引入一定程度的间接性,这种间接性可以附加多种用途. 代理模式的主要作用是为其他对象 ...

  2. Java代理模式——静态代理模式

    一:代理模式 代理模式的作用是:为其他对象提供一种代理以控制这个对象的访问.在某些情况下,一个客户不想或者不能直接引用另一个对象,而代理对象可以在客户端和目标对象之间起到中介的作用. 二:代理模式设计 ...

  3. 黑马程序员:Java基础总结----静态代理模式&动态代理

    黑马程序员:Java基础总结 静态代理模式&动态代理   ASP.Net+Android+IO开发 . .Net培训 .期待与您交流! 静态代理模式 public  class  Ts {   ...

  4. Java 基础 - Set接口 及其实现类HashSet/LinkedHashSet/TreeSet

    笔记: /**Set接口 及其实现类 * 公用操作同Collection: * * ①size(),clear()②isEmpty(),③contains(),④add()方法 和remove()方法 ...

  5. Java NIO Path接口和Files类配合操作文件

    Java NIO Path接口和Files类配合操作文件 @author ixenos Path接口 1.Path表示的是一个目录名序列,其后还可以跟着一个文件名,路径中第一个部件是根部件时就是绝对路 ...

  6. 2.1多线程(java学习笔记) java中多线程的实现(附静态代理模式)

    一.多线程 首先我们要清楚程序.进程.线程的关系. 首先进程从属于程序,线程从属于进程. 程序指计算机执行操作或任务的指令集合,是一个静态的概念. 但我们实际运行程序时,并发程序因为相互制约,具有“执 ...

  7. 派生类&简单工厂模式

    派生类&简单工厂模式 git链接: Operation3.1.1 题目描述的代码部分的解释 首先是声明一个Rand类作为父类,然后两个子类RandNumber类和RandOperation类, ...

  8. Java进阶篇设计模式之七 ----- 享元模式和代理模式

    前言 在上一篇中我们学习了结构型模式的组合模式和过滤器模式.本篇则来学习下结构型模式最后的两个模式, 享元模式和代理模式. 享元模式 简介 享元模式主要用于减少创建对象的数量,以减少内存占用和提高性能 ...

  9. Java设计模式之七 ----- 享元模式和代理模式

    前言 在上一篇中我们学习了结构型模式的组合模式和过滤器模式.本篇则来学习下结构型模式最后的两个模式, 享元模式和代理模式. 享元模式 简介 享元模式主要用于减少创建对象的数量,以减少内存占用和提高性能 ...

随机推荐

  1. Python调用函数带括号和不带括号的区别

    1.不带括号时,调用的是这个函数本身 ,是整个函数体,是一个函数对象,不需等该函数执行完成 2.带括号(此时必须传入需要的参数),调用的是函数的return结果,需要等待函数执行完成的结果 如果函数本 ...

  2. wordpress 搭建

    wordpress 搭建: 公司要使用自建地图.选用了国外的Mapplic .但是Mapplic不支持直接编辑地图,需要用json的格式定义.但是wordpress版本的就有这个鬼东西,所以搞了一个这 ...

  3. 鸿蒙内核源码分析(中断切换篇) | 系统因中断活力四射 | 百篇博客分析OpenHarmony源码 | v42.02

    百篇博客系列篇.本篇为: v42.xx 鸿蒙内核源码分析(中断切换篇) | 系统因中断活力四射 | 51.c.h .o 硬件架构相关篇为: v22.xx 鸿蒙内核源码分析(汇编基础篇) | CPU在哪 ...

  4. NOIP 模拟四 考试总结

    #T1随 又是liu_................... 数列n,m个操作,每次随机取a[i],x=x*a[i]%k; 问题是求x期望%mod; 首先考虑到期望转移过程中存在%k,一般套路线性期望 ...

  5. 阿里限流神器Sentinel夺命连环 17 问?

    1.前言 这是<spring Cloud 进阶>专栏的第五篇文章,这篇文章介绍一下阿里开源的流量防卫兵Sentinel,一款非常优秀的开源项目,经过近10年的双十一的考验,非常成熟的一款产 ...

  6. 11.4.3 LVS-TUN

    LVS-TUN 用IP隧道技术实现虚拟服务器。这种方式是在集群的节点不在同一个网段时可用的转发机制,是将IP包封装在其他网络流量中的方法。为了安全的考虑,应该使用隧道技术中的VPN,也可使用租用专线。 ...

  7. 峰值利用率80%+,视频云离线转码自研上云TKE实践

    作者 刘兆瑞,腾讯云高级研发工程师,负责腾讯明眸极速高清,画质重生等产品.专注于codec优化,画质增强等技术. 背景和问题 随着流量资费的降低和带宽的增加,视频成为人们获取信息越来越重要的方式,随之 ...

  8. 密码学系列之:加密货币中的scrypt算法

    目录 简介 scrypt算法 scrypt算法详解 scrypt的使用 简介 为了抵御密码破解,科学家们想出了很多种方法,比如对密码进行混淆加盐操作,对密码进行模式变换和组合.但是这些算法逐渐被一些特 ...

  9. 重修 Tarjan

    Tarjan是谁 Tarjan's SCCs(有向图强连通分量)algorithm 给定⼀个有向图 \(G\),若存在 \(rt\in V\),满⾜从 \(rt\) 出发能到达 \(V\) 中的所有的 ...

  10. 1. SSTI(模板注入)漏洞(入门篇)

    好久没更新博客了,现在主要在作源码审计相关工作,在工作中也遇到了各种语言导致的一些SSTI,今天就来大概说一下SSTI模板注入这个老生常谈的漏洞 前言 模板引擎 模板引擎(这里特指用于Web开发的模板 ...