1.Map中存放的是对象的引用
后续的取用,都是在同一个对象上进行的操作。
(华软)
2.char Array转换为String
错误用法:
char[] char_s=new char[]{'a' ,'b', 'c'};
String s_new=char_s.toString();
输出一下,可以看到s_new
的内容是[C@1b6d3586
(输出结果为[类型@哈希值])。原因在于数组的toString方法直接用的是Object类的方法,没有被重写。
解决方法:
方法1: 直接在构造String时转换。
char[] data = {'a', 'b', 'c'};
String str = new String(data);
方法2: 调用String类的方法转换。
String.valueOf(char[] ch)
参考:https://blog.csdn.net/diyinqian/article/details/79565172
3.&位运算符和+是平级的
sout(1+1&1) 的运行结果是0
原因在于1先加了1,然后2&1得到了0
注意区分:
sum=sum+n&1;
sum+=n&1;
4.对二维数组按照某一列进行排序
public class t3 {
public static void main(String[] args) {
double[][] d=new double[][]{{1,0.1},{2,10.5},{3,5.5},{4,0.001}};
//错误写法:Arrays.sort(d,(a,b)-> (int) (a[1]-b[1]));
Arrays.sort(d,(a,b)->{
if(a[1]>b[1]) return 1;
if(a[1]<b[1]) return -1;
return 0;
});
for(int i=0;i<d.length;i++){
System.out.println(d[i][1]);
}
}
}
正在做笔试,当时IDEA自动提示了错误的写法(注释位置)。
因为在整数进行排序的时候,通常使用Arrays.sort(d,(a,b)-> (a[1]-b[1]));
就可以了。
先解释一下Comparator:
Compares its two arguments for order. Returns a negative integer, zero, or a positive integer as the first argument is less than, equal to, or greater than the second.
后两个参数是传给compare方法进行比较的。
默认是(a,b)->a-b,也就是前一个数字减后一个数字,即默认升序排序。
比较的结果若是负数或0,不进行位置交换;若是1,则交换位置。
但是因为本次是对 double进行排序,所以a[1]-b[1]的返回值是double并是不int,因此IDEA自动提示转换为int。
但是正是因为转换了int,导致两个浮点数之差小于1的时候,会被转换为0,也就是不交换位置,导致排序出现问题。
5.double 比较 精度问题
double,float,在计算机内的精度不一定准确,两数相等不能直接进行==比较。
异常情况:
System.out.println(0.05+0.01 == 0.06);
System.out.println(1.0-0.42);
System.out.println(4.015*100);
System.out.println(123.3/100);
输出的结果为:
false
0.5800000000000001
401.49999999999994
1.2329999999999999
解决方法及时转换为String后进行比较,或者BigDecimal,或者之间两数做差,差值极小说明两数相等。