首页
沸点
课程
数据标注
HOT
AI Coding
更多
直播
活动
APP
插件
直播
活动
APP
插件
搜索历史
清空
创作者中心
写文章
发沸点
写笔记
写代码
草稿箱
创作灵感
查看更多
登录
注册
确定删除此收藏集吗
删除后此收藏集将被移除
取消
确定删除
确定删除此文章吗
删除后此文章将被从当前收藏集中移除
取消
确定删除
编辑收藏集
名称:
描述:
0
/100
公开
当其他人关注此收藏集后不可再更改为隐私
隐私
仅自己可见此收藏集
取消
确定
java基础
订阅
葛志成
更多收藏集
微信扫码分享
微信
新浪微博
QQ
22篇文章 · 0订阅
Java之HashMap迭代删除使用方法小结
I. Map 迭代删除 1. 非常不优雅版本 2. 正确姿势版 3. 简洁版 4. 其他
浅谈Java中的四种内部类
概述如果你看过一些JDK和框架源码的话,就经常会发现一般在类的定义中,都会再定义一些其他的类,这些类也同样会被编译成字节码文件,这样的类就被叫做内部类,按照一般的分法,大致可以分为以下四类:成员内部类
Java 多线程 - Synchronized 和变量并发访问
在非线程安全得情况下,多个线程对同一个对象中得实例变量进行并发访问时,产生得后果就是脏读,也就是取到得数据其实是被更改过得。 非线程安全问题存在于"实例变量"中,如果是方法内部得私有变量,则不存在"非线程安全"的问题。 使用synchronized修饰方法时应注意使用同一个锁对…
解读 Java 8 HashMap
这篇文章是记录自己分析 Java 8 的 HashMap 源码时遇到的疑问和总结,在分析的过程中笔者把遇到的问题都记录下来,然后逐一击破,如果有错误的地方,希望读者可以指正,笔者感激不尽。 可以看到 load factor 是用于确定 hash table 何时扩容的重要参数之…
线性数据结构总结
数组是一种线性数据结构。创建数组时会在内存中划分出一块连续的内存区域,数据会保存在这块连续区域的每块索引。 首先说明通过下标获取元素的时间复杂度为O(1)。因为数组是一块连续的内存区域,并且每个元素的大小都相等,通过一个线性方程就很快能找到改下标对应的内存地址。例如如果是一个i…
通俗易懂的HashMap(Java8)源码解读!
Java8对Java7的HashMap做了修改,最大的区别就是利用了红黑树。 Java7的结构中,查找数据的时候,我们会根据hash值快速定位到数组的具体下标。但是后面是需要通过链表去遍历数据,所以查询的速度就依赖于链表的长度,时间复杂度也自然是O(n) 为了减少2中出现的问题…
方法和数组就是这么简单!
System 是系统类。 println() 是一个方法。 如果我们想要在一个类中实现很多功能,但是如果我们想要,多次使用,某一个功能,显然我们需要重复书写这个功能的代码多次,显然,这是不明智的。所以方法就来拯救我们了。 定义:方法是定义在类中的一段独立的代码块,用来实现某个功…
对不起,我不是针对你,我是说在座的各位都不会写 Java!
本文不是一个吹嘘的文章,不会讲很多高深的架构,相反,会讲解很多基础的问题和写法问题,如果读者自认为基础问题和写法问题都是不是问题,那请忽略这篇文章,节省出时间去做一些有意义的事情。 不知道有多少”老”程序员还在使用 Eclipse,这些程序员们要不就是因循守旧,要不就是根本就不…
JDK中的原子类
1.unsafe属性可以看到是由Unsafe类调用其静态方法生成。 Unsafe类提供了硬件级别的原子操作。里面有许多的本地方法。JDK中的一些无锁并发操作类都是基于它,里面最主要的就是CAS相关操作。这块我就不详细说明了(有兴趣的小伙伴可以去了解下)。 2.valueOffs…
JDK11 | 第七篇 : ZGC 垃圾收集器
Java 11包含一个全新的垃圾收集器--ZGC,它由Oracle开发,承诺在数TB的堆上具有非常低的暂停时间。 在本文中,我们将介绍开发新GC的动机,技术概述以及由ZGC开启的一些可能性。 那么为什么需要新GC呢?毕竟Java 10已经有四种发布多年的垃圾收集器,并且几乎都是…