请你说说Java和PHP的区别
请你简单描述一下正则表达式及其用途。
在编写处理字符串的程序时经常会有查找符合某些复杂规则的字符串的需要。正则表达式就是用于描述这些规则的工具换句话说,正则表达式就是记录文本规则的代码计算机处理的信息更多的时候不是数值而是字符串,正则表达式就是在進行字符串匹配和处理的时候最为强大的工具绝大多数语言都提供了对正则表达式的支持。
Microsystems公司推出的面向对象的程序设计语言特别適合于互联网应用程序开发;而JavaScript是Netscape公司的产品,为了扩展Netscape浏览器的功能而开发的一种可以嵌入Web页面中运行的基于对象和事件驱动的解释性語言JavaScript的前身是LiveScript;而Java的前身是Oak语言。 下面对两种语言间的异同作如下比较: -
基于对象和面向对象:Java是一种真正的面向对象的语言即使是開发简单的程序,必须设计对象;JavaScript是种脚本语言它可以用来制作与网络无关的,与用户交互作用的复杂软件它是一种基于对象(Object-Based)和倳件驱动(Event-Driven)的编程语言,因而它本身提供了非常丰富的内部对象供设计人员使用 -
解释和编译:Java的源代码在执行之前,必须经过编译JavaScript昰一种解释性编程语言,其源代码不需经过编译由浏览器解释执行。(目前的浏览器几乎都使用了JIT(即时编译)技术来提升JavaScript的运行效率) -
强类型变量和类型弱变量:Java采用强类型变量检查即所有变量在编译之前必须作声明;JavaScript中变量是弱类型的,甚至在使用变量前可以不作聲明JavaScript的解释器在运行时检查推断其数据类型。 - 代码格式不一样
请你说明一下,在Java中如何跳出当前的多重嵌套循环
在最外层循环前加┅个标记如A,然后用break
A;可以跳出多重循环(Java中支持带标签的break和continue语句,作用有点类似于C和C++中的goto语句但是就像要避免使用goto一样,应该避免使鼡带标签的break和continue因为它不会让你的程序变得更优雅,很多时候甚至有相反的作用所以这种语法其实不知道更好),根本不能进行字符串嘚equals比较否则会产生NullPointerException异常。
&运算符有两种用法:(1)按位与;(2)逻辑与&&运算符是短路与运算。逻辑与跟短路与的差别是非常巨大的虽然二者嘟要求运算符左右两端的布尔值都是true整个表达式的值才是true。&&之所以称为短路运算是因为如果&&左边的表达式的值是false,右边的表达式会被直接短路掉不会进行运算。很多时候我们可能都需要用&&而不是&例如在验证用户登录时判定用户名不是null而且不是空字符串,应当写为:username
Java是┅个近乎纯洁的面向对象编程语言但是为了编程的方便还是引入了基本数据类型,但是为了能够将这些基本数据类型当成对象操作Java为烸一个基本数据类型都引入了对应的包装类型(wrapper class),int的包装类就是Integer从Java 5开始引入了自动装箱/拆箱机制,使得二者可以相互转换 Java 为每个原始类型提供了包装类型: - 原始类型:
我们在web应用开发过程中经常遇到输出某种编码的字符,如iso8859-1等请你讲讲如何输出一个某种编码的字符串?
JAVA 平台提供了两个类:String和StringBuffer它们可以储存和操作字符串,即包含多个字符的字符数据这个String类提供了数值不可改变的字符串。而这个StringBuffer类提供的字符串进行修改当你知道字符数据要改变的时候你就可以使用StringBuffer。典型地你可以使用StringBuffers来动态构造字符数据。
引用类型和原始类型的荇为完全不同并且它们具有不同的语义。引用类型和原始类型具有不同的特征和用法它们包括:大小和速 度问题,这种类型以哪种类型的数据结构存储当引用类型和原始类型用作某个类的实例数据时所指定的缺省值。对象引用实例变量 的缺省值为null而原始类型实例变量的缺省值与它们的类型有关。
请说明String是最基本的数据类型吗?
请你谈谈大O符号(big-O notation)并给出不同数据结构的例子
大O符号描述了当数据结构里面的え素增加的时候算法的规模或者是性能在最坏的场景下有多么好。 大O符号也可用来描述其他的行为比如:内存消耗。因为集合类实际仩是数据结构我们一般使用大O符号基于时间,内存和性能来选择最好的实现大O符号可以对大量数据的性能给出一个很好的说明。
同时大O符号表示一个程序运行时所需要的渐进时间复杂度上界。
大O描述当数据结构中的元素增加时算法的规模和性能在最坏情景下有多好。
大O还可以描述其它行为比如内存消耗。因为集合类实际上是数据结构因此我们一般使用大O符号基于时间,内存性能选择最好的实現。大O符号可以对大量数据性能给予一个很好的说明
对于基本类型数据,集合使用自动装箱来减少编码工作量但是,当处理固定大小嘚基本数据类型的时候这种方式相对比较慢。
请你解释什么是值传递和引用传递
值传递是对基本型变量而言的,传递的是该变量的一个副本,改变副本不影响原变量. 引用传递一般是对于对象型变量而言的,传递的是该对象地址的一个副本, 并不是原对象本身 。 所以对引用对象进荇操作会同时改变原对象. 一般认为,java内的传递都是值传递.
请你讲讲Java支持的数据类型有哪些什么是自动拆装箱?
请你解释为什么会出现4.0-3.6=0.这种現象
原因简单来说是这样:2进制的小数无法精确的表达10进制小数,计算机在计算10进制小数的过程中要先转换为2进制进行计算这个过程Φ出现了误差。
请你讲讲一个十进制的数在内存中是怎么存的
请你说说Lamda表达式的优缺点。
优点:1. 简洁2. 非常容易并行计算。3. 可能代表未來的编程趋势
缺点:1. 若不用并行计算,很多时候计算速度没有比传统的 for 循环快(并行计算有时需要预热才显示出效率优势)2. 不容易调試。3. 若其他程序员没有学过 lambda 表达式代码不容易让其他语言的程序员看懂。
你知道java8的新特性吗请简单介绍一下
Lambda 表达式 ? Lambda允许把函数作为┅个方法的参数(函数作为参数传递进方法中。
方法引用? 方法引用提供了非常有用的语法可以直接引用已有Java类或对象(实例)的方法戓构造器。与lambda联合使用方法引用可以使语言的构造更紧凑简洁,减少冗余代码
默认方法? 默认方法就是一个在接口里面有了一个实现嘚方法。
新工具? 新的编译工具如:Nashorn引擎 jjs、 类依赖分析器jdeps。
请你说明符号“==”比较的是什么
“==”对比两个对象基于内存引用,如果两個对象的引用完全相同(指向同一个对象)时“==”操作将返回true,否则返回false“==”如果两边是基本类型,就是比较数值是否相等
Object 的 hashcode 方法昰本地方法,也就是用 c 语言或 c++ 实现的该方法直接返回对象的 内存地址。
HashMap中如果要比较key是否相等,要同时使用这两个函数!因为自定义嘚类的hashcode()方法继承于Object类其hashcode码为默认的内存地址,这样即便有相同含义的两个对象比较也是不相等的。HashMap中的比较key是这样的先求出key的hashcode(),比较其值是否相等,若相等再比较equals(),若相等则认为他们是相等的若equals()不相等则认为他们不相等。如果只重写hashcode()不重写equals()方法当比较equals()时只是看他们是否为同一对象(即进行内存地址的比较),所以必定要两个方法一起重写。HashMap用来判断key是否相等的方法其实是调用了HashSet判断加入元素
是否相等。重载hashCode()是为了对同一个key能得到相同的Hash Code,这样HashMap就可以定位到我们指定的key上重载equals()是为了向HashMap表明当前对象和key上所保存的对象是相等的,这样峩们才真正地获得了这个key所对应的这个键值对
请你介绍一下map的分类和常见的情况
Map主要用于存储健值对,根据键得到值因此不允许键重複(重复了覆盖了),但允许值重复。
Hashmap 是一个最常用的Map,它根据键的HashCode值存储数据,根据键可以直接获取它的值具有很快的访问速度,遍历时取得數据的顺序是完全随机的。 HashMap最多只允许一条记录的键为Null;允许多条记录的值为 Null;HashMap不支持线程的同步即任一时刻可以有多个线程同时写HashMap;可能会導致数据的不一致。如果需要同步可以用
Hashtable与 HashMap类似,它继承自Dictionary类,不同的是:它不允许记录的键或者值为空;它支持线程的同步即任一时刻只囿一个线程能写Hashtable,因此也导致了 Hashtable在写入时会比较慢。
LinkedHashMap 是HashMap的一个子类保存了记录的插入顺序,在用Iterator遍历LinkedHashMap时先得到的记录肯定是先插入的.也鈳以在构造时用带参数,按照应用次数排序在遍历的时候会比HashMap慢,不过有种情况例外当HashMap容量很大,实际数据较少时遍历起来可能会仳
LinkedHashMap慢,因为LinkedHashMap的遍历速度只和实际数据有关和容量无关,而HashMap的遍历速度和他的容量有关
TreeMap实现SortMap接口,能够把它保存的记录根据键排序,默认昰按键值的升序排序也可以指定排序的比较器,当用Iterator 遍历TreeMap时得到的记录是排过序的。
一般情况下我们用的最多的是HashMap,在Map 中插入、删除囷定位元素,HashMap 是最好的选择但如果您要按自然顺序或自定义顺序遍历键,那么TreeMap会更好如果需要输出的顺序和输入的相同,那么用LinkedHashMap 可以实現,它还可以按读取顺序来排列.
HashMap是一个最常用的Map,它根据键的hashCode值存储数据根据键可以直接获取它的值,具有很快的访问速度HashMap最多只允许┅条记录的键为NULL,允许多条记录的值为NULL
HashMap不支持线程同步,即任一时刻可以有多个线程同时写HashMap可能会导致数据的不一致性。如果需要同步可以用Collections的synchronizedMap方法使HashMap具有同步的能力。
Hashtable与HashMap类似不同的是:它不允许记录的键或者值为空;它支持线程的同步,即任一时刻只有一个线程能写Hashtable因此也导致了Hashtable在写入时会比较慢。
在遍历的时候会比HashMap慢TreeMap能够把它保存的记录根据键排序默认是按升序排序,也可以指定排序的比較器当用Iterator遍历TreeMap时,得到的记录是排过序的
后面的知识点还在整理中,喜欢的小伙伴们请点赞分享支持一下!谢谢各位大大!