java常见笔试题目

来源:互联网 发布:逆战数据异常要等多久 编辑:程序博客网 时间:2024/04/28 14:58

java常见笔试题目

1.下列那一行代码编译后不会出现警告或错误。

1) char c="a"; 2) byte b=257; 3) boolean b=null; 4) int i=10; 5)float f=1.3;

2.下面这段代码编译时会发生什么情况。

public class MyClass {

public static void main(String arguments[]) {

amethod(arguments);

}

public void amethod(String[] arguments) {

System.out.println(arguments);

System.out.println(arguments[1]);

}

}

1) error Can't make static reference to void amethod.

2) error method main not correct

3) error array must include parameter

4) amethod must be declared with String

3.byte 的取值范围是:

1)-128 到127; 2)-255 到 256 ;3)-65535 到 65536 ;4)根据不同的java虚拟机而定;

4.下面的命令的输出结果是什么。

java myprog good morning

public class myprog{

public static void main(String argv[])

{

System.out.println(argv[2])

}

}

1) myprog

2) good

3) morning

4) Exception raised: "java.lang.ArrayIndexOutOfBoundsException: 2"

5.下面哪些变量不是合法变量。

1) 2variable 2) variable2 3) _whatavariable 4) _3_ 5) $anothervar 6) #myvar

6.当下面这段程序编译并运行时会出现什么结果。

public class MyClass{

static int i;

public static void main(String argv[]){

System.out.println(i);

}

}

1) Error Variable i may not have been initialized 2) null 3) 1 4) 0

7. String s1=new String("Hello")

String s2=new String("there");

String s3=new String();

下面哪条是正确的。

1) s3=s1 + s2; 2) s3=s1-s2; 3) s3=s1 & s2; 4) s3=s1 && s2;

8. 下面这段代码编译和运行时会发生什么情况。

abstract class MineBase {

abstract void amethod();

static int i;

}

public class Mine extends MineBase{

public static void main(String argv[]){

int[] ar=new int[5];

for(i=0;i < ar.length;i++)

System.out.println(ar[i]);

}

}

1) 将0到5打印出来 2) Error: ar is used before it is initialized

3) Error Mine must be declared abstract 4) IndexOutOfBoundes Error

9. Which two can be used to create a new Thread? (Choose Two)

1) Extend java.lang.Thread and override the run method.

2) Extend java.lang.Runnable and override the start method.

3) Implement java.lang.Thread and implement the run method.

4) Implement java.lang.Runnable and implement the run method.

5) Implement java.lang.Thread and implement the start method

10.写出下面代码的运行结果。

public class Pass{

static int j=20;

public static void main(String argv[]){

int i=10;

Pass p = new Pass();

p.amethod(i);

System.out.println(i);    

System.out.println(j);

}

public void amethod(int x){

x=x*2;

j=j*2;

}

}

x=10;y=40

11.class SuperClass{ public float aaa(){return 3.14f;} }

public class Test extends SuperClass {

public float aaa(){ return 5.14f; }

public double aaa(double double1) {return double1;}

public void aaa(){} //error

public float aaa(float float1){return float1;}

}

//重载绝对不能方法名相同,而类型不同。

12. public int bbb(){

static int i=0; // error

i++;

return i;

}

静态变量不能在方法中定义,切记切记

13.public static void main(String arg[]){

short b=57, a=47;

double c=(short)b/a*2.0;

int d =(short)b/a*2;

}

注意其中的区别。

14. public class Test {

public static void main(String[] args) {

String s ;

Test test = new Test();

test.f(s); //error

}

public void f(String s){

s="1223";

System.out.println(s);

}

}

error: The local variable s may not have been initialized
1.成员变量的初始化
实例变量可以在定义处或者在构造方法中被显式初始化。如果在这两处都没有初始化,那么保留自动初始化时的默认值。final型的变量必须被显式初始化。
静态变量可以在定义处或者在静态代码块中被显式初始化。如果在这两处都没有初始化,那么保留自动初始化的默认值。final型的静态变量必须在定义处或者在静态代码块中被显式初始化。
2. 局部变量的初始化
局部变量必须在使用之前做显式初始化。如果编译器能够确认一个局部变量在使用之前可能没有被初始化,编译器将报错。
如果局部变量没有被初始化,并且在方法中一直没有被使用,编译和运行都会通过。

可以改正为:String s = null ;

15.public class Test {

public static void main(String[] args) {

int i = 0;

Test test = new Test();

test.f();

}

public void f(){

i++; //error

System.out.println(i); //error

}

}

error : The local variable i is never read

16. abstract class AAA{ int i=0;}

class SuperClass extends AAA{ i=3; } //error

public class Test extends SuperClass {

public static void main(String[] args) {

Test test = new Test();

test.f();

}

public void f(){

i++;

System.out.println(i);

}

}

error : Syntax error on token "i", VariableDeclaratorId expected after this token

类体内是声明变量和函数的地方,你突然冒出一个 i=3; 自然是不行的.可以在方法中运用。

17. public class Test {

public static void main(String[] args) {

Test test = new Test();

if(test.f(2)){ //error

System.out.println("111");

}else{

System.out.println("222");

}

}

public int f(int i){return i++; }

}

error: Type mismatch: cannot convert from int to boolean
在JAVA中,if()用的是一个布尔表达式,而不是数字值,这一点与C/C++不同。布尔类型和数字类型不能相互转换。
在switch(expr1)语句中,expr1必须与int类型是赋值兼容的;byte,short或类型可被自动升级;不允许使用float或long表达式。
在case(expr2)语句中,expr2必须是与int类型赋值兼容的常量表达式。当变量或表达式的值不能与任何case值相匹配时,将执行 default后的程序代码。如果没有break语句作为某一个case代码段的结束句,则程序继续执行下一个case的代码块,而不检查下一个case 表达式的值。

18 public class Test {

byte[] arry1,arry2[];

byte[][] arry3;

byte arry4[][];

public void f(){

arry1=arry2; //error

arry2=arry3;

arry2=arry4;

}

}

error : Type mismatch: cannot convert from byte[][] to byte[]

19. abstract class AAA{ int i=0; }

public class Test extends AAA {

public static void main(String arg[]){

int[] ar=new int[5];

for(i=0;i < ar.length;i++) //error

System.out.println(ar[i]);

}

}

error: Cannot make a static reference to the non-static field i

改正为abstract class AAA{ static int i=0; }即可

20.public int bbb(){

int i; //error

i++;

return i;

}

error: The local variable i may not have been initialized

当变量被定义于函数之内,java会运用编译期间错误消息来告诉你没有被初始化。

成员变量的初始化:

21.class CtorBase {

CtorBase(int k) { System.out.println("Base Created");}

}

public class Complex extends CtorBase {

Complex(int k) { System.out.println("Complex Created");}   //error

public static void main(String args[]) {

Complex a = new Complex(10);

}

}

error: Implicit super constructor CtorBase() is undefined. Must explicitly invoke another constructor

Rule1:编译器总是确保类至少有一个构造函数;如果类没有构造函数,编译器会为它构造一个无参的构造函数。Rule2:如果类已经有了一个构造函数,不管它是有参函数还是无参函数,编译器都不会再为它构造一个构造函数。

  在这过程中,编译器会去调用其父类的无参构造函数,如果其父类没有默认(无参)的构造函数,则构造过程出错,编译不能通过。



22.class CtorBase {

int i;

CtorBase(int k) { this.i = k; }

}

public class Complex extends CtorBase {

Complex(int k) {

super(k);

}

public static void main(String args[]) {

Complex a = new Complex(10);

System.out.println("a.i="+a.i);

}

}

结果:a.i=10



23.class CtorBase {

int i;

CtorBase(int k) { this.i = k; }

CtorBase() { }

}

public class Complex extends CtorBase {

Complex(int k) { }

public static void main(String args[]) {

Complex a = new Complex(10);

System.out.println("a.i="+a.i);

}

}

结果:a.i=0

24。

public class Test{
static int cnt=0;
static int sum=0;
int number;
public static void main (String args []){
A a = new A();
B b = new B();
Test test1 = new Test(11);
Test test2 = new Test(22);
test2 = new Test(33);
System.out.println("cnt="+cnt);
System.out.println("sum="+sum);
a.show();
b.show();
}
Test(int n){
number=n;
cnt++;
sum+=number;
}
}

class A {
int a=2;
void show(){
System.out.println("a1="+ a);

}
}
class B extends A{
int a=3;
void show(){
System.out.println("a2="+ super.a);
super.show();
System.out.println("a3="+ a);
}
}

结果:

cnt=3
sum=66
a1=2
a2=2
a1=2
a3=3

25.

class ValHold{
public int i = 10;
}

public class Demo{

public void amethod(){
ValHold v = new ValHold();
another(v);
System.out.println(v.i);
}

public void another(ValHold v){
v.i = 20;
ValHold vh = new ValHold();
v =vh;
System.out.println(v.i);
}

public static void main(String[] argv){
Demo o = new Demo();
o.amethod();
}
}

结果:

10
20

当一个引用变量作为参数传递给一个方法时, 在这个方法内可以改变变量的值,即改变引用指向的对象,(本题中将vh赋给v)但是方法的调用结束后,改变量恢复原来的值,即变量仍然指向原来的对象. (即another(v)调用结束之后,v又回复到第一次ValHold v = new ValHold();时指向的地址空间.) 但是如果在方法内改变了引用指向的对象的数据(属性),那么当方法的调用结束后,尽管引用仍然指向原来的对象,这个对象的某个属性已经被改变了(v的i值 在执行v.i=20的时候就已经被改变了,所以调用another结束后,v.i已经变成了20)

26.
public class Test {
public static void main(String [] args){
Base b = new Subclass();
System.out.println(b.x);
System.out.println(b.method());
}
}
class Base{
int x = 2;
int method(){
return x;
}
}
class Subclass extends Base{
int x = 3;
int method(){
return x;
}
}
结果:2 3
声明变量b后,你能访问的对象部分只是Base的部分; Subclass的特殊部分是隐藏的.这是因为编译器应意识到,e 是一个Base,而不是一个Subclass.但重写的方法除外。abstract和final相互排斥,前者专用于继承,后者禁止继承;抽象类中的抽象 方法不能为static静态方法不能被override,只是被隐藏(hidden)了。
27。
public class Test{
public static String setFileType(String fname){
int p=fname.indexOf('.');
if(p>0) fname=fname.substring(0,p);
fname+=".TXT";
return fname;
}
public static void main(String args[]){
String theFile="Program.java";
String s = setFileType(theFile);
System.out.println("Created "+theFile);
System.out.println("Created "+s);
}
}
String在java成安全的String, 对于String的任一个操作都是先重新生成一个String的拷贝, 然后对这个拷贝进行操作。 所以String在参数传递的时候可以看作是值传递。 即如果你需要修改一个String并返回修改后的String, 你得要再去接一下返回值。
 
原创粉丝点击