Java十道入门易踩坑题分析后篇
作者:/少司命
一,写在前面
本篇主要讲类和对象这一章节的踩坑题,这一章也相对复杂和难理解,面试也是常考的一类题,我分析的都是比较经典的,读者觉得自己学习的不够扎实,可以收藏,如果觉得写发不错的话,求个免费的赞,谢谢!
二,代码分析
代码分析①
阅读如下代码。 请问,对语句行 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
到此这篇关于Java十道入门易踩坑题分析的文章就介绍到这了,更多相关Java 踩坑题内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!