子类及父类常见题目

1、结出如下程序的打印结果
父类:
Java代码

public class Father {
    public Father()
    {
       System.out.println("Father!");
    }
    publicvoid testA()
    {
       System.out.println("Father A");
    }
    publicvoid testB()
    {
       System.out.println("Father B");
    }  
}

子类:
Java代码

public class Children extends Father{
    public Children()
    {
       System.out.println("Childern");
    }
    public void testA()
    {
       System.out.println("Childern A");
    }
    public void testB()
    {
       System.out.println("Childern B");
    }  
    public static void main(String[] arg)
    {
       Father father=new Children();
       father.testA();
       father.testB();
    }
}问打印结果:
解:主要考的是向上转型,这是调用的还是子类的方法,结果如下:
Father!
Childern
Childern A
Childern B
但如果我把测试类改成这样:
Children father=new Children();
打印结果同上。
2、字符串的比较,打印下面的结果:
Java代码 


public class StringCompare {   
    public static void main(String[] arg)
    {
       String a="www";
       String b=a;
       String c=new String("www");

       String d=new String(a);//这个去比较试试
       System.out.print((a==b)+" ");
       System.out.print((a==c)+" ");
       System.out.print((b==c)+" ");
       System.out.print((a.equals(c)));
    }
}解:a,b是同一个对象,所以相等;只有对象相同是,等于的结果才为真。Equals比较的是值,值相等的等于结果为真。
打印如下:
true false false true
3、运行该程序会出现什么样的结果,
Java代码

public class SychorinizedTest {
    public SychorinizedTest()
    {
       System.out.println("SychorinizedTest");
    }
    /**
     * @param args
     */
    public static void main(String[] args) {
       // TODO Auto-generated method stub
       SychorinizedTest test=new SychorinizedTest();
       test.sTest();
    }
    void sTest()
    {
       SychorinizedTest a=this;
       SychorinizedTest b=this;
       synchronized(a)
       {
           try {
              b.wait();
              System.out.println("B is waked up");
           } catch (InterruptedException e) {
              // TODO Auto-generated catch block
              e.printStackTrace();
           }
       }
    }
}
1)、编译错误
2)、运行错误
3)、运行异常
4)、打印结果:SychorinizedTest
5)、打印结果:SychorinizedTest,
              B is waked up
答案:
SychorinizedTest
4、下面运行的结果是怎么样的:
父类:
Java代码:
public class Father {
    public Father()
    {
       System.out.println("Father!");
    }
    publicvoid testA()
    {
       System.out.println("Father A");
    }
    publicvoid testB()
    {
       System.out.println("Father B");
    }  
}

子类:
Java代码

public class Children extends Father{
    public Children()
    {
       System.out.println("Childern");
    }
    public void testA()
    {
       System.out.println("Childern A");
    }
    public void testA(String a)
    {
       System.out.println(a);
    }
    public String testA()
    {
       System.out.println("Childern A");
    }
    public String testA(String a)
    {
       System.out.println("Childern A");
    }
    public void testB()
    {
       System.out.println("Childern B");
    }
   
    public static void main(String[] arg)
    {     
       Children c=new Children();
    }
}
1)、编译错误
2)、运行错误
3)、正常运行
5、写出下面程序运行的结果:
Java代码

publicclass StringBufferTest {
   
    publicstaticvoid main(String[] arg)
    {     
       StringBufferTest t=new StringBufferTest();
       t.test();
    }
    void test()
    {
       int x=4;
       StringBuffer sb=new StringBuffer("..sdfgfe");
       sb.delete(3,6);
       System.out.println(sb);
       sb.insert(1, "aa");
       if(sb.length()>6)
       {
           x=sb.length();
       }
       sb.delete(x-3, x-2);
       System.out.println(sb);
    }
}答案:.aa.fe
6、String,StringBuilder,StringBuffer的区别及性能比较、共同特性
〔网上找〕
7、给出下面程序的执行顺序:
Java代码
publicclass Father {  
    //1  
    String a="aaaaaa";  
    public Father()  
    {  
       //2  
       System.out.println("Father");  
    }     
}  
class Child extends Father  
{  
    //3  
    String b="bbbbbbb";  
    public Child()  
    {  
       //4  
       System.out.println("Children");  
    }  
    //5  
    static{  
       String tt="ttttttt";  
    }  


publicclass Father {
    //1
    String a="aaaaaa";
    public Father()
    {
       //2
       System.out.println("Father");
    }  
}
class Child extends Father
{
    //3
    String b="bbbbbbb";
    public Child()
    {
       //4
       System.out.println("Children");
    }
    //5
    static{
       String tt="ttttttt";
    }
}答案:
我用DEBUG得到的如下显示:
Source breakpoint occurred at line 23 of Father.java.
Source breakpoint occurred at line 5 of Father.java.
Source breakpoint occurred at line 9 of Father.java.
Father
Source breakpoint occurred at line 15 of Father.java.
Source breakpoint occurred at line 19 of Father.java.
Children
也即顺序是:
先执行静态初使化,然后去子类的构造函数,发现有继承,然后转向父类,发现父类有变量初使化,于是执行父类变量的初使化,然后执行父类的构造函数,再回到子类的构造函数,发现有全局变量要初使化,初使化子类的全局变量,再执行子类的构造函数
顺序为:5 1 2 3 4
8、现在一个表,有姓名、性别、年龄,字段分别为varchar(20),varchar(20),int,现有表中已经有上百万条记录了,在姓名上建索引,现在有一个文本文件,已经格式化为姓名、性别、年龄,写一个函数,怎么样一次性的将该文件中的数据以最快的速度导入到数据库中。
如有函数
save(Connection c,File f)
{
    //操作
}
实现该函数
解:
8题的解决思路参见下面MYSQL的解决方案:
http://blog.youkuaiyun.com/fenglibing/archive/2007/10/11/1820153.aspx

 

第2次网课测试题--继承和多态单元测试 题量: 20 满分: 100 作答时间:04-17 18:48至04-20 23:48 一. 单选题(共20题,100分) 1. (单选题) 在下面哪种情况下,可以使用方法重写? A 父类中的方法在子类中没有时 B 父类方法中的返回值类型不适合子类使用 C 父类的功能无法满足子类的需求时 D 父类方法中的形参不适用于子类使用时 2. (单选题) B是父类,C是子类父类引用指向子类对象B b = new C()时,下列说法那个是错误的 A 若子类定义了父类同名的属性,父类引用调用子类的属性 B 若子类未覆盖某属性,则父类引用调用父类本身的旧属性 C 若子类定义了父类同名的某方法,则父类引用调用子类重新定义的新方法 D 若子类未覆盖某方法,则父类引用调用父类本身的旧方法 3. (单选题) 如果父类的方法是静态的,则子类的方法被()修饰才能覆盖父类的静态方法? A static B private C final D protected 4. (单选题) 运行下面程序的结果是什么? abstract class MineBase { abstract void amethod(); static int i; } public class Mine extends MineBase { public static void main(String[] a) { int[] ar = new int[5]; for (int i=0; i<ar.length; i++) { System.out.println(ar[i]); } } } A 编译错误,Mine应声明为抽象类 B 出现IndexOutOfBoundsException异常 C 打印5个0 D 编译错误,数组ar[]必须初始化 5. (单选题) 下面对于final修饰方法的描述中,正确的是? A final修饰的抽象方法可以被子类重写 B final修饰的静态方法不能被类名调用 C final修饰的方法不能被子类重写 D final只能修饰非静态的方法 6. (单选题) 编译运行如下Java代码,输出结果是( )。 class Base { public void m
04-21
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值