Java编程思想:内部类基础部分
- public class Test {
- public static void main(String[] args) {
- // Parcel1.test();
- // Parcel2.test();
- // Sequence.test();
- DotThis.test();
- }
- }
- class Parcel1 {
- class Contents {
- private int i = 11;
- public int value() {
- return i;
- }
- }
- class Destination {
- private String label;
- Destination(String whereTo) {
- label = whereTo;
- }
- String readLabel() {
- return label;
- }
- }
- public void ship(String dest) {
- Contents c = new Contents();
- Destination d = new Destination(dest);
- System.out.println(d.readLabel());
- }
- public static void test() {
- Parcel1 p = new Parcel1();
- p.ship("A");
- }
- }
- /*
- 更典型的情况是:外部类将有一个方法,该方法返回一个指向内部类的引用。
- 截止到目前,内部类都是有方案被更换的
- */
- class Parcel2 {
- class Contents {
- private int i = 11;
- public int value() {
- return i;
- }
- }
- class Destination {
- private String label;
- Destination(String whereTo) {
- label = whereTo;
- }
- String readLabel() {
- return label;
- }
- }
- public Destination to(String s) {
- return new Destination(s);
- }
- public Contents contents() {
- return new Contents();
- }
- public void ship(String dest) {
- //上一个实验中,这儿是手动new出来的
- Contents c = contents();
- Destination d = to(dest);
- System.out.println(d.readLabel());
- }
- public static void test() {
- Parcel2 p = new Parcel2();
- p.ship("B");
- Parcel2 p2 = new Parcel2();
- Parcel2.Destination d = p2.to("C");
- Parcel2.Contents c = p2.contents();
- }
- }
- /*
- 当生成一个内部类的对象时,此对象与制造它的外围对象之间就有了一种联系,所以它能访问
- 其他外围对象的所有成员,而不需要任何特殊条件。此外,内部类还拥有其外部类的所有元素
- 的访问权。
- 我突然想到了一件事,实现Iterable接口的iterator()方法时,我们就返回的是一个内部
- 类。一直不理解这个内部类设计的好处,现在发现自己一直在用它。
- */
- /*
- 当某个外部类的对象创建了一个内部类对象时,此内部类对象必定会秘密的捕获一个指向那个
- 外部类的引用。内部类对象只能在与其外围类的对象相关联的情况下才能被创建(在内部类是
- 非static类时)。
- */
- interface Selector {
- boolean end();
- Object current();
- void next();
- }
- class Sequence {
- private Object[] items;
- private int next = 0;
- public Sequence(int size) {
- items = new Object[size];
- }
- public void add(Object x) {
- if (next < items.length) {
- items[next]=x;
- next++;
- }
- }
- private class SequenceSelector implements Selector {
- private int i = 0;
- @Override
- public boolean end() {
- /*
- 书中的逻辑:return i == items.length;
- 我觉得不太严谨,又没有说,一定要把items装满,除非你想取到空元素
- 我的逻辑:
- return i >= next;
- */
- return i >= next;
- }
- @Override
- public Object current() {
- if (i < next) {
- return items[i];
- }
- return null;
- }
- @Override
- public void next() {
- i++;
- }
- }
- private Selector selector() {
- return new SequenceSelector();
- }
- public static void test() {
- Sequence sequence = new Sequence(100);
- for (int i = 0; i < 10; i++) {
- sequence.add(Integer.toString(i));
- }
- Selector selector = sequence.selector();
- while (!selector.end()) {
- System.out.println(selector.current()+" ");
- selector.next();
- }
- }
- }
- /*
- 需求:
- 如果你在内部类中需要生成对外部类的对象的引用,可以使用外部类的名字后面紧跟圆点和
- this。
- */
- class DotThis {
- void f() {
- System.out.println("DotThis.f()");
- }
- public class Inner {
- public DotThis outer() {
- return DotThis.this;
- }
- }
- public Inner inner() {
- return new Inner();
- }
- public static void test() {
- DotThis outter = new DotThis();
- DotThis.Inner inner = outter.inner();
- inner.outer().f();
- }
- }
- /*
- 需求:
- 有时,你可能想要告知某些其他对象,去创建某个内部类的对象。要实现这个目的,你必须
- 在new表达式中提供对其他外部类对象的引用,这就需要.new语法。
- ——怎么告知?
- 我感觉这就是一个,创建内部类对象的语法
- 想要直接创建内部类的对象,不能去引用外部内的名字,而必须使用外部类的对象来创建该
- 内部类的对象,就像在上面的程序中所看到的那样。
- */
- class DotNew {
- public class Inner {
- }
- public static void test() {
- DotNew dn = new DotNew();
- /*
- 这种编码果然创建不了内部类的对象,编译器报错说:DotNew.this cannot 关联到
- 一个静态的上下文。联系上文说的,创建一个内部类时是需要捕捉一个外围内的引用的
- 这种方式得不到外围类的引用, 所以无法完成创建。
- DotNew.Inner di = new DotNew.Inner();
- */
- DotNew.Inner di = dn.new Inner();
- }
- }
- class Parcel3 {
- class Contents {
- private int i = 11;
- public int value() {
- return i;
- }
- }
- class Destination {
- private String label;
- Destination(String whereTo) {
- label = whereTo;
- }
- String readLabel() {
- return label;
- }
- }
- public static void test() {
- Parcel3 p = new Parcel3();
- Parcel3.Contents c = p.new Contents();
- Parcel3.Destination d = p.new Destination("D");
- }
- }
Java编程思想:内部类基础部分的更多相关文章
- Java编程思想学习(八) 内部类
可以将一个类的定义放在另一个类的定义内部,这就是内部类. 内部类的定义是简单的,但是它的语法确实很是复杂,让人不是很好理解.下面就内部类做一个小结. 一.内部类的分类 总的来讲内部类分为普通内部类,匿 ...
- java编程思想-基础
interface: 方法默认为public:成员变量默认 static and final 对象数组的定义:理解? 多接口继承:可以多个接口,但只有一个具体类,具体类在前面 自:多接口继承时,来自不 ...
- 《java编程思想》--多线程基础--Runnable
一.简单说下Runnable是什么 1.它是一个接口 2.只提供了run方法 3.这个接口提供了一个协议:实现这个接口的类是active的(不必成为Thread的子类) 4.run方法没有返回值 /* ...
- Java编程思想 (1~10)
[注:此博客旨在从<Java编程思想>这本书的目录结构上来检验自己的Java基础知识,只为笔记之用] 第一章 对象导论 1.万物皆对象2.程序就是对象的集合3.每个对象都是由其它对象所构成 ...
- Java编程思想(前十章)
Java编程思想 有C++编程基础的条件下, 前10章可以快速过一下,都是基本语法,不需要花太多时间. 着重中后段的一些章节,类型信息.泛型.容器.IO.并发等. 中文翻译版 阅读地址 对于一个架构师 ...
- 《Java编程思想第四版完整中文高清版.pdf》-笔记
D.2.1 安插自己的测试代码 插入下述“显式”计时代码,对程序进行评测: long start = System.currentTimeMillis(); // 要计时的运算代码放在这儿 long ...
- 《Java编程思想第四版》附录 B 对比 C++和 Java
<Java编程思想第四版完整中文高清版.pdf>-笔记 附录 B 对比 C++和 Java “作为一名 C++程序员,我们早已掌握了面向对象程序设计的基本概念,而且 Java 的语法无疑是 ...
- Java编程思想第四版勘误
坊间传说这本书翻译得很烂,我倒觉得还好.虽然看原文更准确,但是如果在具备一定编程思维和基础.能够看出来疑问的情况下,还是看中文更快一些,而且这本书本身也不适合初学者看.当然,错误和不通顺还是有的,而且 ...
- 《Java编程思想》阅读笔记二
Java编程思想 这是一个通过对<Java编程思想>(Think in java)进行阅读同时对java内容查漏补缺的系列.一些基础的知识不会被罗列出来,这里只会列出一些程序员经常会忽略或 ...
- Java编程思想(第4版) 中文清晰PDF完整版
Java编程思想(第4版) 中文清晰PDF完整版 [日期:2014-08-11] 来源:Linux社区 作者:Linux [字体:大 中 小] <Java编程思想>这本书赢得了全 ...
随机推荐
- 解决iconv函数无法转换某些中文的问题
原文: 解决iconv函数无法转换某些中文的问题 请先看以下代码,这个页面是GB2312编码的: $str = '陶喆';echo 'gb2312-'.$str;echo '<br />' ...
- C#管理服务停止启动
由于机器性能问题,把许多服务关闭了,需要用的时候再开启,这样每次都打开服务管理或cmd命令比较麻烦.就自己写了工具显示在桌面上; 声明:ServiceController myController = ...
- Qt 5.6 5.8 vs2015 编译静态库版本(有全部的截图)good
安装Qt 去Qt官网下载Qt安装包 安装Qt和源码,一定要勾选source选项 添加bin到系统变量 工具 需要python3和 perl. vs2015 第三方工具,到官方下载安装 在命令行 ...
- Access Violation分成两大类:运行期和设计期(很全的解释)
用Delphi开发程序时,我们可以把遇到的Access Violation分成两大类:运行期和设计期. 一.设计期的Access Violation 1.硬件原因 在启动或关闭Delphi IDE以 ...
- 【图文】[新手]C++ 动态库导出函数名“乱码”及解决
刚接触C++,在尝试从 dll 中导出函数时,发现导出的函数名都"乱码"了. 导出过程如下: 新建一个Win32项目: 新建的解决方案里有几个导出的示例: // 下列 ifdef ...
- python算法与数据结构-循环链表(39)
一.循环链表的介绍 上一篇我们已经讲过单链表,本篇给大家讲解循单链表的一个变形是单向循环链表,链表中最后一个节点的next域不再为None,而是指向链表的头节点,其基本操作和单链表思路一样. 常用的操 ...
- spark streaming 接收kafka消息之四 -- 运行在 worker 上的 receiver
使用分布式receiver来获取数据使用 WAL 来实现 exactly-once 操作: conf.set("spark.streaming.receiver.writeAheadLog. ...
- c++汉诺塔相关知识总结1
困扰已久,难以攻克的汉诺塔总结来啦 Part One 汉诺塔到底是什么呢? 汉诺塔(Tower of Hanoi)源于印度传说中,大梵天创造世界时造了三根金钢石柱子,其中一根柱子自底向上叠着64片黄金 ...
- ThreadLocal使用原理、注意问题、使用场景
想必很多朋友对ThreadLocal并不陌生,今天我们就来一起探讨下ThreadLocal的使用方法和实现原理.首先,本文先谈一下对ThreadLocal的理解,然后根据ThreadLocal类的源码 ...
- 跟我学SpringCloud | 第一篇:介绍
首先讲一下我为什么要写这一系列的文章,现在网上大量的springcloud相关的文章,使用的springboot和springcloud的版本都相对比较老,很多还是在使用springboot1.x的版 ...