java重载与重写(覆盖)

转载自:http://blog.163.com/sunflower123_happy/blog/static/1732744212010102051746420/

有时候,类的同一种功能有多种实现方式,到底采用那种实现方式,取决于调用者给定的参数。例如杂技师能训练动物,对于不同的动物有不同的训练方式。

*        public void train (Dog dog){

*        //训练小狗站立,排队,做算数

*        }

*        public void train(Monkey monkey){

*        //训练猴子骑自行车等

*        }

*        再如某个类的一个功能是比较两个城市是否相同,一种方式是比较两个城市的名字,一种是除了比较两个城市的名字外,还要比较所在国家的名字。

*        publi boolean isSameCity (String city1,String city2){

*        return city1.equals(city2);

*        }

*        public boolean isSameCity(String city1,String city2,Stirng Country1,String Country2){

*        return isSameCity(city1,city2)&&Country1.equals(Country2);

*        }

*        在例如 java.lang.Math 类的 max ()方法能够从两个数字中取出最大值,它有多种实现方式。

*        public static int max(int a,int b)

*        public static int max(long a, long b)

*        public static int max(float a,float b)

*        以下程序多次调用Math 类的max() 方法,运行时,Java 虚拟机先判断给定参数的类型,然后决定到底执行哪个 max()方法。

*        // 参数为 int 类型,因此执行max(int a, int b)方法

·          Math.max(1,2);

*        //参数为 flloat 类型,因此执行 max(float a, float b) 方法

·          Math.max(1.0F,2.9F);

 

*        对于类的方法(包括从父类中继承的方法)如果有两个方法的方法名相同,但参数不一致,那么可以说,一个方法是另一个方法的重载方法。

*        重载方法满足以下条件

*        方法名相同

*        方法的参数类型,个数,顺序至少有一项不相同

*        方法的返回类型可以不相同

*        方法的修饰符可以不相同

*        在一个类中不允许定义另个方法名相同,并且参数签名也完全相同的方法。假如存在这样的两个方法,Java 虚拟机 在运行时就无法决定到底执行哪个方法。参数签名是指参数的类型,个数和顺序。

*        例如 :public class Sample {

·           public void amethod(int i,String s){} }

*        下面哪个方法可以加入到 Sample 类中去?

·          public void amethod(String s,int i)                //OK

·          public int amethod(int i,String s){return 0}   //NO 

¨        //不行,参数签名和类中方法一样

·          public void amethod(int i,String myString){} //NO

¨        //不行,参数签名和类中方法一样

·          public void Amethod (int i,Sting s){} //              OK

¨        //可以,因为 Amethod 和amethod 是两个不同的方法名称。

·          abstract void amethod( int i);          //NO

¨        尽管它的参数列和类中方法参数不一样,但是,此处的Sample 类不是抽象类,所以不能包括这个抽象方法。假如把Sample 类改为抽象类,就能把这个方法加入到 Sample 类中了。

·          (源码)

·            public boolean compareCity(String city1,String city2){

·                        return city1.equals(city2);

·                    }

·                   

·                public int compareCity(String city1,String city2){

·                       

·                        if(city1.equals(city2)){

·                                return 1;

·                            }else{

·                                return 0;

·                            }

·                    }

·          编译错误:compareCity(java.lang.String,java.lang.String) is already defined

·          // compareCity(String ,String ) 方法已经被定义过

*        作为程序的入口 main()方法也可以被重载。

*        public static void main(String args[]){

*                 

*                  }

*             

*              public void main(String s,int i){}               //可以

*             

*              private void main(int i,String myString []){}       //可以

*         

*              public void main(String s)throws Exception{}     //可以

*         

*              public final static int main(String args[]){}  //不可以

*                它已经和已有的 main ()方法有相同的签名,因此不允许再加到这个类中来。

*             main(java.lang.String []) is already defined in Sample

 

 

方法覆盖

*        假如有100个类,分别是 Sub1,Sub2,Sub3…….Sub100 ,它们的一个共同行为是写字,除了Sub1用脚写字外,其他都用手写字。可以抽象一个父类Base,它有一个表示写字的方法 write(),那么这个方法到底如何实现呢?从尽可能提高代码可重用性的角度看,write() 方法应该采取适用于大多数子类的实现方式,这样就可以避免在大多数子类中重复定义 write()方法。因此Base 类的 write() 方法定义如下:

*        public void write(){   // Base 类的 write() 方法   用手写字}

*        由于 Sub1 类的写字的实现方式与Base 类不一样,因此在Sub1类中必须重新定义 write() 方法。

*        public void write(){// Sub1 类中的 write() 方法  // 用脚写字}

 

*        如果在子类中定义的一个方法,其名称,返回类型及参数签名正好与父类中某个方法的名称,返回类型及参数签名相匹配,那么可以说,子类的方法覆盖了父类的方法。

*        覆盖方法 必须满足多种约束

*        1)子类方法的名称,参数签名和返回类型必须与父类方法的名称,参数签名和返回类型一致

·          例如,下列代码将发生编译错误

¨        public class Base{

¨            public void method(){……….}

¨        }

¨        public class Sub extends Base{

¨            public int method(){……………. return 0};// 编译错误

¨        }

¨        method() in Simon.Sub cannot overrid method() in Simon.Base;

¨        attempting to use incompatible return type

¨        在Simon 包 Sub 中的方法不不能重写(覆盖) 在 Simon 包 Base类中的方法

¨        试图用不匹配的返回类型

*        Java编译器首先判断Sub 类的 method()方法与 Base 类的 method() 方法的参数签名。由于两者一致,所以Java 编译器就认为 Sub 类 的 method() 方法试图覆盖父类的方法,既然如此,Sub 类的 method() 方法就必须和被覆盖的方法具有相同的返回类型。

·          以下代码中子类覆盖了父类的一个方法,然后又定义了一个重载方法,这是合法的。

¨        public class Base{

¨             public void method(){…………..}

¨        }

 

¨        public class Sub extends Base{

public void method(){……….}//覆盖 Base 类的method 方法

public int mehod(int a){………return 0.}  //重载method 方法

¨        }

*        2) 子类方法不能缩小父类方法的访问权限。例如以下代码中子类的 method() 方法是私用的,父类的 method()方法是公共的,子类缩小了 父类方法的访问权限,这是无效的方法覆盖,将导致编译错误。

¨        public class Base{

¨             public void method(){…………..}

¨        }

 

¨        public class Sub extends Base{

private void method(){……….}//覆盖 Base 类的method 方法,但是缩小了 父类方法访问权限

}

¨        method() in Simon.Sub cannot override method() in Simon.Base;

¨        attempting to assign weaker access privileges ;

¨        was public

¨        Simon 包中 的 Sub 类 method()不能重写、覆盖 Simon 包中Base类的 method()方法。

¨        试图分配一个更弱的访问权限

¨        原来是 public (现在却是 private)

·          为什么子类方法不允许缩小父类方法的访问权限呢?这时因为假如没有这个限制,将于Java 语言的多态机制发生冲突。

¨        Base base = new Sub() ;//base 变量被定义为Base 类型,但引用 Sub 的实例。

¨        base.method();

¨        Java 编译器认为以上是合法的代码,但是在运行时,根据动态绑定规则,Java 虚拟机会调用base 变量所引用的Sub 实例的 method()方法,如果这个方法为 private 类型,Java 虚拟机就没有办法访问它.所以为了避免这样的矛盾,Java 语言不允许子类方法缩小父类中被覆盖方法的权限。

*        3)子类方法不能抛出比父类方法更多的异常。

·          子类方法抛出的异常必须和父类方法抛出的异常相同,或者子类方法抛出的异常类是父类抛出的异常类的子类。

¨        假设异常类ExceptionSub1 和 ExceptionSub2 是 ExceptionBase 类的子类,则以下代码是合法的。

¨        public class Base{

¨             void method () throws ExceptionBase{}

¨        }

¨        public class Sub1 extends Base{

¨             void method () throws ExceptionSub1{}

¨        }

¨        public class Sub2 extends Base{

¨             void method () throws ExceptionSub1,ExceptionSub2

¨        }

¨        public class Sub3 extends Base{

¨             void methos () throws ExceptionBase

¨        }

¨        以下代码不合法

¨        public class Base{

¨            void method() throws ExceptionSub1{ }

¨        }

¨        public class Sub1 extends Base{

¨            void method() throws ExceptionBase{ } //编译出错

¨        }

¨        public class Sub2 extends Base{

¨          void method() throws ExceptionSub1,ExceptionSub2{}//编译出错

¨        }

·          为什么子类不允许抛出比父类方法更多的异常呢?这时因为假如没有这个限制,将会与Java 语言的多态机制发生冲突。

¨        Base base = new Sub2() ;//base 变量被定义为Base 类型,但引用Sub2 的实例。

¨        try{

¨             base.method();

¨        }catch(ExceptionSub1 e){……..}  //仅仅描述ExceptionSub1 异常

·          Java 编译器认为以上是合法的代码。但在运行时,根据动态绑定规则,Java虚拟机会调用 base 变量所引用的Sub2 实例的 method() 方法。

·          假如 Sub2 实例的 method() 方法抛出 ExceptionSub2 异常,由于该异常没有被捕获,将导致程序异常终止。

*        4)方法覆盖只存在于子类和父类(包括直接父类和间接父类)之间,在同一个类中方法只能被重载,不能被覆盖。

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
应用背景为变电站电力巡检,基于YOLO v4算法模型对常见电力巡检目标进行检测,并充分利用Ascend310提供的DVPP等硬件支持能力来完成流媒体的传输、处理等任务,并对系统性能做出一定的优化。.zip深度学习是机器学习的一个子领域,它基于人工神经网络的研究,特别是利用多层次的神经网络来进行学习和模式识别。深度学习模型能够学习数据的高层次特征,这些特征对于图像和语音识别、自然语言处理、医学图像分析等应用至关重要。以下是深度学习的一些关键概念和组成部分: 1. **神经网络(Neural Networks)**:深度学习的基础是人工神经网络,它是由多个层组成的网络结构,包括输入层、隐藏层和输出层。每个层由多个神经元组成,神经元之间通过权重连接。 2. **前馈神经网络(Feedforward Neural Networks)**:这是最常见的神经网络类型,信息从输入层流向隐藏层,最终到达输出层。 3. **卷积神经网络(Convolutional Neural Networks, CNNs)**:这种网络特别适合处理具有网格结构的数据,如图像。它们使用卷积层来提取图像的特征。 4. **循环神经网络(Recurrent Neural Networks, RNNs)**:这种网络能够处理序列数据,如时间序列或自然语言,因为它们具有记忆功能,能够捕捉数据中的时间依赖性。 5. **长短期记忆网络(Long Short-Term Memory, LSTM)**:LSTM 是一种特殊的 RNN,它能够学习长期依赖关系,非常适合复杂的序列预测任务。 6. **生成对抗网络(Generative Adversarial Networks, GANs)**:由两个网络组成,一个生成器和一个判别器,它们相互竞争,生成器生成数据,判别器评估数据的真实性。 7. **深度学习框架**:如 TensorFlow、Keras、PyTorch 等,这些框架提供了构建、训练和部署深度学习模型的工具和库。 8. **激活函数(Activation Functions)**:如 ReLU、Sigmoid、Tanh 等,它们在神经网络中用于添加非线性,使得网络能够学习复杂的函数。 9. **损失函数(Loss Functions)**:用于评估模型的预测与真实值之间的差异,常见的损失函数包括均方误差(MSE)、交叉熵(Cross-Entropy)等。 10. **优化算法(Optimization Algorithms)**:如梯度下降(Gradient Descent)、随机梯度下降(SGD)、Adam 等,用于更新网络权重,以最小化损失函数。 11. **正则化(Regularization)**:技术如 Dropout、L1/L2 正则化等,用于防止模型过拟合。 12. **迁移学习(Transfer Learning)**:利用在一个任务上训练好的模型来提高另一个相关任务的性能。 深度学习在许多领域都取得了显著的成就,但它也面临着一些挑战,如对大量数据的依赖、模型的解释性差、计算资源消耗大等。研究人员正在不断探索新的方法来解决这些问题。
深度学习是机器学习的一个子领域,它基于人工神经网络的研究,特别是利用多层次的神经网络来进行学习和模式识别。深度学习模型能够学习数据的高层次特征,这些特征对于图像和语音识别、自然语言处理、医学图像分析等应用至关重要。以下是深度学习的一些关键概念和组成部分: 1. **神经网络(Neural Networks)**:深度学习的基础是人工神经网络,它是由多个层组成的网络结构,包括输入层、隐藏层和输出层。每个层由多个神经元组成,神经元之间通过权重连接。 2. **前馈神经网络(Feedforward Neural Networks)**:这是最常见的神经网络类型,信息从输入层流向隐藏层,最终到达输出层。 3. **卷积神经网络(Convolutional Neural Networks, CNNs)**:这种网络特别适合处理具有网格结构的数据,如图像。它们使用卷积层来提取图像的特征。 4. **循环神经网络(Recurrent Neural Networks, RNNs)**:这种网络能够处理序列数据,如时间序列或自然语言,因为它们具有记忆功能,能够捕捉数据中的时间依赖性。 5. **长短期记忆网络(Long Short-Term Memory, LSTM)**:LSTM 是一种特殊的 RNN,它能够学习长期依赖关系,非常适合复杂的序列预测任务。 6. **生成对抗网络(Generative Adversarial Networks, GANs)**:由两个网络组成,一个生成器和一个判别器,它们相互竞争,生成器生成数据,判别器评估数据的真实性。 7. **深度学习框架**:如 TensorFlow、Keras、PyTorch 等,这些框架提供了构建、训练和部署深度学习模型的工具和库。 8. **激活函数(Activation Functions)**:如 ReLU、Sigmoid、Tanh 等,它们在神经网络中用于添加非线性,使得网络能够学习复杂的函数。 9. **损失函数(Loss Functions)**:用于评估模型的预测与真实值之间的差异,常见的损失函数包括均方误差(MSE)、交叉熵(Cross-Entropy)等。 10. **优化算法(Optimization Algorithms)**:如梯度下降(Gradient Descent)、随机梯度下降(SGD)、Adam 等,用于更新网络权重,以最小化损失函数。 11. **正则化(Regularization)**:技术如 Dropout、L1/L2 正则化等,用于防止模型过拟合。 12. **迁移学习(Transfer Learning)**:利用在一个任务上训练好的模型来提高另一个相关任务的性能。 深度学习在许多领域都取得了显著的成就,但它也面临着一些挑战,如对大量数据的依赖、模型的解释性差、计算资源消耗大等。研究人员正在不断探索新的方法来解决这些问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值