回头JAVA

先从字符串处理、异常处理、容器(Container)、输入/输出(I/O)、线程(Thread)这几个主题入手。掌握常用的API后.回头看源码和算法.

您可能会遇到以下的几个错误,这表示您有一些地方操作有误:
   error: cannot read: HelloJava.java
这表示javac工具程序找不到您指定的.java文件,请检查文件是否存在目前的目录中,或是文件名称是否有误。
   HelloJava.java:1: class HelloJava is public, should be declared in a file named HellJava.java
类名称与主文件名不符,请确定主文件名与类名称是相同的。
   HelloJava.java:3: cannot find symbol
程序代码中某些部分输入错了,最常发生的原因可能是没有注意到字母大小写。
   javac 不是内部或外部命令、可执行的程序或批量文件
Path设置有误或没有在Path中加入JDK的bin目录,请参考2.2节的内容。
2.3.2 执行Java程序
在顺利编译出 .class的文件之后,可以使用java工具程序来执行它。执行时必须指定类名称,就以上的例子来说,也就是指定HelloJava.class这个文件的主文件名。命令执行方式如下:
C:/workspace>java HelloJava
java工具程序会根据您指定的类名称,实际加载.class的文件,以上例来说,就是载入HelloJava.class并执行,执行的结果应该是图2-14所示的画面。
您可能会遇到以下的几个错误,这表示您有一些地方操作有误:
   Exception in thread"main" java.lang.NoClassDefFoundError
java工具程序找不到您所指定的类,请确定指定的类存在目前的目录中,名称是否指定正确(如果是旧版的JDK,可能必须在Classpath中加入.,表示可于目前目录中找到所指定的类)。
   Exception in thread "main" java.lan.NosuchMethodError: main
没有指定Java程序的入口(Entry Point)。java工具程序指定的类必须要有一个程序入口,也就是必须包括main(String[] args)这个方法(Method),请确定您的程序中包括它,必须与2-13所示的HelloJava.java内容一致。

数组的索引值由0开始并不是没有原因的。事实上索引值表示的是:所指定的数组元素相对于数组第一个元素内存位置的位移量(Offset)。索引为0表示位移量为0,所以就是指第一个元素,而索引9就是指相对于第一个元素的位移量为9。不过在Java中您不直接处理关于内存地址的操作,以上的观念主要是让您了解一下数组索引的运作原理。

>>>>>>>>>>>>>>>>>>>>>>>>单元测试<<<<<<<<<<<<<<<<<<<<<<<<<
然而要完全使用一个方法来完成一个单元操作在实现上是有困难的,所以单元也可广义解释为数个方法的集合。这数个方法组合为一个单元操作,目的是完成一个任务。
不过设计时仍优先考虑将一个公开的方法设计为单元,辅助的方法则使用设定为私用,尽量不用数个公开的方法来完成一件工作,以保持接口简洁与单元边界清晰。将工作以一个单元进行设计,这使得单元可以重用,并且也使得单元可以进行测试,进而增加类的可重用性。
单元测试指的是对每一个工作单元进行测试,了解其运行结果是否符合我们的要求。例如当编写完MathTool类之后,也许会这么写一个小小的测试程
### Java 中 `super` 关键字的使用说明 #### 1. 基本概念 `super` 是 Java 中的一个关键字,用于访问和调用父类(超类)的方法以及构造器。它可以帮助开发者实现继承机制中的重要功能[^1]。 --- #### 2. 调用父类的构造方法 当子类创建对象时,默认会先调用其父类的无参构造函数来初始化继承自父类的部分属性。如果未显式指定 `super()` 其他形式的父类构造函数调用,则编译器会在子类构造方法的第一行隐式插入一条默认的 `super()` 调用语句[^2]。 需要注意的是,在同一个构造方法中,`super()` 和 `this()` 不可以同时存在,因为它们都必须位于构造方法的第一条执行语句位置[^3]。 示例代码如下: ```java class Parent { public Parent() { System.out.println("Parent Constructor"); } } class Child extends Parent { public Child() { // 隐式的 super() 将在此处被调用 System.out.println("Child Constructor"); } public static void main(String[] args) { new Child(); } } ``` 运行上述程序将输出: ``` Parent Constructor Child Constructor ``` --- #### 3. 显式调用特定的父类构造方法 除了默认的无参数构造方法外,还可以通过传递适当数量和类型的实参给 `super(…)` 来调用带参数的父类构造方法。这种方式允许更灵活地控制如何初始化从父类继承下来的成员变量。 例如: ```java class Animal { String name; public Animal(String name) { this.name = name; System.out.println("Animal Name: " + name); } } class Dog extends Animal { public Dog(String name, int age) { super(name); // 调用了父类有参构造方法 System.out.println("Dog Age: " + age); } public static void main(String[] args) { new Dog("Buddy", 5); } } ``` 此例子的结果将是: ``` Animal Name: Buddy Dog Age: 5 ``` --- #### 4. 访问父类中的字段 (Field) 假设子类重写了某个来自父类的数据成员名称相同的实例变量,那么可以通过前缀 `super.` 的方式明确指出要操作的是父类版本的那个数据项而不是当前类自己的副本。 举个简单的案例演示这一点: ```java class Vehicle { protected String type = "Generic"; public void showType(){ System.out.println("Vehicle Type : "+type); } } class Car extends Vehicle{ private String type="Car"; public void displayTypes(){ System.out.println("SubClass Field Value:"+this.type); System.out.println("SuperClass Field Value:"+super.type); } } public class TestInheritance{ public static void main(String []args){ Car c=new Car(); c.displayTypes(); } } ``` 这段脚本最终打印出来的内容应该是这样的两行文字: ``` SubClass Field Value:Car SuperClass Field Value:Generic ``` --- #### 5. 调用父类中的方法 (Method Invocation) 同样道理,假如发生了一个同名覆盖现象即子类别重新定义了一种行为模式替代掉原来由基底所提供的那个动作的话;我们依然能够借助于附加限定符 "`super.`" 来触发原始版的功能表现而非最新改写的那一套逻辑流程。 下面给出一段示范性的源码片段予以阐明该知识点的实际运用场景之一: ```java class Shape { void draw() { System.out.println("Drawing a shape..."); } } class Circle extends Shape { @Override void draw() { super.draw(); // 先让Shape完成它的部分工作... System.out.println("...and now drawing a circle."); } } // Main method to test above classes. public class Demo { public static void main(String[] args) { Circle obj = new Circle(); obj.draw(); } } ``` 以上测试结果应当呈现为连续两条消息串接起来的形式展示出来: ``` Drawing a shape... ...and now drawing a circle. ``` --- ### 总结 综上所述,`super` 主要有以下几个用途: - **调用父类的构造方法**:无论是默认还是带有参数的情况都可以适用。 - **区分隐藏的成员变量**:解决因命名冲突而导致无法正常引用到上级层次实体的问题。 - **恢复已被遮蔽住的行为特性**:即使某函数已经被子代所取代仍有机会回头再利用起始设定下的处理规则。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值