网站首页 > 技术文章 正文
1. 阅读下列代码回答问题(第一个Java程序,理解PATH和CLASSPATH,学会使用javac和java命令)
[java] view plain copy
package cn.edu.uibe;
publicclass HelloWorld {
publicstaticvoid main(String[] args) {
System.out.println("Hello World!");
}
}
问:
(1)上面代码所在的源文件的文件名是_______________?
(2)在DOS提示符下,当前目录为该源文件所在的目录,PATH环境变量已包含编译程序所在的路径,编译目标路径为“D:/classes”,编译命令行是_____________?
(3)为了让Java解释器能够找到编译后的类文件,需要如何设置环境变量___________?
(4)在正确设置了相关的环境变量之后,运行HelloWorld类的命令行是____________?
答案:
(1)HelloWorld.java,公共类必须定义在和类名同名的文件中,文件名区分大小写。
(2)javac -d D:/classes HelloWorld.java ,-d给出输出目录,javac会在D:/classes创建包的目录层次结构
cn/edu/uibe/HelloWorld.class
(3)set CLASSPATH=.;D:/classses,CLASSSPATH给出Java寻找.class文件的多个路径,路径之间用分号分隔,“.”表示当前路径。
(4)java cn.edu.uibe.HelloWorld,注意需要给出包名,类名后面不要加“.class”。
2. 阅读下列代码回答问题(关于private的理解)
[java] view plain copy
public class Light {
private int brightness = 5;
public void brighten(Light another){
another.brightness++;
}
public static void main(String[] args) {
Light light1 = new Light();
Light light2 = new Light();
light1.brighten(light2);
}
}
问:上面代码Java编译器是否会给出错误提示?为什么?
答案:不会出现错误提示,private限制了私有变量只能被同一个类访问,但是没有限制同一个类的不同对象之间互相访问私有变量。实际上,private是在编译时进行检查,如果想限制同类对象之间互相访问,需要在动态运行时实现,开销较大,而且没有必要。
3. 阅读下列代码回答问题(关于多态性的理解)
[java] view plain copy
class Base {
int i=1;
void f(){
System.out.println("Base.f()");
}
void g(){
f(); //会调用上面的f()方法吗?
}
}
public class Derived extends Base { //继承了Base类
int i=2; //Derived类的对象有1个i还是2个i呢? 答:2个
void f(){ //覆盖override了f()方法
System.out.println("Derived.f()");
}
public static void main(String[] args) {
Derived d = new Derived(); //创建子类对象
Base b = d; //没有创建对象,仅仅是父类引用指向了子类对象
d.f(); //将会输出Derived.f()
b.f(); //也会输出Derived.f(),方法具有多态性
System.out.println(d.i); //输出的是2,d.i访问子类中定义的变量i
System.out.println(b.i); //输出的是1,b.i访问的是父类中定义的变量i,成员变量是不会动态绑定而表现出多态性的。
d.g(); //输出Derived.f()
b.g(); //也输出Derived.f(),从父类中调用被覆盖的方法f(),也将调用到子类中更具体的方法。
}
}
问: 写出上面代码的输出?
答案:参见代码注释,子类和父类中定义同名的变量时,仅仅是隐藏了,变量没有多态性;而对于覆盖的方法,Java表现出多态性,
会调用更具体的子类里面的方法,无论从哪里调用,无论使用什么引用类型调用。
4.阅读下列代码回答问题(关于匿名内部类的理解)
[java] view plain copy
interface A {
void f();
}
public class B {
public void f(A a) {
}
public static void main(String[] args) {
B b= new B();
b.f(new A() {
public void f() {
}
});
}
}
问:请解释语句
b.f(new A() {
public void f() {
}
});
的含义与作用。
答案:
这个语句在参数表中定义了一个匿名内部类,这个匿名内部类实现了接口A,实例化了一个匿名内部类的对象,并将这个对象传递给了接收接口A作为参数的方法f(A a)。需要注意的是接口A中的方法f()和类B中的方法f(A a)没有任何关系,是不同的方法。
5. 阅读下列代码回答问题(关于static的理解)
[java] view plain copy
public class Static {
static int i = 0;
int j=0;
public static void main(String[] args) {
Static s1 = new Static();
Static s2 = new Static();
s1.i++;
s2.i++;
s1.j++;
s2.j++;
System.out.println(s1.i);
System.out.println(s1.j);
System.out.println(s2.i);
System.out.println(s2.j);
}
}
问:写出上面代码的输出。
答案: 2 1 2 1,i是静态变量,类的所有实例共享同一个i,通常我们不通过引用变量访问静态变量,而是通过类名访问Static.i,注意Static是我们自己定义的类名,而小写的static是关键字,表示静态的,为类的所有实例共享的变量或方法。j是实例变量,每个对象具有不同的,属于其自身的一个变量j。
6. 阅读下列代码回答问题(关于引用变量的理解)
[java] view plain copy
class Counter{
int i=0;
}
public class Reference {
public void plus(int i){
i++; //不会改变传递进来的参数的值,Java传递基本类型时进行了值的拷贝
}
public void plus(Counter c){
c.i++; //会改变,因为c是一个引用变量,相当于指针
}
public void create(Counter c){
c = new Counter();
c.i++; //不会改变,因为c执行了另外一个新建的对象
}
public static void main(String[] args) {
int i = 0;
Reference r = new Reference();
Counter c1 = new Counter();
Counter c2 = new Counter();
r.plus(i);
r.plus(c1);
r.create(c2);
System.out.println(i);
System.out.println(c1.i);
System.out.println(c2.i);
}
}
问:上面代码输出是?
答案:参考代码注释,输出应该是:0 1 0
7. 阅读下列代码回答问题(关于异常的理解)
[java] view plain copy
class MyException extends Exception{
public MyException(String message){
super(message);
}
}
public class ExceptionDemo{
public void f(int num) throws MyException {
if(num<0){
throw new MyException("参数不能为负数!");
}
System.out.println(num);
}
public void g(){
try{
f(1);
f(3);
f(0);
f(-1);
f(2);
f(-5);
}catch(MyException e){
System.err.println(e.getMessage());
return;//会立即返回吗?答:不会!
}finally{
System.out.println("无论什么时候!");
}
}
public static void main(String[] args) {
ExceptionDemo demo = new ExceptionDemo();
demo.g();
}
}
问:上面代码输出是?
答案:输出是:1 3 0 参数不能为负数! 无论什么时候!
try语句块里面的一行代码抛出了异常,后续代码就不再执行了,而是转到catch开始匹配异常类型。finally语句块里面的代码始终会被执行,即使在catch语句块里面有行return语句也不会立即返回,Java确保finally语句块执行完函数才会返回。
学习有困难可以加扣:578024144进行交流获取免费听课权限一对一进行指导学习。
猜你喜欢
- 2025-07-03 有望取代 java?GO 语言项目了解一下
- 2025-07-03 ScalersTalk成长会Java小组第7周学习笔记
- 2025-07-03 java基础回顾(七)——类和方法
- 2025-07-03 泣血推荐,Java高阶必备的7大经典书籍
- 2025-07-03 centos7 java dockerfile
- 2025-07-03 对Java意义重大的7个性能指标
- 2025-07-03 Net7/JDK19/Delphi10性能对比(续)
- 2025-07-03 java文本对比工具源码7
- 2025-07-03 崩溃卡死?Java老司机私藏的7条救命命令,5分钟搞定线上事故!
- 2025-07-03 Java 中的 7 种重试机制,还有谁不会?!
- 最近发表
-
- Qt编程进阶(63):Qt Quick高级控件的使用
- Qt编程进阶(47):QML鼠标事件处理(qt编程难不难)
- 使用Xamarin和Visual Studio开发Android可穿戴设备应用
- Qt使用教程:创建Qt Quick应用程序(三)
- QML性能优化 | 常见界面元素优化(qml布局自适应大小)
- Qt使用教程:创建移动应用程序(二)
- Qt Quick 多媒体开发播放音乐和视频
- Qt使用教程:创建Qt Quick UI表单(三)
- 如何将 Qt 3D 渲染与 Qt Quick 2D 元素结合创建太阳系行星元素?
- QML控件:TextInput, TextField, TextEdit, TextArea用法及自定义
- 标签列表
-
- axure 注册码 (25)
- exploit db (21)
- mutex_lock (30)
- oracleclient (27)
- nfs (25)
- springbatch (28)
- oracle数据库备份 (25)
- dir (26)
- connectionstring属性尚未初始化 (23)
- output (32)
- panel滚动条 (28)
- centos 5 4 (23)
- sql学习 (33)
- c 数组 (33)
- pascal语言教程 (23)
- ppt 教程 (35)
- java7 (24)
- 自适应网站制作 (32)
- server服务自动停止 (25)
- 超链接去掉下划线 (34)
- 什么是堆栈 (22)
- map entry (25)
- ubuntu装qq (25)
- outputstreamwriter (26)
- fill_parent (22)