所有对应的值都是空的,因此当垃圾收集器收集它们时,它会自动收集它们
张三心情不好。因为最近天气很热,他决定出去面试,和面试官聊天。因此,在他提交简历后,有人请他面试。
暗自高兴的张三来到东方的办公室接受了现场采访。我失去了面试官不,这是一个满是划痕的Mac。这就是传说中的建筑师吗
张三的态度突然崩溃了。他在第一次面试时遇到了一位高级面试官。谁能忍受呢。
我说我很少用它。我还问自己是否感觉不好。哦,哦,我记得。事务隔离级别。
你好,面试官。事实上,我想到的第一件事是在spring中实现事务隔离级别的源代码。这是在我女朋友在大学甩了我之后我在图书馆哭的时候发现的。
奖金计划来了。我真的看到了。安装B的机会终于来了。
对于一些面试官,我会的!!!
还有,我有。别急着问下一个问题。让我补充几点,推迟面试。
嗯,你的回答很好。你能告诉我基本的实施原则吗
作为一名优秀的面试官,让我先谈谈他的用法:
它可以实现线程之间的数据隔离,因此其他线程不能使用get方法获取其他线程的值。然而,有一些方法可以做到这一点,我将在后面描述。
让我们先看看他收藏的源代码:
记者:这是一个好问题。我在偷偷地骂。你不能让我休息一下吗
结构如下:
好的,面试官说。
至于散列冲突,让我们先看看源代码:
然后判断:如果当前位置为空,初始化一个entry对象并将其放置在位置I;
如果位置I不为空,如果条目对象的键是要设置的键,则刷新条目中的值;
如果位置I不为空且键不等于输入,则搜索下一个空位置,直到其为空。
下面是get的源代码。这不容易理解吗
在Java中,堆栈内存属于单个线程,每个线程都有一个堆栈内存。存储在堆栈内存中的变量只能在它自己的线程中看到,也就是说,堆栈内存可以被理解为线程的私有内存,堆内存中的对象对所有线程都是可见的,堆内存的对象可以被所有线程访问。
在线程源代码中,让我们看看创建线程init时它做了什么
我截获了部分代码。如果线程的变量不是空的,如上面的例子所示,并且父线程也存在,我将把父线程给当前线程。
这不是很有趣吗
你是说内存泄漏
我把它弄丢了。为什么这个孩子知道我想问什么 对,对。告诉我。
这个问题确实存在。让我告诉你为什么。你还记得上面的代码吗
首先让我介绍弱引用:
只有弱引用对象的生命周期较短。当垃圾收集器线程扫描其管辖范围内的内存区域时,它将在仅找到弱引用对象时回收其内存,而不管当前内存空间是否足够。
然而,由于垃圾收集器是一个低优先级线程,因此查找仅具有弱引用的对象并不一定容易。
最好在代码末尾使用remove。我们只需要记住使用remove来清除代码末尾的值。
remove的源代码非常简单。所有对应的值都是空的,因此当垃圾收集器收集它们时,它会自动收集它们。
如果键未设置为弱引用,将导致与条目中的值相同的内存泄漏。
我突然变得如此多愁善感不是很难吗 是为了训练我吗 师父很难这样想我。我心里一直在暗骂他。我会回去努力学习。
事实上,对细节设计的处理往往是我们和伟大的上帝之间的区别。我认为很多不合理的观点只有在谷歌和我们自己有了深刻的理解后才是合理的。这实在令人难以接受。
此外,奥冰还将他的采访文章编辑成一本电子书,共1630页!内容如下,以及我在审查期间总结的面试问题和简历模板
现在它是免费的。你可以通过回复我的官方账户,第三位王子敖冰得到它。
我是欧冰。你知道的越多,你不知道的越多。下次见!
人才是奥冰创作的最大动力。如果本博客中有任何错误和建议,请留言!
1e
发表评论