最近到广州某建站互联网公司面试,当时面试官问假设有两个字符串String a="abc",String b = "abc";问输出a==b是true还是false.我当时毫不犹豫答了true,然后根据字符串常量池的知识点结合jvm的内存模型讲解,然而他却跟我说是false,说这是最基本的问题.我当时一脸懵逼,跟他讨论了很长时间,后来发现他是错的,他说a,b两个变量是存在栈中,这两个引用是不一样的,只不过它们指向的内容是一样的.因为他毕竟工作了好几年,我当时也质疑我的
1.3 Given two strings, write a method to decide if one is a permutation of the other. 这道题给定我们两个字符串,让我们判断一个是否为另一个的全排列字符串.在LeetCode中,关于排列的题有如下几道,Permutation Sequence 序列排序,Permutations 全排列, Permutations II 全排列之二 和 Next Permutation 下一个排列.这道题跟它们比起来,算是很简单的
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>去重</title> </head> <body> <script type="text/javascript"> /*数组去重*/ function quchong(arr){ var len = a
String字符串相加的问题 前几天同事跟我说我之前写的代码中在操作字符串时候,使用字符串相加的方式而不是使用StringBuffer或者StringBuilder导致内存开销很大.这个问题一直在困扰我,因为在<Think in java>一书中,作者说使用"+"拼接字符串并不比StringBuffer或者StringBuilder效率低下,因为"+"是java唯一一个系统级的针对字符串的重载过的操作符. 大家都知道String是一个final修饰的类.