Java 踩坑题
/少司命 人气:0一,写在前面
本篇主要讲类和对象这一章节的踩坑题,这一章也相对复杂和难理解,面试也是常考的一类题,我分析的都是比较经典的,读者觉得自己学习的不够扎实,可以收藏,如果觉得写发不错的话,求个免费的赞,谢谢!
二,代码分析
代码分析①
阅读如下代码。 请问,对语句行 test.hello(). 描述正确的有()
package NowCoder; class Test { public static void hello() { System.out.println("hello"); } } public class MyApplication { public static void main(String[] args) { // TODO Auto-generated method stub Test test=null; test.hello(); } }
A.能编译通过,并正确运行
B.因为使用了未初始化的变量,所以不能编译通过
C.以错误的方式访问了静态方法
D.能编译通过,但因变量为null,不能正常运行
静态的方法不依赖于对象,直接可以调用类名,虽然test=null,但test不指向任何对象,可以直接调用test。选择A
代码分析②
下面代码的运行结果是()
public static void main(String[] args){ String s; System.out.println("s="+s); }
A.代码编程成功,并输出”s=”
B.代码编译成功,并输出”s=null”
C.由于String s没有初始化,代码不能编译通过。
D.代码编译成功,但捕获到NullPointException异常
使用局部变量必须初始化,否则会报错
如果我们使用成员变量,成员变量将会赋初值,局部变量使用一定要初始化
class rra{ String s; public static void main(String[] args) { rra t = new rra(); System.out.println(t.s); } }
选择D
代码分析③
如下代码的输出结果是什么?
public class Test { public int aMethod(){ static int i = 0; i++; return i; } public static void main(String args[]){ Test test = new Test(); test.aMethod(); int j = test.aMethod(); System.out.println(j); } }
A.0
B.1
C.2
D.编译失败
在方法里面不能定义静态的变量,静态的变量属于类变量,不能编译通过
选择D
代码分析④
当你编译和运行下面的代码时,会出现下面选项中的哪种情况?
public class Pvf{ static boolean Paddy; public static void main(String args[]){ System.out.println(Paddy); } }
A.编译时错误
B.编译通过并输出结果false
C.编译通过并输出结果true
D.编译通过并输出结果null
静态成员变量没有赋初值,打印false
选择B
代码分析⑤
以下代码运行输出的是
public class Person{ private String name = "Person"; int age=0; } public class Child extends Person{ public String grade; public static void main(String[] args){ Person p = new Child(); System.out.println(p.name); } }
A.输出:Person
B.没有输出
C.编译出错
D.运行出错
被 private 修饰的成员变量或者成员方法, 不能被类的调用者使用,编译出错
选择C
代码分析⑥
关于以下程序代码的说明正确的是()
public class HasStatic {// 1 private static int x = 100;// 2 public static void main(String args[]) {// 3 HasStatic hsl = new HasStatic();// 4 hsl.x++;// 5 HasStatic hs2 = new HasStatic();// 6 hs2.x++;// 7 hsl = new HasStatic();// 8 hsl.x++;// 9 HasStatic.x--;// 10 System.out.println(" x=" + x);// 11 } }
A.程序通过编译,输出结果为:x=102
B.程序通过编译,输出结果为:x=103
C.10行不能通过编译.因为x星私有静态变量
D.5行不能通过编译.因为引用了私有静态变量
一般静态变量是用类名访问,不能通过对象的引用访问,但这里是可以这样写的,编译器不报错,但不建议这样写。成员变量被static修饰它在方法区只有一个,虽然hsl被引用两次,但x还是原来的X,所以结果为102,不管x指向何处,它在方法区只有一份,选择A
代码分析⑦
以下代码在编译和运行过程中会出现什么情况
public class TestDemo{ private int count; public static void main(String[] args) { TestDemo test=new TestDemo(88); System.out.println(test.count); } TestDemo(int a) { count=a; } }
A.编译运行通过,输出结果是88
B.编译时错误,count变量定义的是私有变量
C.编译时错误,System.out.println方法被调用时test没有被初始化
D.编译和执行时没有输出结果
count 初始值为0.new带有参数的构造方法,a=88,count=88,选择A
代码分析⑧
cnt的值是( )
public class Test{ static int cnt = 6; static{ cnt += 9; } public static void main(String[] args){ System.out.println(“cnt =” + cnt); } static{ cnt /=3; }; }
A.cnt=5
B. cnt=2
C.cnt=3
D.cnt=6
静态代码块不管生成多少个对象,其只会执行一次,且是最先执行的。
静态代码块执行完毕后, 实例代码块(构造块)执行,再然后是构造函数执行
所以cnt从上到下依次执行,选择A
代码分析⑨
程序输出结果为:
class Test{ public String toString() { System.out.print("aaa"); return "bbb"; } } public static void main(String[] args) { System.out.println(new Test()); }
A.aaa
B.bbb
C.aaabbb
D.bbbaaa
解决这道题先引用一段代码
class Test{ public String toString() { System.out.print("aaa"); return "bbb"; } } class ss{ public static void main(String[] args) { Test test = new Test(); System.out.println(test); System.out.println(new Test()); int a = 10; System.out.println(a); System.out.println(10); } }
观察一和二,他们其实各自对应等价,所以选择C
代码分析⑩
如下哪些使用是正确的()
public class Test{ private float f=1.0f; int m=12; static int n=1; public static void main(String args[]){ Test t=new Test(); } }
A.t.a = 1.0
B.this.n
C.Test.m
D.Test.n
由题意知,f和m放在堆区,n在方法区(静态成员变量放在方法区),f虽然可以引用,但f为浮点型,f=10.0; this不能访问静态变量;m为成员变量,要用引用访问,不能用类名访问;类名可以访问静态变量,所以选择D
加载全部内容