http://blog.csdn.net/lmj623565791/article/details/26626391
猪厂面试(Java后台开发)
- i++的并发问题在栈中如何改变
- atomicInteger的具体实现原理(直接说了句硬件实现保证变量的原子操作,其他的关键点没说出来,没复习)
- threadlocal源码实现
- 多线程共享数据的多种方式,除了共享变量
- 为什么hashtable用了synchronized,concurrentHashMap用的是ReentrantLcok
- 线程有序执行的几种方法,守护线程之前的线程死循环的条件下守护线程如何结束
- 读写锁(会吗?不太了解,只知道CopyAndWriteArrayList)
- 两个线程操作一个变量i,一个从1-50自加,一个从51-100自加,最终结果输出给main线程,保证main的结果准确,结果一定是两个线程变量的准确值相加(如何保证线程安全)
- 生产者消费者模型写代码(不能用blockingqueue)
- java反射的过程,C++有反射吗?为什么没有?
- 抽奖,如何保证10小时内发出十个奖品保证公平性(不能将奖品在很短的时间间隔全部发出)
- hashmap的entry太长怎么处理
- gc的几种方法原理,脱离jvm应用,引用计数方式的优缺点,GCRoot的优缺点,在哪种条件下引用计数能比GCRoot发挥更好的效果?
- 写一段代码,给出一个用数组实现的队列,保证队列在满的条件下依旧能够push,在push之前pop队头元素(感觉是考察线程安全的问题,一直在跟面试官确认线程安全和队列可有的数据结构)
- Tcp的连接过程,加解密算法的简单逻辑,常有的MITM能干啥?CA的详细验证过程
i++的并发问题,在栈中如何改变##
通过源码的字节码观察数据移动过程,使用javap -c class文件名
查看对应的class文件内容
JVM指令集:http://blog.csdn.net/lm2302293/article/details/6713147
public class Test {
public static void main(String[] args) {
int i = 0;
i = i++;
System.out.println(i);
}
}
Class字节码文件分析
Compiled from "Test.java"
public class Test {
public Test();
Code:
0: aload_0
1: invokespecial #1 // Method java/lang/Object."<init>":()V
4: return
public static void main(java.lang.String[]);
Code:
0: iconst_0 // 将常量0放入栈中
1: istore_1 // 将栈中的0存入局部变量1中
2: iload_1 // 将局部变量1的值(也就是0)存入栈中
3: iinc 1, 1 //对局部变量1中的值自加(加后为1)
6: istore_1 //重新将栈中的0存入局部变量1的值中,此时局部变量1的值又变回0
7: getstatic #2 // Field java/lang/System.out:Ljava/io/PrintStream;
10: iload_1 // 将局部变量1的值写回栈中,此时为0,因此i依旧为0;
11: invokevirtual #3 // Method java/io/PrintStream.println:(I)V
14: return
}