凹数科技笔试

一、Java

1、成员变量作用域public/protected/defaultprivate/区别?

public:该成员变量或其方法对当前类、同一包、子类、其他包都可见,所有类和对象都可以直接访问。

protected:该成员变量或其方法对当前类、同一包、子类都可见。

default:该成员变量或其方法对当前类、同一包可见,子类与该成员变量所在的父类位于同一包,子类可以访问,否则不能。

private:该成员变量或其方法只对当前类可见。

2、Override(覆盖)和Overload(重载)区别?

重载和覆盖是Java多态性的不同表现方式。

覆盖是子类函数覆盖基类函数,覆盖一个方法并对其重写以达到不同的作用。

Note:

  • 子类中的覆盖方法必须父类中被覆盖的方法有相同的函数名和参数。
  • 子类中覆盖方法的返回值必须和父类中被覆盖方法的返回值相同。
  • 子类中覆盖方法所抛出的异常类必须和父类中被覆盖方法相同。
  • 父类中被覆盖方法不能为private,负责子类只是定义了一个新方法而不是覆盖。

重载是通过不同的参数列表来区分,如不同的参数个数,参数类型,参数顺序。

Note:

  • 不能通过方法的访问权限、返回值类型,抛出异常类型来区分重载。
  • 对于继承来说,如果父类方法的访问权限为private,就不能在子类中对其重载,只是新定义的一个方法。

覆盖与重载的区别:

1)Override是子类与父类之间的关系,是垂直关系;Overload 是同一个类中方法之间的关系,是水平关系。

2)覆盖关系中,是根据对象的类型决定调用哪个方法(父类或子类的);重载是根据参数列表的不同决定调用哪个方法。

3)覆盖要求参数列表相同,重载不同。

4)覆盖只能由一个方法或由一对方法产生关系;重载是多个方法之间的关系。

3、ArrayList与Vector区别?

均在java.util包中,均为可伸缩数组,可以动态改变长度。两者都是基于存储元素的Object[] array实现的,在内存中开辟连续的空间来存储,支持用下标访问。ArrayList和Vector都有一个初始化的容量大小,当超过时,Vector默认扩充为原来的2倍,ArrayList默认扩充为原来的1.5倍。

最大区别:同步( synchronization)的使用,ArrayList的方法都不是同步的,Vector的大部分方法是同步的(add/insert/remove等)。Vector是线程安全的,提供了线程安全机制,因此其性能上要略逊于ArrayList;ArrayList不是线程安全的

4、HahMap与HashTable区别?(待补充)

5、类加载器class loader加载类的步骤?Java提供的类加载器有?

见(Tanks):http://blog.csdn.net/gjanyanlig/article/details/6818655

6、阅读程序填空,输出,有关Java程序初始化顺序(static、构造函数)

二、数据结构

7、给出前序遍历判断不可能的中序顺序。

8、邻接表,给出邻接表写出深度优先广度优先,伪代码

见(Tanks):https://segmentfault.com/a/1190000002685939

三、操作系统

9、临界区、互斥量、信号量、事件概念,Java中怎么实现?

见(Thanks):http://blog.csdn.net/vividonly/article/details/6415748  Java中怎么实现?(待解决)

10、进程调度算法有?区别?适用场合?

11、进程的状态有?三个基本状态:运行、就绪、阻塞 。见:http://blog.sina.com.cn/s/blog_7c03bb1f0100wcco.html

12、进程的数据结构?

13、实现复数Complex类,支持加减

public class ComplexDemo { 
 // main方法 
 public static void main(String[] a) { 
  Complex b = new Complex(2, 5); 
  Complex c = new Complex(3, -4); 
  System.out.println(b + "+" + c + "=" + b.add(c)); 
  System.out.println(b + "-" + c + "=" + b.minus(c)); 
  System.out.println(b + "*" + c + "=" + b.multiply(c)); 
  System.out.println(b + "/" + c + "=" + b.divide(c)); 
 } 
} 
 
// Complex类 
class Complex { 
 private double m;// 实部 
 private double n;// 虚部 
 
 public Complex(double m, double n) { 
  this.m = m; 
  this.n = n; 
 } 
 
 // add 
 public Complex add(Complex c) { 
  return new Complex(m + c.m, n + c.n); 
 } 
 
 // minus 
 public Complex minus(Complex c) { 
  return new Complex(m - c.m, n - c.n); 
 } 
 
 // multiply 
 public Complex multiply(Complex c) { 
  return new Complex(m * c.m - n * c.n, m * c.n + n * c.m); 
 } 
 
 // divide 
 public Complex divide(Complex c) { 
  double d = Math.sqrt(c.m * c.m) + Math.sqrt(c.n * c.n); 
  return new Complex((m * c.m + n * c.n) / d, Math.round((m * c.n - n * c.m) / d)); 
 } 
 
 public String toString() { 
  String rtr_str = ""; 
  if (n > 0) 
   rtr_str = "(" + m + "+" + n + "i" + ")"; 
  if (n == 0) 
   rtr_str = "(" + m + ")"; 
  if (n < 0) 
   rtr_str = "(" + m + n + "i" + ")"; 
  return rtr_str; 
 } 
}
运行结果:
凹数科技笔试_第1张图片

13、编程:线程A不断向队列Queue写数据,线程B不断向队列Queue读数据。

已上传至GitHub:https://github.com/HiSunny/InterviewXianChengQue

你可能感兴趣的:(凹数科技笔试)