×
暂无评论
图文详情
  • ISBN:7111212509
  • 装帧:简裝本
  • 册数:暂无
  • 重量:暂无
  • 开本:32
  • 页数:1508
  • 出版时间:2007-04-01
  • 条形码:9787111212508 ; 978-7-111-21250-8

内容简介

本书曾荣获:
2003年《Software Development》杂志Jolt大奖
2002年《Java Developer’s Journal》读者*佳选择图书奖
2001年《JavaWorld》杂志编辑推荐图书奖
2000年《JavaWorld》读者*佳选择图书奖
1999年《Software Development》杂志*佳产品奖
1998年《Java Developer’s Journal》编辑推荐*佳图书奖

本书赢得了全球程序员的广泛赞誉,即使是*晦涩的概念,在Bruce Eckel的文字亲和力和小而直接的编程示例面前也会化解于无形。从Java的基础语法到*高级特性,本书都能逐步指导你轻松掌握。

前言

一开始,我只是将Java看作“又一种程序设计语言”。从许多方面看,它也的确如此。
但随着时间流逝,以及对Java的深入研究,我渐渐发现,与我所见过的其他编程语言相比,Java有着完全不同的核心目的。
程序设计其实是对复杂性的管理:待解决问题的复杂性,以及用来解决该问题的工具的复杂性。正是这种复杂性,导致多数程序设计项目失败。在我所知的所有程序设计语言中,几乎没有哪个将自己的设计目标专注于克服开发与维护程序的复杂性。当然,有些编程语言在设计决策时也曾考虑到复杂性的问题,然而,总是会有其他议题被认为更有必要加入到该语言中。于是不可避免地,正是这些所谓更必要的议题导致程序员*终“头撞南墙”。例如,C++选择向后兼容C(以便更容易吸引C程序员),以及具备C一样的高效率。这两点都是非常有益的设计目标,也确实促成了C++的成功,然而它们却暴露出更多的复杂性问题,而这也使得很多项目不得善终(你自然可以责怪程序员或者项目管理,但是,如果一种语言能够帮助你解决错误,那何乐而不为呢?)。再看一个例子,Visual Basic(VB)选择与Basic绑在一起,而Basic并未被设计为具备可扩展性的程序设计语言,结果呢,建立在VB之上的所有扩展都导致了无法维护的语法。还有Perl,它向后兼容awk、sed、grep,以及所有它打算替代的Unix工具,结果呢,人们开始指责Perl程序成了“不可阅读(write-only)的代码”(即,只要稍过一会儿,你就读不懂刚完成的程序了)。从另一个角度看,在设计C++,VB,Perl,以及Smalltalk之类的程序设计语言时,设计师也都为解决复杂性问题做了某种程度的工作。并且,正是解决某类特定问题的能力,成就了它们的成功。
随着对Java的了解越来越深,Sun对Java的设计目标给我留下了*深刻印象,那就是:为程序员减少复杂性。用他们的话说就是:“我们关心的是,减少开发健壮代码所需的时间以及困难。”在早期,这个目标使得代码的运行并不快(Java程序的运行效率已经改善了),但它确实显著地缩短了代码的开发时间。与用C++开发相同的程序相比,采用Java只需一半甚至更少的开发时间。仅此一项,就已经能节约无法估量的时间与金钱了。然而Java并未止步于此。它开始着手解决日渐变得重要的各种复杂任务,例如多线程与网络编程,并将其作为语言特性或以工具库的形式纳入Java,这使得开发此类应用变得倍加简单。*终,Java解决了一些相当大的复杂性问题:跨平台编程、动态代码修改,甚至是安全的议题。它让你在面对其中任何一个问题时,都能从“举步维艰”到“起立鼓掌”。抛去我们都能看到的性能问题,Java确实非常精彩地履行了它的诺言:极大地提升程序员的生产率。
同时,Java正从各个方面提升人们相互通讯的带宽。它使得一切都变得更容易:编写程序,团队合作,创建与用户交户的用户界面,在不同类型的机器上运行程序,以及编写通过因特网通信的程序。
我认为,通讯变革的成果并不见得就是传输巨量的比特。我们所看到的真正变革是人与人之间的通讯变得更容易了:无论是一对一的通信,还是群体与群体之间,甚至整个星球之间的通信。我曾听闻,在足够多的人之间的相互联系之上,下一次变革将是一种全球意识的形成。Java说不定就是促进该变革的工具,至少,它所具备的可能性使我觉得,教授这门语言是非常有意义的一件事情。
Java SE5 与 SE6
本书的第4版得益于Java语言的升级。Sun起初称其为JDK1.5,稍后改作JDK5或J2SE5,*终Sun弃用了过时的“2”,将其改为Java SE5。Java SE5的许多变化都是为了改善程序员的体验。你将会看到,Java语言的设计者们并未完全成功地完成该任务,不过,总的来说,他们已经向正确的方向迈出了一大步。
新版的一个重要目标就是完整地吸收Java SE5/6的改进,并通过本书介绍以及应用这些变化。这意味着本书基本可以称之为“只限Java SE5/6”。并且,书中的多数代码并没有经过老版本的Java编译测试,所以如果你使用的是老版本的Java,编译可能会报错并中止。不过,我觉得这样利大于弊。
如果你不得不采用老版本的Java,我仍然为你在www.MindView.net提供了本书早期版本的免费下载。基于某些原因,我决定不提供本书当前版本的免费电子版。
Java SE6
本书是一个非常耗时的,且具有里程碑意义的一个项目。就在本书出版之前,Java SE6(代号野马mustang)已经发布了beta版。虽然Java SE6中的一些小变化,对书中的代码示例有一点影响,但其主要的改进对本书的绝大部分内容并没有影响。因为Java SE6主要关注于提升速度,以及改进一些(不在本书讨论范围之内)类库的特性。
本书中代码全部用Java SE6的一个发布候选版(RC)进行过测试,因此我不认为Java SE6正式发布时会有什么变化能够影响本书的内容。如果到时真的有什么重要的改变,我将更新本书中的代码,你可以通过www.MindView.net下载。
本书的封面已经指出,本书面向“Java SE5/6”。也就是说本书的撰写“面向Java SE5及其为Java语言引入的重大变化,同时也适用于Java SE6”。
第4版
为一本书写作新版时,作者*满意的是:把事情做得“恰如其分”。这是我从本书上一个版本发布以来所学到的东西。通常而言,这种见识正如谚语所云,“学习就是从失败中汲取教训。”并且,我也借机进行了一些修订。与往常一样,一个新的版本必将带来引人入胜的新思想。此时,新发现带来的喜悦,采用比以往更好的形式表达思想的能力,已经远远超过了可能引入的小错误。
这也是对不断在我脑中盘旋低语着的一种挑战,那就是让持有本书老版本的读者也愿意购买新的版本。这些促使着我尽可能改进,重写,以及重新组织内容,为热忱的读者们献上一本全新的,值得拥有的书。
改变
此版本中将不再包含以往本书中所携带的CD光盘。该CD中的重要部分《Thinking in C》的多媒体教程(由Chuck Allison为MindView创建),现在提供了可下载的Flash版本。该教程是为不熟悉C语法的读者所准备的。虽然,本书用了两章对语法做了较为完整的介绍,然而对于没有相应背景知识的读者而言,这也许仍然不够。而《Thinking in C》正是为了帮助这些读者提升到必要的程度。
完全重写了“并发”这一章(以前称为“多线程”),以符合Java SE5并发类库的重大改变。它将为读者了解并发的核心思想打下基础。如果没有这些核心的基础知识,读者很难理解关于线程的更复杂的议题。我花了很多个月撰写这一章,深陷“并发”的地狱之中,*终,这一章不仅涵盖了基础知识,而且大胆地引入了一些高级议题。
而对于Java SE5所具有的每一个重大的新特性,本书都有一个新的章节与之对应。其他的新特性则加入到了原有的章节中。我还一直在研究设计模式,因此在本书中,也介绍了设计模式的相关内容。
本书经历了重大的重组。这大多源自教授Java的过程,以及我对于“章节”的意义的重新思考。以前,我会不假思索地认为,每个“章节”应该包含一个“足够大的”主题。但是,在我教授设计模式的时候,我发现,如果每次只介绍一个模式(即使讲课的时间很短),然后立刻组织大家做练习,此时那些学员们的表现是*好的(我发现,这种节奏对于我这个老师而言也更有乐趣)。因此,在这一版中,我试着打破按主题划分章节的做法,也不理会章节的长度。我想,这也是一个改进。
我同样也认识到代码测试的重要性。必须要有一个内建的测试框架,并且每次你开发系统时都必须进行测试。否则,根本没有办法知道代码可靠与否。为了做到这一点,我开发了一个测试框架以显示和验证本书中每一个程序的输出结果。(该框架是用Python编写的,你可以在www.MindView.net找到可下载的代码。)关于测试的话题在附录中有讨论,你可以在http://MindView.net/Books/BetterJava找到。其中还包含了其他一些基本技术,我认为所有程序员都应该将它们加入到自己的工具箱中。
此外,我还仔细检查了书中的每一个示例,并且问我自己,“我为什么采用这种方式实现?”对大多数的示例,我都做了一定程度的修订与改进,使得这些示例更加贴切。同时,也传达出我所认为的Java编程中的*佳实践(至少起到抛砖引玉的作用)。许多以前的示例都经过了重新设计与重新编写;同时,删除了不再有意义的示例,也添加了新的示例。
读者们为此书的前三个版本提出了许多许多精彩的意见。这自然使我觉得非常高兴。不过,偶尔读者也会有抱怨,例如有读者埋怨“本书太长了”。对我而言,如果“页数太多”是你唯一的苦恼,那这真令人哭笑不得。(据说奥地利皇帝曾抱怨莫扎特的音乐“音符太多”!我可不是想把自己比作莫扎特。)此外,我只能猜测,发出这种抱怨的读者还不了解Java语言的博大精深,而且也没有看过这一领域的其他书籍。无论如何,在这一版中,我已经删减了过时无用,或不再重要内容。总的来说,我已经尽我所能仔细复查了全书,进行了必要的增删与改进。对于删除旧的章节,我还是挺放心的。因为原始的材料在网站上都有(www.MindView.net)。本书从**版到第三版,以及本书的附录,都可以从此网站上下载。
对于仍然不能接受本书篇幅的读者,我向你们道歉。请相信,我已经尽我所能精简本书的长度了。
封面图片的故事
《Java编程思想》的封面创作灵感来自于美国的 Arts & Crafts运动。该运动始于世纪之交,并在1900 到1920年间达到顶峰。它起源于英格兰,是对工业革命带来的机器产品和维多利亚时代高度装饰化风格的回应。Arts & Crafts强调简洁设计,而回归自然是其整个运动的核心,注重手工制造及推崇个性化设计,可是它并不回避使用现代工具。这和我们现今的情形有很多相似之处:世纪之交,从计算机革命的*初起源到对个人来说更精简、更意味深长的事物的演变,以及对软件开发技能而不仅是生产程序代码的强调。
我以同样的眼光看待Java:尝试将程序员从操作系统机制中解放出来,朝着“软件艺师”的方向发展。
我和封面设计者自孩提时代就是朋友,我们从这次运动中获得灵感,并且都拥有源自那个时期的(或受那个时期启发而创作的)家具、台灯和其他作品。
这个封面暗示的另一主题是一个收集盒,博物学家可以用它来展示他们保存的昆虫标本。这些昆虫可以看作是对象,并放置到“盒”这个对象当中,而盒对象又放置到“封面对象”当中,这形象地说明了面向对象程序设计中*为基本的“集合”概念。当然,程序员可能会不禁联想到“程序缺陷(bug)”;这些虫子被捕获,并假设在标本罐中被杀死,*后禁闭于一个展示盒中,似乎暗示Java有能力发现、显示和制服程序缺陷(事实上,这也是它*为强大的属性之一)。
在本版中,我创造了一幅水彩画,你可以在封面的背景中看到它。

目录

读者评论
前言
简介
第1章 对象导论
1.1 抽象过程
1.2 每个对象都有一个接口
1.3 每个对象都提供服务
1.4 被隐藏的具体实现
1.5 复用具体实现
1.6 继承
1.6.1 “是一个”(is-a)与“像是一个”(is-like-a)关系
1.7 伴随多态的可互换对象
1.8 单根继承结构
1.9 容器
1.9.1 参数化类型(范型)
1.10 对象的创建和生命期
1.11 异常处理:处理错误
1.12 并发编程
1.13 Java与Internet
1.13.1 Web是什么
1.13.2 客户端编程
1.13.3 服务器端编程
1.22 总结
第2章 一切都是对象
2.1 用引用操纵对象
2.2 必须由你创建所有对象
2.2.1 存储到什么地方
2.2.2 特例:基本类型
2.2.3 Java中的数组
2.3 永远不需要销毁对象
2.3.1 作用域
2.3.2 对象的作用域
2.4 创建新的数据类型:类
2.4.1 域和方法
2.4.2 基本成员默认值
2.5 方法、参数和返回值
2.5.1 参数列表
2.6 构建一个Java程序
2.6.1 名字可见性
2.6.2 运用其他构件
2.6.3 static 关键字
2.7 你的**个Java程序
编译和运行
2.8 注释和嵌入式文档
2.8.1 注释文档
2.8.2 语法
2.8.3 嵌入式HTML
2.8.4 一些标签示例
2.8.5 文档示例
2.9 编码风格
2.10 总结
2.11 练习
第3章 操作符
3.1 更简单的打印语句
3.2 使用Java操作符
3.3 优先级
3.4 赋值
3.4.1 方法调用中的别名问题
3.5 算术操作符
3.5.1 一元加、减操作符
3.6 自动递增和递减
3.7 关系操作符
3.7.1 测试对象的等价性
3.8 逻辑操作符
3.8.1 短路
3.9 直接常量
3.9.1 指数记数法
3.10 按位操作符
3.11 移位操作符
3.12 三元操作符 if-else
3.13 字符串操作符 + 和 +=
3.14 使用操作符时常犯的错误
3.15 类型转换操作符
3.15.1 截尾和舍入
3.15.2提升
3.16 Java没有“sizeof”
3.17 操作符小结
3.18 总结
第4章 控制执行流程
4.1 true和false
4.2 if-else
4.3 迭代
4.3.1 do-while
4.3.2 for
4.3.3 逗号操作符
4.4 Foreach语法
4.5 return
4.6 break和 continue
4.7 臭名昭著的“goto”
4.8 switch
4.9 总结
第5章 初始化与清理
5.1 用构造器确保初始化
5.2 方法重载
5.2.1 区分重载方法
5.2.2 涉及基本类型的重载
5.2.3 以返回值区分重载方法
5.3 缺省构造器
5.4 this关键字
5.4.1 在构造器中调用构造器
5.4.2 static的含义
5.5 清理:终结处理和垃圾回收
5.5.1 finalize()的用途何在
5.5.2 你必须实施清理
5.5.3 终结条件
5.5.4 垃圾回收器如何工作
5.6 成员初始化
5.6.1 指定初始化
5.7 构造器初始化
5.7.1 初始化顺序
5.7.2. 静态数据的初始化
5.7.3. 显式的静态初始化
5.7.4. 非静态实例初始化
5.8 数组初始化
5.8.1 可变参数列表
5.9 枚举类型
5.10 总结
第6章 访问权限控制
6.1 包:库单元
6.1.1 代码组织
6.1.2 创建独一无二的包名
6.1.3 定制工具库
6.1.4 用 import改变行为
6.1.5 对使用包的忠告
6.2 Java访问权限修饰词
6.2.1 包访问权限
6.2.2 public:接口访问权限
6.2.3 private: 你无法访问
6.2.4 protected:继承访问权限
6.3 接口和实现
6.4 类的访问权限
6.5 总结
第7章 复用类
7.1 组合语法
7.2 继承语法
7.2.1 初始化基类
7.3 代理
7.4 结合使用组合和继承
7.4.1 确保正确清理
7.4.2 名称屏蔽
7.5 在组合与继承之间选择
7.6 protected关键字
7.7 向上转型
7.7.1 为什么称为“向上转型”?
7.7.2 再论组合与继承
7.8 final关键字
7.8.1 final 数据
7.8.2 final 方法
7.8.3 final 类
7.8.4 有关final的忠告
7.9 初始化及类的加载
7.9.1 继承与初始化
7.10 总结
第8章 多态
8.1 再论向上转型
8.1.1 忘记对象类型
8.2 转机
8.2.1 方法调用绑定
8.2.2 产生正确的行为
8.2.3 可扩展性
8.2.4 缺陷:“覆盖”私有方法
8.2.5 缺陷:域与静态方法
8.3 构造器和多态
8.3.1 构造器的调用顺序
8.3.2 继承与清理
8.3.3 构造器内部的多态方法的行为
第9章 接口
9.1 抽象类和抽象方法
9.2 接口
9.3 完全解耦
9.4 Java中的“多重继承”
9.5 通过继承来扩展接口
9.5.1 组合接口时的名字冲突
9.6 适配接口
9.7 接口中的域
9.7.1 初始化接口中的域
9.8 嵌套接口
9.9 接口与工厂
9.10 总结
第10章 内部类
10.1 创建内部类
10.2 链接到外部类
10.3 使用.this与.new
10.4 内部类与向上转型
10.5 在方法和作用域内的内部类
10.6 匿名内部类
10.6.1 再访工厂方法
10.7 嵌套类
10.7.1 接口内部的类
10.7.2 从多层嵌套类中访问外部类的成员
10.8 为什么需要内部类
10.8.1 闭包与回调
10.8.2 内部类与控制框架
10.9 内部类的继承
10.10 内部类可以被覆盖吗
10.11 局部内部类
10.12 内部类标识符
10.13 总结
第11章 持有对象
11.1 泛型和类型安全的容器
11.2 基本概念
11.3 添加一组元素
11.4 容器的打印
11.5 List
11.6 迭代器
11.6.1 ListIterator
11.7 LinkedList
11.8 Stack
11.9 Set
11.10 Map
11.11 Queue
11.11.1 PriorityQueue
11.12 Collection和Iterator
11.13 Foreach与迭代器
11.13.1 适配器方法惯用法
11.14 总结
第12章 通过异常处理错误
12.1 概念
12.2 基本异常
12.2.1 异常参数
12.3 捕获异常
12.3.1 try块
12.3.2 异常处理程序
12.4 创建自定义异常
12.4.1 异常与记录日志
12.5 异常说明
12.6 捕获所有异常
12.6.1 栈轨迹
12.6.2 重新抛出异常
12.6.3 异常链
12.7 Java标准异常
12.7.1 特例: RuntimeException(运行时异常)
12.8 使用finally进行清理
12.8.1 finally用来做什么
12.8.2 在return中使用finally
12.8.3 缺憾:异常丢失
12.9 异常的限制
12.10 构造器
12.11 异常匹配
12.12 其他可选方式
12.12.1 历史
12.12.2 观点
12.12.3 把异常传递给控制台
12.12.4 把“受检查异常”转换为“不受检查的异常”
12.13 异常使用指南
12.14 总结
第13章 字符串
13.1 不可变String
13.2 重载"+"与StringBuilder
13.3 无意识的递归
13.4 String上的操作
13.5 格式化输出
13.5.1 printf()
13.5.2 System.out.format()
13.5.3 Formatter类
13.5.4 格式化说明符
13.5.5 Formatter转换
13.5.6 String.format()
13.6 正则表达式
13.6.1 基础
13.6.2 创建正则表达式
13.6.3 限定符
13.6.4 Pattern和Matcher
13.6.5 split()
13.6.6 替换操作
13.6.7 reset()
13.6.8 正则表达式与Java I/O
13.7 扫描输入
13.7.1 Scanner定界符
13.7.2 用正则表达式扫描
13.8 StringTokenizer
13.9 总结
第14章 类型信息
14.1 为什么需要RTTI
14.2 Class对象
14.2.1 类字面常量
14.2.2 泛化的Class引用
14.2.3 新的转型语法
14.3类型转换前先做检查
14.3.1 使用类字面常量
14.3.2 动态instanceof
14.3.3 递归计数
14.4 注册工厂
14.5 instanceof 与 Class的等价性
14.6 反射:运行时类信息
14.6.1 类方法抽取器
14.7 动态代理
14.8 空对象
14.8.1 模拟对象与桩
14.9 接口与类型信息
14.10 总结
第15章 泛型
15.1 与C++的比较
15.2 简单泛型
15.2.1 一个元组类库
15.2.2 一个栈类
15.2.3 RandomList
15.3 泛型接口
15.4 泛型方法
15.4.1 利用类型参数推断
15.4.2 可变参数与泛型方法
15.4.3 用于Generator的泛型方法
15.4.4 一个通用的Generator
15.4.5 简化元组的使用
15.4.6 一个Set实用工具
15.5 匿名内部类
15.6 构建复杂模型
15.7 擦除的神秘之处
15.7.1 C++的方式
15.7.2 迁移的可兼容性
15.7.3 擦除的问题
15.7.4 边界处的动作
15.8 擦除的补偿
15.8.1 创建类型实例
15.8.2 泛型数组
15.9 边界
15.10 通配符
15.10.1 编译器有多聪明?
15.10.2 抗变
15.10.3 无界通配符
15.10.4 捕获转换
15.11 问题
15.11.1 任何基本类型都不能作为类型参数
15.11.2 实现参数化接口
15.11.3 转型和警告
15.11.4 重载
15.11.5 基类劫持了接口
15.12 自限定的类型
15.12.1 离奇的循环泛型
15.12.2 自限定
15.12.3 参数协变
15.13 动态类型安全
15.14 异常
15.15 混用
15.15.1 C++中的混用
15.15.2 与接口混用
15.15.3 使用装饰器模式
15.15.4 与动态代理混用
15.16 潜在类型机制
15.17 缺乏潜在类型机制的补偿
15.17.1 反射
15.17.2 将一个方法应用于序列
15.17.3 当你并未碰巧拥有正确的接口时
15.17.4 用适配器仿真潜在类型机制
15.18 将函数对象用作策略
15.19 总结:转型真的如此之糟吗?
15.19.1 进阶读物
第16章 数组
16.1 数组为什么特殊
16.2 数组是**级对象
16.3 返回一个数组
16.4 多维数组
11.5 数组与泛型
16.6 创建测试数据
16.6.1 Arrays.fill()
16.6.2 数据生成器(Generator)
16.6.3 从Generator中创建数组
16.7 Arrays实用功能
16.7.1 复制数组
16.7.2 数组的比较
16.7.3 数组元素的比较
16.7.4 数组排序
16.7.5 在已排序的数组中查找
16.8 总结
第17章 容器深入研究
17.1 完整的容器分类法
17.2 填充容器
17.2.1 一种Generator解决方案
17.2.2 Map生成器
17.2.3 使用Abstract类
17.3 Collection的功能方法
17.4 可选操作
17.4.1 未获支持的操作
17.5 List的功能方法
17.6 Set和存储顺序
17.6.1 SortedSet
17.7 队列
17.7.1 优先级队列
17.7.2 双向队列
17.8 理解Map
17.8.1 性能
17.8.2 SortedMap
17.8.3 LinkedHashMap
17.9 散列与散列码
17.9.1 理解hashCode()
17.9.2 为速度而散列
17.9.3 覆盖hashCode()
17.10 选择接口的不同实现
17.10.1 性能测试框架
17.10.2 对List的选择
17.10.3 微基准测试的危险
17.10.4 对Set的选择
17.10.5 对Map的选择
17.11 实用方法
17.11.1 List的排序和查询
17.11.2 设定Collection或Map为不可修改
17.11.3 Collection或Map的同步控制
17.12 持有引用
17.12.1 WeakHashMap
17.13 Java 1.0/1.1 的容器
17.13.1 Vector 和 Enumeration
17.13.2 Hashtable
17.13.3 Stack
17.13.4 BitSet
17.14 总结
第18章 Java I/O系统
18.1 File类
18.1.1目录列表器
18.1.2 目录实用工具
18.1.3 目录的检查及创建
18.2 输入和输出
18.2.1 InputStream类型
18.2.2 OutputStream类型
18.3 添加属性和有用的接口
18.3.1 通过FilterInputStream从InputStream读取
18.3.2 通过FilterOutPutStream向OutputStream写入
18.4 Reader和Writer
18.4.1 数据的来源和去处
18.4.2 更改流的行为
18.4.3 未发生变化的类
18.5 自我独立的类:RandomAccessFile
18.6 I/O流的典型使用方式
18.6.1 缓冲的输入文件
18.6.2 从内存中输入
18.6.3 格式化的内存输入
18.6.4 基本文件输出
18.6.5 存储和恢复数据
18.6.6 读取和写入随机访问文件
18.6.7 管道流
18.7 文件读写的实用工具
18.7.1 读取二进制文件
18.8 标准I/O
18.8.1 从标准输入中读取
18.8.2 将System.out转换成PrintWriter
18.8.3 标准I/O重定向
18.9 进程控制
18.10 新I/O
18.10.1 转换数据
18.10.2 获取基本类型
18.10.3 视图缓冲器
18.10.4 用缓冲器操纵数据
18.10.5 缓冲器的细节
18.10.6 内存映射文件
18.10.7 文件加锁
18.11 压缩
18.11.1 用GZIP进行简单压缩
18.11.2 用Zip进行多文件存储
18.11.3 Java档案文件
18.12 对象序列化
18.12.1 寻找类
18.12.2 序列化的控制
18.12.3 使用“持久性”
18.13 XML
18.14 Preferences
18.15 总结
第19章 枚举类型
19.1 基本enum特性
19.1.1 将静态导入用于enum
19.2 向enum中添加新方法
19.2.1 覆盖enum的方法
19.3 switch语句中的enum
19.4 values()的神秘之处
19.5 实现但不继承随机选取
19.6 为组织而使用接口
19.7 使用EnumSet替代标志
19.8 使用EnumMap
19.9 常数相关的方法
19.9.1 使用enum的职责链
19.9.2 使用enum的状态机
19.10 多路分发
19.10.1 使用enum分发
19.10.2 使用常数相关的方法
19.10.3 使用EnumMap分发
19.10.4 使用二维数组
19.11 总结
第20章 注解
20.1 基本语法
20.1.1 定义注解
20.1.2 元注解
20.2 编写注解处理器
20.2.1 注解元素
20.2.2 缺省值限制
20.2.3 生成外部文件
20.2.4 注解不支持继承
20.2.5 实现处理器
20.3 使用apt处理注解
20.4 将观察者模式用于apt
20.5 基于注解的单元测试
20.5.1 将@Unit用于泛型
20.5.2 不需要任何“套件”
20.5.3 实现@Unit
20.5.4 移除测试代码
20.6 总结
第21章 并发
21.1 并发的多面性
21.1.1 更快的执行
21.1.2 改进代码设计
21.2 基本的线程机制
21.2.1 定义任务让步
21.2.2 Thread类
21.2.3 使用Executor
21.2.4 从任务产生返回值
21.2.5 休眠
21.2.6 优先级
21.2.7 让步
21.2.8 后台线程
21.2.9 编码的变体
21.2.10 术语
21.2.11 加入一个线程
21.2.12 创建有响应的用户界面
21.2.13 线程组
21.2.14 捕获异常
21.3 共享受限资源
21.3.1 不正确地访问资源
21.3.2 解决共享资源竞争
21.3.3 原子性与易变性
21.3.4 原子类
21.3.5 临界资源
21.3.6 在其他对象上同步
21.3.7 线程局部存储
21.4 终结任务
21.4.1 装饰性花园
21.4.2 在阻塞时终结
21.4.3 中断
21.4.4 检查中断
21.5 线程之间的协作
21.5.1 wait()与notifyAll()
21.5.2 notify()与notifyAll()
21.5.3 生产者与消费者
21.5.4 生产者-消费者与队列
21.5.5 任务间使用管道进行输入/输出
21.6 死锁
21.7 新类库中的构件
21.7.1 CountDownLatch
21.7.2 CyclicBarrier
21.7.3 DelayQueue
21.7.4 PriorityBlockingQueue
21.7.5 使用ScheduledExecutor的温室控制器
21.7.6 Semaphore
21.7.7 Exchange
21.8 仿真
21.8.1 银行出纳仿真
21.8.2 饭店仿真
21.8.3 分发工作
21.9 性能调优
21.9.1 比较各类互斥技术
21.9.2 免锁容器
21.9.3 乐观锁
21.9.4 ReadWriteLock
21.10 活动对象
21.11 总结
21.12 进阶读物
第22章 图形化用户界面
22.1 applet
22.2 Swing基础
22.2.1 一个显示框架
22.3 创建按钮
22.4 捕获事件
22.5 文本区域
22.6 控制布局
22.6.1 BorderLayout
22.6.2 FlowLayout
22.6.3 GridLayout
22.6.4 GridBagLayout
22.6.5 绝对定位
22.6.6 BoxLayout
22.6.7 *好的方式是什么
22.7 Swing事件模型
22.7.1 事件与监听器的类型
22.7.2 跟踪多个事件
22.8 Swing组件一览
22.8.1 按钮
22.8.2 图标
22.8.3 工具提示
22.8.4 文本域
22.8.5 边框
22.8.6 滚动面板
22.8.7 一个迷你编辑器
22.8.8 复选框
22.8.9 单选按钮
22.8.10 组合框(下拉列表)
22.8.11 列表框
22.8.12 页签面板
22.8.13 消息框
22.8.22 菜单
22.8.15 弹出式菜单
22.8.16 绘图
22.8.17 对话框
22.8.18 文件对话框
22.8.19 Swing组件上的HTML
22.8.20 滑块与进度条
22.8.21 选择外观
22.8.22 树、表格和剪贴板
22.9 JNLP与Java Web Start
22.10 Swing与并发
22.10.1 长期运行的任务
22.10.2 可视化线程机制
22.11 可视化编程与JavaBean
22.11.1 JavaBean是什么
22.11.2 使用Introspector抽取出BeanInfo
22.11.3 一个更复杂的Bean
22.11.4 JavaBean与同步
22.11.5 把Bean打包
22.11.6 对更复杂的Bean的支持
22.11.7 更多有关Bean的读物
22.12 Swing的可替换选择
22.13 用Flex构建Flash Web客户端
22.13.1 Hello, Flex
22.13.2 编译MXML
22.13.3 MXML与ActionScript
22.13.4 容器与控制
22.13.5 效果与风格
22.13.6 事件
22.13.7 连接到Java
22.13.8 数据模型与数据绑定
22.13.9 构建和部署
22.14 创建SWT应用
22.14.1 安装SWT
22.14.2 Hello, SWT
22.14.3 根除冗余代码
22.14.4 菜单
22.14.5 页签面板、按钮和事件
22.14.6 图形
22.14.7 SWT中的并发
22.14.8 SWT还是Swing
22.15 总结
22.15.1 资源
附录A 补充材料
可下载的补充材料
Thinking in C:Java的基础
Java编程思想 研讨课
Hands-on Java研讨课CD
Thinking in Objects研讨课
Thinking in Enterprise Java
Thinking in Patterns(with Java)
Thinking in Patterns研讨课
设计咨询与复审
附录B 资源
软件
编辑器与IDE
书籍
分析与设计
Python
我的著作列表
索引
展开全部

作者简介

Bruce Eckel是MindView公司(www.MindView.net)的总裁,他在面向对象技术和设计模式方面提供公开的和专有的培训研讨会、咨询、指导和设计评论。Bruce Eckel是《Thinking in C++》(C++编程思想)的作者,以及《Thinking in C#》、《Thinking in C++,Volume 2》和其他一些书的作者之一。他发表过150多篇文章,有20多年世界各地的研讨会和演讲经验。他是C++标准委员会拥有表决权的成员之一,拥有应用物理学学士和计算机工程学硕士学位。









预估到手价 ×

预估到手价是按参与促销活动、以最优惠的购买方案计算出的价格(不含优惠券部分),仅供参考,未必等同于实际到手价。

确定
快速
导航