适配器模式(Adapter)

本文介绍了适配器模式,它能将某类接口转换为客户所需接口,协调不兼容接口使其共同工作。文中详细阐述了Target、Adapter、Adaptee和Client的定义及作用,并给出了Java代码示例,展示了如何封装现有组件接口以适应客户端。

将某类的接口转换为客户所需的接口。Adapter能协调不兼容的接口,使它们共同工作。封装现有组件接口,使其适应客户端。

TargetChemicalCompound

定义Client要使用的特定接口

AdapterCompound

转换Adaptee接口为用户所要的Target接口。

AdapteeChemicalDatabank

定义需要转换的现有接口。

Client(AdapterApp)

调用Target接口

代码:

//Target

public class ChemicalCompound{

protected String name;

protected float boilingPoint; //沸点

protected float meltingPoint; //溶点

protected double molecularWeight; //分子量

protected String molecularFormula; //分子式

public ChemicalCompound(String name){

this.name=name;

}

public float get BoilingPoint{

return this.boilingPoint;

}

public float getMeltingPoint {

return this.meltingPoint;

}

public float getMolecularWeight {

return this.molecularWeight;

}

public float getMolecularFormula {

return this.molecularFormula;

}

}

//Adapter

public class Compound extends ChemicalCompound{

private ChemicalDatabank bank;

public Compound(String name){

supter(name);

bank=new ChemicalDatabank();

boilingPoint=bank.GetCriticalPoint(name,”B”);

meltingPoint=bank.getCriticalPoint(name,”M”);

molecularWeight=bank.GetMolecularWeight(name);

molecularFormula=bank.getMolecularStructure(name);

}

public void Display(){

System.out.println(“Compound:”+name);

System.out.println(“ Formula:”+ molecularFormula);

System.out.println(“ Weight:”+ molecularWeight);

System.out.println(“ Melting Pt:”+ meltingPoint);

System.out.println(“ Boiling Pt:”+ boilingPoint);

}

}

//Adaptee

class ChemicalDatabank{

public float GetCriticalPoint(String compound, String point){

float temperature=0.0F;

//melting point

if(point==”M”){

if (compound.equal(”water”))

temperature=0.0F;

if(compound.equal(”benzene”))

temperature=5.5F;

if(compound.equal(”alcohol”))

temperature=-114.1F;

}else{

//Boiling Point

if (compound.equal(”water”))

temperature=100.0F;

if(compound.equal(”benzene”))

temperature=80.1F;

if(compound.equal(”alcohol”))

temperature=-78.3F;

}

return temperature;

}

public String GetMolecularStructure(String compound){

String structure=””;

if (compound.equal(”water”))

structure =”H20”;

if(compound.equal(”benzene”))

structure =”C6H6”;

if(compound.equal(”alcohol”))

structure =”C2H602”;

return structure;

}

public double GetMolecularWeight(String compound){

double weight=0.0;

if (compound.equal(”water”))

weight =18.015;

if(compound.equal(”benzene”))

weight =78.1134;

if(compound.equal(”alcohol”))

weight =46.0688;

return weight;

}

}

//adapterapp test

public class AdapterApp{

public static void main(String[] args){

Compound water=new Compound(“water”);

water.Display();

Compound benzene=new Compound(“benzene”);

benzene.Display();

Compound alcohol=new Compound(“alcohol”);

alcohol.Display();

}

}

Output

Compound: Water ------
Formula: H20
Weight : 18.015
Melting Pt: 0
Boiling Pt: 100

Compound: Benzene ------
Formula: C6H6
Weight : 78.1134
Melting Pt: 5.5
Boiling Pt: 80.1

Compound: Alcohol ------
Formula: C2H6O2
Weight : 46.0688
Melting Pt: -114.1
Boiling Pt: 78.3

【四轴飞行器】非线性三自由度四轴飞行器模拟器研究(Matlab代码实现)内容概要:本文围绕非线性三自由度四轴飞行器模拟器的研究展开,重点介绍了基于Matlab的建模与仿真方法。通过对四轴飞行器的动力学特性进行分析,构建了非线性状态空间模型,并实现了姿态与位置的动态模拟。研究涵盖了飞行器运动方程的建立、控制系统设计及数值仿真验证等环节,突出非线性系统的精确建模与仿真优势,有助于深入理解飞行器在复杂工况下的行为特征。此外,文中还提到了多种配套技术如PID控制、状态估计与路径规划等,展示了Matlab在航空航天仿真中的综合应用能力。; 适合人群:具备一定自动控制理论基础和Matlab编程能力的高校学生、科研人员及从事无人机系统开发的工程技术人员,尤其适合研究生及以上层次的研究者。; 使用场景及目标:①用于四轴飞行器控制系统的设计与验证,支持算法快速原型开发;②作为教学工具帮助理解非线性动力学系统建模与仿真过程;③支撑科研项目中对飞行器姿态控制、轨迹跟踪等问题的深入研究; 阅读建议:建议读者结合文中提供的Matlab代码进行实践操作,重点关注动力学建模与控制模块的实现细节,同时可延伸学习文档中提及的PID控制、状态估计等相关技术内容,以全面提升系统仿真与分析能力。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值