五泉山网页设计宣传网站制作兰州优化定制

diannao/2026/1/16 23:56:45/文章来源:
五泉山网页设计宣传网站制作,兰州优化定制,成都高新区规划国土建设局网站,枣庄网站优化2019独角兽企业重金招聘Python工程师标准 Java中接口、抽象类与内部类学习 接口与内部类为我们提供了一种将接口与实现分离的更加结构化的方法。 抽象类和抽象方法 抽象方法#xff1a;仅有声明而没有方法体。 抽象类#xff1a;包含一个或多个抽象方法的类 Java中接口、抽象类与内部类学习 接口与内部类为我们提供了一种将接口与实现分离的更加结构化的方法。 抽象类和抽象方法 抽象方法仅有声明而没有方法体。 抽象类包含一个或多个抽象方法的类该类就必须限定为抽象的否则会报错。 abstract void f() { //抽象方法 }抽象类的特点 抽象类中的方法并不需要所有的方法都是抽象的只需部分的方法是抽象的即可。如果一个新类从一个抽象类继承并想创建该新类的对象name就必须为基类中所有的抽象方法提供方法定义。否则导出类也是抽象类并要用abstract修饰该类。抽象类并不能被实例化。抽象类中的抽象方法不能有方法体但抽象类中的其它非抽象方法必须有方法体。抽象类中也可以没有抽象方法。抽象类中不应该有private的成员注意是不应该而不是不能。不管是成员变量还是非抽象方法都不建议用private修饰抽象方法是禁止使用private修饰。原因就是我们创建抽象类的目的就是要实现代码复用方便子类继承private修饰的是不能继承的同时抽象类不能实例化对象所以用private修饰的成员毫无用处。抽象类的中抽象方法只允许用public和默认修饰JDK1.8之前默认是用protected修饰但在JDK1.8之后则是默认为default修饰 接口 interface关键字使抽象的概念更向前了一步。interface将产生一个完全抽象的类没有提供任何具体实现。 接口的特点 允许创建者确定方法名、参数列表和返回类型。但是没有任何方法体。接口只提供了形式并没有提供任何具体实现。接口中可以包含域如intString但是域默认是static、final的。即默认定为public static final类型的。接口中的方法必须是public修饰的默认为public。接口中的方法不能有方法体。接口中定义的方法都需要有实现类来实现如果实现类不能实现接口中的所有方法则实现类定义为抽象类。接口中的方法可以为static int method即defalut static修饰但是默认修饰方法的还是public abstarct的在接口中只有方法的声明没有方法体。接口与抽象类的使用判断 若要创建不带任何方法定义及成员变量的基类则选择接口注意接口中没有成员变量只有public static final修饰的常量且符号要大写若知道某事物应该成为一个基类则第一选择应是使它成为一个接口。 完全解耦—接口的应用p174 Java中的多重继承 可以通过接口实现Java的多继承当将一个具体类和多个接口组合到一起时这个具体类必须放在前面后面跟着的才是接口否则编译器会报错。 interface CanFight{void fight(); } interface CanSwim{void swim(); } interface CanFly{void fly(); } class ActionCharacter{public void fight(){} } class Hero extends ActionCharacter implements CanFight,CanFly,CanSwim {public void swim() {}public void fly() {} } public class Adventrue {private static void t(CanFight x){x.fight(); }private static void u(CanSwim x){x.swim(); }private static void v(CanFly x){x.fly(); }private static void w(ActionCharacter x){x.fight(); }public static void main(String [] args){Hero hero new Hero();t(hero);u(hero);v(hero);w(hero);} }使用接口的核心原因 为了能够向上转型为多个基类型由此带来的灵活性防止客户端程序员创建该类的对象并确保这仅仅是建立一个接口 通过继承来扩展接口 适配接口 接口中的域 初始化接口中的域 在接口中定义的域不能是”空final“但是可以被非常量的表达式初始化。例如int RANM_INT Rand.nextInt(10);.因为域是static的可以在域第一次加载时就初始化当然这些域不是接口的一部分他们的值被存在该接口的静态储存区域中。 嵌套接口 接口可以嵌套在类或其他接口中。 接口与工厂 内部类补 为什么使用内部类 使用内部类最吸引人的原因是每个内部类都能独立地继承一个接口的实现所以无论外围类是否已经继承了某个接口的实现对于内部类都没有影响 使用内部类最大的优点就在于它能够非常好的解决多重继承的问题,使用内部类还能够为我们带来如下特性:   (1)、内部类可以用多个实例每个实例都有自己的状态信息并且与其他外围对象的信息相互独。   (2)、在单个外围类中可以让多个内部类以不同的方式实现同一个接口或者继承同一个类。   (3)、创建内部类对象的时刻并不依赖于外围类对象的创建。   (4)、内部类并没有令人迷惑的“is-a”关系他就是一个独立的实体。   (5)、内部类提供了更好的封装除了该外围类其他类都不能访问。 内部类分类 成员内部类 public class Outer{private int age 99;String name Coco;public class Inner{String name Jayden;public void show(){System.out.println(Outer.this.name);System.out.println(name);System.out.println(age);}}public Inner getInnerClass(){return new Inner();}public static void main(String[] args){Outer o new Outer();Inner in o.new Inner();in.show();}}1.Inner 类定义在 Outer 类的内部相当于 Outer 类的一个成员变量的位置Inner 类可以使用任意访问控制符 如 public 、 protected 、 private 等 2.Inner 类中定义的 show() 方法可以直接访问 Outer 类中的数据而不受访问控制符的影响 如直接访问 Outer 类中的私有属性age 3.定义了成员内部类后必须使用外部类对象来创建内部类对象而不能直接去 new 一个内部类对象 即内部类 对象名 外部类对象.new 内部类( ); 4.编译上面的程序后会发现产生了两个 .class 文件: Outer.class,Outer$Inner.class{} 5.成员内部类中不能存在任何 static 的变量和方法,可以定义常量: (1).因为非静态内部类是要依赖于外部类的实例,而静态变量和方法是不依赖于对象的,仅与类相关, 简而言之:在加载静态域时,根本没有外部类,所在在非静态内部类中不能定义静态域或方法,编译不通过; 非静态内部类的作用域是实例级别 (2).常量是在编译器就确定的,放到所谓的常量池了 ★★友情提示: 1.外部类是不能直接使用内部类的成员和方法的可先创建内部类的对象然后通过内部类的对象来访问其成员变量和方法; 2.如果外部类和内部类具有相同的成员变量或方法内部类默认访问自己的成员变量或方法如果要访问外部类的成员变量 可以使用 this 关键字,如:Outer.this.name 静态内部类 是 static 修饰的内部类 1.静态内部类不能直接访问外部类的非静态成员但可以通过 new 外部类().成员 的方式访问 2.如果外部类的静态成员与内部类的成员名称相同可通过“类名.静态成员”访问外部类的静态成员 如果外部类的静态成员与内部类的成员名称不相同则可通过“成员名”直接调用外部类的静态成员 3.创建静态内部类的对象时不需要外部类的对象可以直接创建 内部类 对象名 new 内部类(); public class Outer{private int age 99;static String name Coco;public static class Inner{String name Jayden;public void show(){System.out.println(Outer.name);System.out.println(name); }}public static void main(String[] args){Inner i new Inner();i.show();}}.方法内部类 访问仅限于方法内或者该作用域内 (1).局部内部类就像是方法里面的一个局部变量一样是不能有 public、protected、private 以及 static 修饰符的 (2).只能访问方法中定义的 final 类型的局部变量,因为: 当方法被调用运行完毕之后局部变量就已消亡了。但内部类对象可能还存在, 直到没有被引用时才会消亡。此时就会出现一种情况就是内部类要访问一个不存在的局部变量; 使用final修饰符不仅会保持对象的引用不会改变,而且编译器还会持续维护这个对象在回调方法中的生命周期. 局部内部类并不是直接调用方法传进来的参数而是内部类将传进来的参数通过自己的构造器备份到了自己的内部 自己内部的方法调用的实际是自己的属性而不是外部类方法的参数; 防止被篡改数据,而导致内部类得到的值不一致 /* 使用的形参为何要为 final??? 在内部类中的属性和外部方法的参数两者从外表上看是同一个东西但实际上却不是所以他们两者是可以任意变化的 也就是说在内部类中我对属性的改变并不会影响到外部的形参而然这从程序员的角度来看这是不可行的 毕竟站在程序的角度来看这两个根本就是同一个如果内部类该变了而外部方法的形参却没有改变这是难以理解 和不可接受的所以为了保持参数的一致性就规定使用 final 来避免形参的不改变 */public class Outer{public void Show(){final int a 25;int b 13;class Inner{int c 2;public void print(){System.out.println(访问外部类: a);System.out.println(访问内部类: c);}}Inner i new Inner();i.print();}public static void main(String[] args){Outer o new Outer();o.show();}} (3).注意:在JDK8版本之中,方法内部类中调用方法中的局部变量,可以不需要修饰为 final,匿名内部类也是一样的主要是JDK8之后增加了 Effectively final 功能http://docs.oracle.com/javase/tutorial/java/javaOO/localclasses.html 反编译jdk8编译之后的class文件,发现内部类引用外部的局部变量都是 final 修饰的 匿名内部类 (1).匿名内部类是直接使用 new 来生成一个对象的引用; (2).对于匿名内部类的使用它是存在一个缺陷的就是它仅能被使用一次创建匿名内部类时它会立即创建一个该类的实例 该类的定义会立即消失所以匿名内部类是不能够被重复使用; (3).使用匿名内部类时我们必须是继承一个类或者实现一个接口但是两者不可兼得同时也只能继承一个类或者实现一个接口; (4).匿名内部类中是不能定义构造函数的,匿名内部类中不能存在任何的静态成员变量和静态方法; (5).匿名内部类中不能存在任何的静态成员变量和静态方法,匿名内部类不能是抽象的,它必须要实现继承的类或者实现的接口的所有抽象方法 (6).匿名内部类初始化:使用构造代码块利用构造代码块能够达到为匿名内部类创建一个构造器的效果 public class OuterClass {public InnerClass getInnerClass(final int num,String str2){return new InnerClass(){int number num 3;public int getNumber(){return number;}}; /* 注意分号不能省 */}public static void main(String[] args) {OuterClass out new OuterClass();InnerClass inner out.getInnerClass(2, chenssy);System.out.println(inner.getNumber());}}interface InnerClass {int getNumber();} 内部类 可以将一个类的定义放在另一个类的定义内部这就是内部类。内部类的使用与其他类没有什么不同但是如果想从外部类的非静态方法之外的任意位置创建某个内部类的对象时那么必须指明这个对象的类型OuterClassName.InnerClassName。 public class Parcel2 {class Contents {private int i 11;public int value() {return i;}}class Destination{private String label;Destination(String whereTo){label whereTo;}String readLable(){return label;}}public Contents contents(){ return new Contents(); }public Destination destination(String s){ return new Destination(s); }public void ship(String dest){Contents c new Contents();Destination d new Destination(dest);System.out.println(d.readLable());}public static void main(String [] args){Parcel2 p new Parcel2();p.ship(Tasmania);//defing references to inner classParcel2 q new Parcel2();Parcel2.Contents c q.contents();Parcel2.Destination d q.destination(borneo);} }内部类标识符 外围内的名字 “$” 内部类的名字.class。如果内部类是匿名的编译器会简单地产生一个数字作为其标识符。如果内部类是嵌套在别的内部类中只需直接将他们的名字加在其外围类标识符与“$”后面。 链接到外部类 当生成一个内部类对象时此对象与制造它的外围对象之间就有了一种联系所以他就能访问其外围对象的所有成员而不需要任何其他条件。内部类拥有其外围类的所有元素的访问权。内部类的对象只能在与外围类的对象相关联的情况下才能被创建。构建一个内部类时需要一个指向其外围类对象的引用如果编译器找不到这个引用则会报错。外部类访问内部类可以通过几种方式访问 方式一外部类name.内部类name name 外部类对象.get方法返回内部类new的对象。如 Parcel2.Contents c q.contents();要求在外部类的contents方法中要返回内部类的new对象。 方式二内部类实现了外部的一个接口则可以 interface name 外部类.get方法返回内部类的对象。都不能直接在外部类中采用new字段去构造对象再访问可以用封装在外部类的方法中再new内部类后用方法返回。 方式三通过.new去创建 使用.this和.new 要生成对外部类的引用可以再外部类的名字后紧跟”.this“。这样产生的引用具有正确的类型且在编译期就被知晓并检查因此没有任何运行时的开销。 public class DoThis {void f(){ System.out.println(DoThis.f()); }public class Inner{public DoThis outer(){ return DoThis.this; } //返回外部类的引用}public Inner inner(){ return new Inner(); }public static void main(String [] args){DoThis dt new DoThis();DoThis.Inner di dt.inner();di.outer().f();} }创建某个内部类的对象使用“.new”。要创建某个类的对象必须使用外部内的对象来创建该内部类的对象。在拥有外部类对象之前是不可能创建内部类对象的因为内部类会暗暗地连接到引用它的外部类对象上。但是如果创建的是嵌套类静态内部类那么就不需要对外部类对象的引用。 public class DoNew {public class Inner{}public static void main(String [] args){DoNew dn new DoNew();DoNew.Inner di dn.new Inner();} }内部类与向上转型 当将内部类向上转型为其基类尤其是转型为一个接口时内部类就发挥很大作用了。因为内部类——某个借口的实现——能够完全不可见并且不可用。所以得到得只是指向基类或接口的引用能够很方便的隐藏实现细节。 在方法和作用域内的内部类 可以在一个方法里面或者在任意的作用域内定义内部类。 实现某个类型的接口于是可以创建并返回对其的引用。想创建一个类来辅助解决问题但不希望这个类是公共可用的。 局部内部类 在方法的作用域内创建一个完整的类。在方法的作用域外是不能访问的。在方法执行完毕并不意味着局部内部类就不可以使用了。可以在同一个子目录的任意类中对局部内部类使用相同的类标识符这并不会引起命名冲突。 匿名内部类 将返回值的生成与表示这个返回值的类的定义结合在一起。这个类是没有名字的。 public class Parcel7 {public Contens contens(){return new Contens() {private int i 11;public int value() {return i;}};}public static void main(String [] args){Parcel7 p new Parcel7();Contens c p.contens();} }匿名内部类的基类如果只有带参构造器在使用匿名类时可以传递合适的参数给基类的构造器即可。 public class Parcel8 {public Wrappping wrappping(int x) {return new Wrappping(x) {public int value() {System.out.println(super.value(): super.value());return super.value() * 47;}};}public static void main(String[] args) {Parcel8 p new Parcel8();Wrappping wrappping p.wrappping(10);wrappping.value();} }在匿名类的末尾的分号并不是用来标记此内部类结束的它标识的是表达式的结束只不过表达式正好包含了匿名内部类。这与别的地方使用的分号是一致的。在匿名类中定义字段时还可以初始化。如果匿名内部类希望使用一个在其外部定义的对象编译器要求参数引用时final的。这个在jdk以前的版本是这样但是在jdk1.8的时候这一规则不再适用。内部类可以访问外部类中的所有变量无需用final修饰了 public class Parcel9 {public Destination destination( /*final*/ String dest){return new Destination() {private String label dest;public String readLabel() {return label;}};}public static void main(String [] args){Parcel9 p new Parcel9();Destination d p.destination(sdcsd);} }匿名内部类既可以扩展类也可以实现接口但是在实现接口时变不能继承继承时便不能实现接口而且实现接口时只能实现一个接口。 嵌套类 嵌套类不需要内部类对象与其外围类对象有联系那么可以将内部类声明为static。普通的内部类不能有static数据和static字段也不能包含嵌套类。但是嵌套类可以包含所有的这些东西。 接口中的类 接口中的任何类修饰都是public和static的可以在接口中的内部类实现其外围接口。如果想创建某些公共代码使得他们都可以被某个接口的的所有不同实现所共用name使用接口内部的嵌套类会很方便。 转载于:https://my.oschina.net/PrivateO2/blog/1575796

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/91251.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网站建设合同表(书)vps如何做网站步骤

这篇文章将介绍如何使用Guava EventBus将更改发布到Java 7 WatchService检测到的目录或子目录中。 Guava EventBus是向应用程序添加发布/订阅通信的好方法。 Java 7 java.nio.file软件包中新增的WatchService用于监视目录中的更改。 由于EventBus和WatchService已在以前的文章中…

网站设置什么意思360建筑网一级消防

本文讨论了领导者在沟通过程中如何避免成为传声筒,通过筛选、处理和总结信息,在向上、向下沟通时保持相关性和真实性,提高沟通效率和效果。原文: The Dumbest Mistake Leaders Make in Communication 中层管理者作为高层领导、下属团队和其他…

网站建设活动广告网站建设 工作建议

我们知道,只要在一个Java类上加上Component、Service、Controller等注解,就可以被加载到Spring容器中,除了以上方式,加了Bean和Import好像也可以将对象添加到Spring容器中,究竟Spring是如何实现这些功能的呢&#xff1…

东莞外贸网站设计网页设计入门教学视频

一、python介绍python的创始人为吉多・范罗苏姆(Guido van Rossum)目前python主要应用领域:・云计算・WEB开发・科学运算、人工智能・系统运维・金融:量化交易,金融分析等,作为动态语言的python,语言结构清晰简单&…

绍兴网站推广福永网站建设公司

背景互联网时代的数据重要性不言而喻,任何数据的丢失都会给企事业单位、政府机关等造成无法计算和无法弥补的损失,尤其随着云计算和大数据时代的到来,数据中心的规模日益增大,环境更加复杂,云上客户群体越来越庞大&…

国外做储物柜的网站wordpress功能小工具栏

落地灯对于上班族、学生党来说真的很友好,能够提供贴合眼睛用光舒适的光度,使这些日常长时间用眼的人能够减少不良光线对眼睛造成的影响,从而科学健康的用眼! 市面上的落地灯产品越来越多,琳琅满目的产品让不少刚接触落…

环保设备网站建设模板舆情网站直接打开怎么弄

在最后的社区主题演讲后,我前往希尔顿金门大桥3/4/5观看了维克多巴生 ( Viktor Klang )的( Typesafe )“上,下,外:Akka”演讲。 巴生(Klang)是Akka的技术主管…

烟台网站制作工具什么样的网站好优化

在很多python脚本中在最后的部分会执行一个判断语句if __name__ "__main__:",之后还可能会有一些执行语句。那添加这个判断的目的何在? 在python编译器读取源文件的时候会执行它找到的所有代码,而在执行之前会根据当前运行的模块是…

织梦搬家 网站空白网站建设的平台分析

save和saveOrUpdate之间的区别是什么或save和persist之间的区别是任何Hibernate面试中常见的面试问题,就像Hibernate中get和load方法之间的区别一样。 Hibernate Session类提供了几种通过save , saveOrUpdate和persist等方法将对象保存到数据库中的方法。…

网站建设核心点tp框架做餐饮网站

ConfigurableListableBeanFactory 提供bean definition的解析,注册功能,再对单例来个预加载(解决循环依赖问题). 貌似我们一般开发就会直接定义这么个接口了事.而不是像Spring这样先根据使用情况细分那么多,到这边再合并 ConfigurableListableBeanFactory具体: 1、…

做公司网站的费用计入什么科目wordpress图片添加音乐

泽宇对自己的研究方向也就是知识图谱嵌入(KG Embedding)技术进行了总结,并制作了一套slides,力求让大家只看slides就可以理解并掌握知识图谱嵌入的相关知识和最新研究情况,包括知识图谱嵌入的基本概念、方法分类和经典…

给公司建立网站不可以做到的网络架构图怎么画

目录 0 引言1 函数指针模拟多播委托 🙋‍♂️ 作者:海码007📜 专栏:UE虚幻引擎专栏💥 标题:【UE 委托】如何利用函数指针理解委托的基本原理❣️ 寄语:书到用时方恨少,事非经过不知难…

公司网站维护一般需要做什么大数据技术建设网站

共享指针是 C 中一种智能指针,用于管理动态内存。它可以有效防止内存泄漏和悬空指针问题。在实际项目中,共享指针有以下几种常见的用法: 1. 管理对象的生命周期 共享指针可以用来管理对象的生命周期。当最后一个共享指针指向的对象时&#…

设计师网站 pins东营刚刚发生

目录 1.软件与平面基础 2.互联网插画 3.互联网运营设计 4.C4D三维制作 5.UI设计基础

新乡模板建站WordPress输出当前网址

一个程序被加载到内存当中运作,那么在内存内的那个数据就被称为进程(process)。 进程是操作系统上非常重要的概念,所有系统上面跑的数据都会以进程的型态存在。 进程 在 Linux底下所有的指令与能够进行的动作都与权限有关,而系统如何判定权…

网站建设控制面板怎么设置网页图片下载不了怎么办

还不错… 生成后一般放在imgs的下面. link:favicon tab 导入链接http://www.faviconico.org/

小型影视网站源码制作软件下载

模糊集基本理论 典型隶属函数 如前所述, 构造恰当的隶属函数是模糊集理论应用的基础。一种基本的构造隶属函数的方法是“参考函数法”, 即参考一些典型的隶属函数, 通过选择适当的参数, 或通过拟合、整合、实验等手段得到需要的隶属函数。 下面介绍典型隶属函数(最早由法国学者…

全国 做网站的企业网站分析报告范文

写在开头:本章是Hive教程第六部分,着重于归纳SQL编写。文章内容输出来源:拉勾教育大数据高薪训练营。本章将介绍Hive中常见的面试题和自己的解答思路,以供大家训练和记忆。SQL面试题1、求连续7天登录的用户— 数据。uid dt status…

做企业网站需要注意哪些网页制作工具有哪些

文章目录机器学习定义说人话例子专家系统 定义好, 应招,速度快机器学习 实验 奖惩 调参对象任务 TASK T一个或多个经验 EXPERIENCE性能PERFORMANCE类比人类学习监督学习半监督学习无监督学习增强学习可解决问题不可解决问题举例f(x&#xff0…

广州营销型网站优化做的很好的网站

一、查询 递归查询 寻找的值比根节点大&#xff0c;遍历右子树&#xff1b; 寻找的值比根节点小&#xff0c;遍历左子树。 def qurey(self, node, val):if not node: # 没有节点&#xff0c;返回空return Noneif node.data < val:return self.qurey(node.rchild, val)el…