增加了Redis(Memcached)缓存,以避免频繁调用一些不变的数据。
在MyBatis的xml里,select语句where条件有isnull,即这个值有就增加一个where条件,对此,会对任何一个where增加一个不带isnull的查询条件,以免该语句当传入参数都是null时,做全表扫描。
后端异步返回的数据量很大,时间很长,调大了异步返回的最大时间,或者对返回信息做了压缩处理,以增加网络传输性能。
String类作为java语言中最常见的字符串类被广泛使用,如果在做大量字符串拼接效率时变得比较低,因为虚拟机需要不断地将对象引用指向新的地址。因此,一般方法内的私有变量推荐使用stringBuilder来完成如果是多线程需要同步的自然选用stringBuffer。
String类中equals的实现方法,当左边为Null时会出现NPE。因此后续代码中需要保证equals方法左边变量不为null。如“abc”.equals(str),而不是str.equals(“abc”);
Integer a = 128;
Integer b = 128;
System.out.println(a==b);
打印的结果为false
而:
Integer a = 127;
Integer b = 127;
System.out.println(a==b);
打印结果为true
为啥?通过源码可知Integer的valueof()方法缓存了-127-128的数值,为什么要缓存该部分值呢?因为这部分值使用频率相比较高,可以提升效率。Integer类型当正整数小于128时是在内存栈中创建值的,并将对象指向这个值,这样当比较两个栈引用时因为是同一地址引用两者则相等。当大于127时将会调用new Integer(),两个整数对象地址引用不相等了。这就是为什么当值为128时不相等,当值为100时相等了。
PS:Integer.MAX_VALUE+1后得到的是Integer.最小值。
select count(1) from table ,resultType为Integer时,Java代码要注意判断Interger是否为null后再取值判断。否则数据库抽风时会返回null,导致后台报空指针异常
将一个私有变量作为形参传递赋值并不会改变参数原有的值,但是如果将一个对象作为参数传递改变属性,对象的属性值就会随着改变。因此total的值仍然为0。
public static void main(String[] args){
int a=100;
Integer b=100;
Integer c=128;
Num num=new Num();
change(a);
change(b);
change(c);
change(num);
System.out.println(a);
System.out.println(b);
System.out.println(c);
System.out.println(num.a);
}
private static void change(Integer a){
a++;
}
private static void change(int a){
a++;
}
private static void change(Num a){
a.a++;
}
static class Num{
int a=100;
}
100
100
128
101
数组转换的列表其实不是我们经常使用的arrayList,但只是数组中内部定义的一种数据结构类型,本质还是原数组而并非列表,因此当向列表添加元素就会出现错误。
public static void main(String[] args){
String[] array=new String[]{"aa","bb","cc"};
List<String> list=Arrays.asList(array);
System.out.println(list.size());
System.out.println(list.get(1));
System.out.println(list.remove(1));
}
输出
3
bb
Exception in thread "main" java.lang.UnsupportedOperationException
at java.util.AbstractList.remove(AbstractList.java:161)
at com.xyzq.job.common.Test.main(Test.java:24)
当移除某个元素时,上次计算出来的长度超过了当前列表长度,故而会出现越界错误。
两个float类型数据相减会丢失精度,尾部带着常常的一串数字。如果实际场景要做计算我给你两个思路:第一可以用bigdecimal来计算,第二先将单位做成整数再做除法。