目录
一,写在前面
二,代码分析
代码分析①
代码分析②
代码分析③
代码分析④
代码分析⑤
代码分析⑥
代码分析⑦
代码分析⑧
代码分析⑨
代码分析⑩
一,写在前面
本篇主要讲类和对象这一章节的踩坑题,这一章也相对复杂和难理解,面试也是常考的一类题,我分析的都是比较经典的,读者觉得自己学习的不够扎实,可以收藏,如果觉得写发不错的话,求个免费的赞,谢谢!
二,代码分析
代码分析①
阅读如下代码。 请问,对语句行 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
感觉写的不错话求个免费的赞,比心♥