黑马程序员 面向对象 Object与内部类
2015-04-17 17:53
417 查看
1、Object:是所有类直接或间接的父类,该类中具备所有对象都具备的功能。
2、 内部类:将以各类定义在另一个类里面,内部的类就叫做内部类。
▲内部类的访问规则:
内部类可以直接访问外部类中的成员,包括私有。
外部类要访问内部类,必须建立内部类的对象。
内部类之所以可以直接访问外部类中的成员,因为内部类中有一个外部类的引用,格式为:外部类名.this。
▲访问格式:
当内部类定义在外部类成员位置上,非私有,可在外部其他类中直接建立内部类对象。
外部类名.内部类名 变量名 = 外部类对象.内部类对象
Outer.Inner o = new Outer().new Inner();
当内部类定义在成员位置上,就可以被成员修饰符所修饰:
•private:将内部类在外部类中进行封装。
•static:内部类中具有static的属性。
当内部类被static修饰后,只能访问外部类中static成员,有访问局限。
在外部其他类中,直接访问static内部类的非静态成员:
new.Outer.Inner().function();
在外部其他类中,直接访问static内部类的非静态成员:
Outer.Inner.function();
注:当内部类中定义了静态成员,该内部类必须是静态的。
▲描述市事物内部时,事物的内部还有事物,该事物利用内部类描述,因为内部事务在使用外部事务。
内部类定义在局部时,不可以被成员修饰符修饰,可以直接访问外部类中成员,因为还持有外部类中引用,但不可以访问它所在的局部中变量,只能访问被final修饰的局部变量。
3、 匿名内部类
匿名内部类其实就是内部类的简写格式。
定义匿名内部类前提:内部类必须继承一个类或者接口。
匿名内部类的格式:
匿名内部类就是一个匿名子类对象。
2、 内部类:将以各类定义在另一个类里面,内部的类就叫做内部类。
▲内部类的访问规则:
内部类可以直接访问外部类中的成员,包括私有。
外部类要访问内部类,必须建立内部类的对象。
内部类之所以可以直接访问外部类中的成员,因为内部类中有一个外部类的引用,格式为:外部类名.this。
▲访问格式:
当内部类定义在外部类成员位置上,非私有,可在外部其他类中直接建立内部类对象。
外部类名.内部类名 变量名 = 外部类对象.内部类对象
Outer.Inner o = new Outer().new Inner();
当内部类定义在成员位置上,就可以被成员修饰符所修饰:
•private:将内部类在外部类中进行封装。
•static:内部类中具有static的属性。
当内部类被static修饰后,只能访问外部类中static成员,有访问局限。
在外部其他类中,直接访问static内部类的非静态成员:
new.Outer.Inner().function();
在外部其他类中,直接访问static内部类的非静态成员:
Outer.Inner.function();
注:当内部类中定义了静态成员,该内部类必须是静态的。
▲描述市事物内部时,事物的内部还有事物,该事物利用内部类描述,因为内部事务在使用外部事务。
内部类定义在局部时,不可以被成员修饰符修饰,可以直接访问外部类中成员,因为还持有外部类中引用,但不可以访问它所在的局部中变量,只能访问被final修饰的局部变量。
3、 匿名内部类
匿名内部类其实就是内部类的简写格式。
定义匿名内部类前提:内部类必须继承一个类或者接口。
匿名内部类的格式:
<code class="hljs cs has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;"> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">new</span>.父类或借口() { 定义子类内容 } 函数</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li></ul>
匿名内部类就是一个匿名子类对象。
<code class="hljs actionscript has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;">Class Outer { <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">private</span> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">static</span> int x = <span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">3</span>; <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">static</span> <span class="hljs-class" style="box-sizing: border-box;"><span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">class</span> <span class="hljs-title" style="box-sizing: border-box; color: rgb(102, 0, 102);">Inner</span> {</span> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">static</span> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">void</span> <span class="hljs-function" style="box-sizing: border-box;"><span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">function</span><span class="hljs-params" style="color: rgb(102, 0, 102); box-sizing: border-box;">()</span> {</span> System.out.println(“inner:”+x) } } <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">static</span> <span class="hljs-class" style="box-sizing: border-box;"><span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">class</span> <span class="hljs-title" style="box-sizing: border-box; color: rgb(102, 0, 102);">Inner2</span> {</span> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">void</span> show() { System.out.println(“inner2 show”) } } Public <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">static</span> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">void</span> method() { Inner.<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">function</span>(); New.Inner2().show(); } } <span class="hljs-class" style="box-sizing: border-box;"><span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">class</span> <span class="hljs-title" style="box-sizing: border-box; color: rgb(102, 0, 102);">InnerDemo</span> {</span> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">public</span> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">static</span> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">void</span> main(String[] args) { Outer.method(); } } </code>
相关文章推荐
- 黑马程序员--面向对象三(final、abstract、Interface、Object、内部类)
- 黑马程序员_面向对象_内部类与枚举类
- 黑马程序员_面向对象_多态_内部类
- 黑马程序员_面向对象(二)_继承、多态、内部类
- 黑马程序员--面向对象学习---接口、多态、内部类、异常
- 黑马程序员 面向对象--抽象类、接口、内部类总结
- 黑马程序员——Java面向对象之抽象类 接口 内部类笔记
- 黑马程序员_面向对象:继承、多态、内部类
- 黑马程序员--面向对象第二部分-内部类、异常--java学习日记6(基础知识)
- 黑马程序员 面向对象 多态 需求 object
- 黑马程序员_面向对象2_(继承、多态、抽象类abstract、接口interface、内部类)
- 黑马程序员-面向对象-08天-3 (Object)
- 黑马程序员—java面向对象总结(4)—内部类、异常
- 面向对象 object 内部类
- 黑马程序员_第五天 面向对象(二)_继承、多态、内部类
- 黑马程序员_面向对象二(继承,多态,抽象类abstract,接口Interface,内部类)
- 黑马程序员--------java面向对象 内部类、异常
- 黑马程序员--Java学习笔记之面向对象思想(多态、内部类、匿名内部类、异常类)
- 黑马程序员_Java面向对象_内部类
- 黑马程序员_java面向对象总结【4】(内部类、异常处理、Package)