首页
学习
活动
专区
圈层
工具
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

hashmap面试题简书_java面试问答题

大家好,又见面了,我是你们的朋友全栈君。 JAVA中的HashMap面试题整理 JDK1.7版本,HashMap的数据结构是什么?...数组+单向链表 什么叫做Hash桶 数组中的单向链表 HashMap的数组长度为什么必须是2的幂?...计算元素存在数组中下标的算法:hash值 & 数组长度-1 如果数组长度不是2的幂,减1后二进制的某一位有可能出现0,导致数组某个位置永远存不到数据 HashMap的默认负载因子是多少,作用是什么?...因为数组长度必须是2的幂并且HashMap数组最大长度的变量为int类型,所有1<<30 什么叫做Hash碰撞/冲突? 两个对象的hash值一样,导致在数组中的下标一样 HashMap何时扩容?...元素个数>=阈值,并且存入数据的位置不等于null HashMap扩容机制是什么? 原来的2倍 HashMap存入null键的位置? hash数组下标为0的位置 什么叫做Hash回环?

39020

java中scanner意思_Java中的Scanner

对于Scanner的进一步理解还是在LeetCode的一道算法题上,题目大意是输入一组分式加法构成的字符串,要求输出分式相加的结果。首先是输入”-2/3+2/3-4/5″,接着求其和。...首先第一步需要解析字符串为所需的数据,我使用了split()的方式,有位大哥就使用了`scanner.useDelimiter(pattern)`方法,直接将数据解析到了Scaner对象中。...# Scanner的工作方式 Scanner的分隔符模式将输入分割到令牌(token,就是临时存储区域),默认情况下以**空格**分割。然后可以使用各种next方法将得到的令牌转换成不同类型的值。...`pattern的模式`,并返回一个新的Scanner对象。...**总结:使用Scanner+正则的组合可以简化很多字符串的处理,而无需使用大量的代码分割字符串和数值转换。

2.6K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    java中finalized的用法_java中的引用类型

    一个例子 Object类是所有类的父类,如果你去查看java.lang.Object类的源码,你会发现里面有个finalize方法,这个方法没有默认实现,需要子类根据实际情况重写这个方法,但是如果不恰当使用...类里也有一个引用队列,这个引用队列是JVM和垃圾回收器打交道的唯一途径,当垃圾回收器需要回收该对象时,会把该对象放到引用队列中,这样java.lang.ref.Finalizer类就可以从队列中取出该对象...$100(Finalizer.java:14) at java.lang.ref.Finalizer$FinalizerThread.run(Finalizer.java:160) 这个线程唯一的职责就是不断的从...java.lang.ref.Finalizer.ReferenceQueue队列中取对象,当一个对象进入到队列中,finalizer线程就执行对象的finalize方法并且把对象从队列中删除,因此在下一次...histo:live 8700|head -n 10命令强制触发一次GC,结果和前面的分析一致,Finalizer对象都放到引用队列中,并依次调用了对象的finalize方法,内存中java.lang.ref.Finalizer

    2.2K10

    java中getclass_java中的getClass()函数

    大家好,又见面了,我是你们的朋友全栈君。 Java反射学习 所谓反射,可以理解为在运行时期获取对象类型信息的操作。...1,获得类型类 我们知道在Java中一切都是对象,我们一般所使用的对象都直接或间接继承自Object类。Object类中包含一个方法名叫getClass,利用这个方法就可以获得一个实例的类型类。...类型类指的是代表一个类型的类,因为一切皆是对象,类型也不例外,在Java使用类型类来表示一个类型。所有的类型类都是Class类的实例。...可以看到,对象a是A的一个实例,A某一个类,在if语句中使用a.getClass()返回的结果正是A的类型类,在Java中表示一个特定类型的类型类可以用“类型.class”的方式获得,因为a.getClass...特别注意的是,类型类是一一对应的,父类的类型类和子类的类型类是不同的,因此,假设A是B的子类,那么如下的代码将得到 “unequal”的输出: A a = new A(); if(a.getClass(

    2K20

    【Java】Java流中的API

    概述: Java Stream API 有助于处理元素序列,提供过滤、映射和减少等操作。...流可用于以声明方式执行操作,类似于对数据的类似 SQL 的操作 关键概念: 流:支持顺序和并行聚合操作的元素序列 中间操作:返回另一个流且延迟的操作(例如,filter、map) 码头运营:产生结果或副作用且不懒惰的操作...; import java.util.List; import java.util.stream.Collectors; public class Main { public static void...Collectors.toList()); names.forEach(System.out::println); } } 收集:收集将流的元素收集到集合或其他数据结构中...它允许: 滤波:根据条件选择元素 映射:转换元素 收集:将元素收集到集合或其他数据结构中 减少:将元素组合成一个结果。 平面映射:展平嵌套结构。 排序:Order 元素。

    31710

    java中的stringbuffer是什么_java中&和&&的区别

    大家好,又见面了,我是你们的朋友全栈君。 JAVA提供了两个类:String和StringBuffer,它们可以储存和操作字符串,即包含多个字符的字符数据。...这个String类提供了不可改变的字符串。 而这个StringBuffer类提供的字符串可以进行修改。 String: 为不可变对象,一旦被创建,就不能修改它的值....对于已经存在的String对象的修改都是重新创建一个新的对象,然后把新的值保存进去....;//error 对象被建立以后,在内存中就会分配内存空间,并初始保存一个null.向StringBuffer 中付值的时候可以通过它的append方法. ss.append(“w!”)...而String是不能被修改的,只能重复的去创建对象来实现修改。——如果频繁的对字符串进行追加、替换、修改、插入、删除操作,最好使用StringBuffer。

    1K30

    设计模式 - 创建型模式_原型模式

    以上的代码主要就三部分内容;⾸先创建选择题和问答题到集合中、定义详情字符串包装结果、返回结果内容。 但以上的代码有⼀个没有实现的地⽅就是不能乱序,所有⼈的试卷顺序都是⼀样的。...B:JAVA程序中可以有多个main方法 C:JAVA程序中类名必须与文件名一样 D:JAVA程序的main方法中如果只有一条语句,可以不用{}(大括号)括起来 答案:A 第3题:变量命名规范说法正确的是...B:JAVA程序中可以有多个main方法 C:JAVA程序中类名必须与文件名一样 D:JAVA程序的main方法中如果只有一条语句,可以不用{}(大括号)括起来 答案:A 第3题:变量命名规范说法正确的是...程序的main方法中如果只有一条语句,可以不用{}(大括号)括起来 C:JAVA程序中类名必须与文件名一样 D:JAVA程序的main方法必须写在类里面 答案:D 二、问答题 第1题:小红马和小黑马生的小马几条腿...A:变量不能以数字作为开头; B:不同类型的变量,可以起相同的名字; C:A和a在java中是同一个变量; D:变量由字母、下划线、数字、$符号随意组成; 答案:A 二、问答题 第1题:为什么好马不吃回头草

    39610

    Java中的Sort

    Java中的SortArrayslegacyMergeSort归并排序ini 代码解读复制代码 // 数组排序 public static void sort(T[] a, Comparator...排序的输入的单位不是一个个单独的数字,而是一个个的块-分区。其中每一个分区叫一个run。针对这些 run 序列,每次拿一个 run 出来按规则进行合并。每次合并会将两个 run合并成一个 run。...合并的结果保存到栈中。合并直到消耗掉所有的 run,这时将栈上剩余的 run合并到只剩一个 run 为止。这时这个仅剩的 run 便是排好序的结果。...force; } // Push run onto pending-run stack, and maybe merge // 把已经排好序的数列压入栈中...assert lo == hi; ts.mergeForceCollapse(); assert ts.stackSize == 1; }binarySort二分插入排序java

    10600

    Java 中的并发

    如何创建一个线程 按 Java 语言规范中的说法,创建线程只有一种方式,就是创建一个 Thread 对象。...而从 HotSpot 虚拟机的角度看,创建一个虚拟机线程 有两种方式,一种是创建 Thread 对象,另一种是创建 一个本地线程,加入到虚拟机线程中。 如果从 Java 语法的角度。有两种方法。...流控 同时,可以设置线程数目,这样,线程不会增大到影响系统整体性能的程度。当任务太多时,可以在队列中排队, 如果有空闲线程,他们会从队列中取出任务执行。...Executors JDK 的 java.util.concurrent.Executors 类提供了几个静态的方法,用于创建不同类型的线程池。...原理 JDK 中的线程池通过 HashSet 存储工作者线程,通过 BlockingQueue 来存储待处理任务。

    76660

    Java中的锁

    Java语言提供了volatile,在某些情况下比锁要更加方便。 volatile在多处理器开发中保证了共享变量的“ 可见性”。...先来看下利用synchronized实现同步的基础:Java中的每一个对象都可以作为锁。 具体表现为以下3种形式。 对于普通同步方法,锁是当前实例对象。...2.2.3 锁存放的位置 锁标记存放在Java对象头的Mark Word中。 ? Java对象头长度 ? 32位JVM Mark Word 结构 ? 32位JVM Mark Word 状态变化 ?...2.2.4 锁的优缺点对比 ? image.png 2.3、CAS CAS,在Java并发应用中通常指CompareAndSwap或CompareAndSet,即比较并交换。...3、Java中的锁实现 3.1、队列同步器(AQS) 队列同步器AbstractQueuedSynchronizer(以下简称同步器),是用来构建锁或者其他同步组件的基础框架。

    97950

    Java中的this指针

    大家好,又见面了,我是你们的朋友全栈君。 在Java中,提到this谁都不会陌生,这里再简单整理下,备忘。...Java中,一般来说this指针指的是当前正在访问的这段代码的对象,但是如果在内部类中需要使用外部类中的对象,这时就需要使用外部类的类名进行限定。这种方式在Android开发中也比较常见。...} public static void main(String[] args) { A a = new A(); } } Inner是内部类,访问类A中的...输出结果为: inner run outer run ——– outer run 另外,在构造方法中,经常使用this(参数表)来调用参数多的构造方法(和Swift中的convenience initializer...类似,在Swift中,convenience initializer必须调用或者说代理给designated initializer),并且Java要求在构造方法中,this(参数表)要出现在任何其他语句之前

    41410

    java中的锁

    看来确实是要学习的最好方式是要带着问题去学,并且解决问题。 在java中锁主要两类:内部锁synchronized和显示锁java.util.concurrent.locks.Lock。...确实是不一样的,此时获取的锁已经不是this了,而this对象指向的class,也就是类锁。因为Java中的类信息会加载到方法常量区,全局是唯一的。这其实就提供了一种全局的锁。...java中对内置锁也提供了一些实现,主要的特点就是java都是对象,而每个对象都有锁,所以可以根据情况选择用什么样的锁。...java.util.concurrent.locks.Lock 前面看了synchronized,大部分的情况下差不多就够啦,但是现在系统在并发编程中复杂性是越来越高,所以总是有许多场景synchronized...或者像java并发编程>中说的那样,concurrent中的lock是对内部锁的一种补充,提供了更多的一些高级特性。

    1.5K90

    JAVA中的注解

    1.2、注解和注释的区别 注解的字面意思是注释、解释的意思,和Java中的注释一样,都有解释、说明的意思。 只不过,注释是程序猿自己写的,解释说明的对象是自己或者是其他程序猿。...比方:注释就是文言文上我们自己添加的对文言文的说明性信息;注解就是文言文下方官方添加的解释性信息。 总结:注释和注解都有解释说明的作用,只不过二者说明的对象的侧重点不同。...1.3、注解的历史 注解是JDK1.5之后才有的一门技术,本来JDK开发出注解这门技术的时候是想给自己用的,并没想到会给别人用,但是因为java是一门很开放的语言,或者说sun公司是一家很open的公司...​ @override:检查子类是否是重写父类中的方法 ​ @Deprecated:标记过时 ​ @SuppressWarnings(“all”):压制错误警告 2.1、@override代码演示...Target @Target(ElementType.FIELD)//value=ElementType.FIELD public @interface MetaAnno { } @Target注解中的参数至少有三个

    62410

    JAVA中的数组

    当然我们也可以采用像在c语言中定义数组的方式,不过在java中并不常用,在此不再介绍。...我们可以设置一个数组 int[] arr = new int[100]; int[] arr1 = arr; 此时arr中的元素全都是0,实际上arr1与arr指向的是痛一个数组,如果修改arr[0]...那么应该如何做到真正的复制一个数组呢? 这时候就需要用到Arrays类中的copyOf方法,利用这个方法,就可以将数组进行复制。...数组是会给存储到数组中 的元素分配一个索引值的,索引值从0开始,最大的索引值是length-1; 数组一旦初始化,长度固定。 数组中的元素与元素之间的内存地址是连续的。...0x06结语 感谢您的阅读,欢迎指正博客中存在的问题,也可以跟我联系,一起进步,一起交流!

    2.2K20

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券