JAVA工程师面试题
本套试题目前一共包含50分,其中试题以java为主,包含部分数据库,linux等简单题目。
【java】
1.请看以下代码,写出类A的代码,使得main函数执行后输出的结果为abAbB。(6分)
class B extends A{
static {
System.out.print("A");
}
public B() {
System.out.print("B");
}
}
public class mainTest {
public static void main(String[] args){
A a = new A();
B b = new B();
}
}
答案:
class A{
static {
System.out.print("a");
}
public A() {
System.out.print("b");
}
}
2.解释输出这样结果的原因。(4分)
答案:
创建对象时构造器的调用顺序是:先初始化静态成员,然后调用父类构造器,再初始化非静态成员,最后调用自身构造器。
【java】
- 观察以下代码,请在下划线处补全代码,使得main函数执行后输出结果为true,false,false,true(3分)
private static void printProgramming(){
String s1 = "Program" + "ming";
String s2 = ________;
String s3 = ________;
System.out.println(String.format(“%s,%s,%s,%s”, s1 == s2, s1 == s3,s2 == s3, s2.equals(s3));
}
public static void main(String[] args){
printProgramming();
}
答案:
String s2 = s1;
String s3 = new String("Programming");
2. 以下函数是线程不安全函数,请修改函数内部代码,使其成为线程安全函数(2分)
public class mainTest {
private static int count = 0;
private static void inc() {
count++;
}
public static void synchronized main(String[] args) throws InterruptedException {
ExecutorService es = Executors.newFixedThreadPool(10);
for(int i = 0; i < 100000; i++) {
es.submit(mainTest::inc);
}
es.shutdown();
es.awaitTermination(1, TimeUnit.MINUTES);
System.out.println("count:" + count);
}
}
答案:
3. 请分别用synchronized和lock两种不同机制来实现上述题目的要求,并给出两种机制的效率对比以及得出对比结论的原因。(5分)
【java】
- 写一个正则表达式,取出“你住在北京市门头沟区,而我住在上海市徐汇区”中所有的行政区域。(3分)
答案:
2.请用java代码,把“你住在北京市的门头沟区,而我住在上海市徐汇区”这句话中的城市和行政区等实体存入一个map,结构如下:(7分)
北京市=>门头沟区
上海市=>徐汇区
答案:
【mysql】
1. 在mysql数据库中有个chat表,大致表数据如下:(4分)
id | question | answer | module |
1 | 你好 | 你好啊,很高兴认识你 | CHAT |
2 | 你叫什么名字 | 我叫小影 | FAQ |
3 | 你多大了 | 这是秘密哦~我不能告诉你 | FAQ |
4 | 你是男是女 | 当然是女生 | CHAT |
5 | 你的身高是多少 | 很高很高 | FAQ |
请写一条sql语句(按不同模块显示id前两条数据),显示出以下结果。
module | num |
CHAT | 2 |
FAQ | 3 |
答案:
2. 在以上answer表中,已经对question和answer两列建立好全文索引,请用模糊查询的方式写出sql语句:
- question字段包含’你’,但是不包含’是’的记录(2分)
答案:
- answer字段至少包含 ‘你’和’我’ 两个字中间任意一个的记录(2分)
答案:
- answer字段包含’你’或者’我’的记录,但是保证同时包含你我的记录 优先于 包含你的记录 优先于 包含我的记录 显示。(2分)
答案:
【linux命令】
- Linux服务器上有一通过emotibot-controller.jar启动的进程,请用命令将其监听的端口找出来。
答案:
Linux服务器有一个env的文本文件,内容如下
EC_KAFKA_HOST=192.168.1.1:9092
EC_KAFKA_HOSTNAME=bocm
EC_MYSQL_HOST=192.168.1.2:3306
2.请用一条linux命令将mysql的IP地址取出。(2分)
答案:
3.写一个脚本(shell, php, python, perl均可),以文件名为输入参数,将文本中mysql的地址修改为本机的IP地址。(2分)
答案: