Java开发过程中要注意的事项

合理使用缓存

  增加了Redis(Memcached)缓存,以避免频繁调用一些不变的数据。

MyBatis参数问题

  在MyBatis的xml里,select语句where条件有isnull,即这个值有就增加一个where条件,对此,会对任何一个where增加一个不带isnull的查询条件,以免该语句当传入参数都是null时,做全表扫描。

后端异步返回的数据量大

  后端异步返回的数据量很大,时间很长,调大了异步返回的最大时间,或者对返回信息做了压缩处理,以增加网络传输性能。

String拼接问题

  String类作为java语言中最常见的字符串类被广泛使用,如果在做大量字符串拼接效率时变得比较低,因为虚拟机需要不断地将对象引用指向新的地址。因此,一般方法内的私有变量推荐使用stringBuilder来完成如果是多线程需要同步的自然选用stringBuffer。

String equals()方法

  String类中equals的实现方法,当左边为Null时会出现NPE。因此后续代码中需要保证equals方法左边变量不为null。如“abc”.equals(str),而不是str.equals(“abc”);

Integer的Cache缓存

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.最小值。

Mybaits Sql Count(1) 返回类型Integer要判断是否为null

  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

由数组转换的list不能增加元素,删除元素,这是为何?

  数组转换的列表其实不是我们经常使用的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)

遍历ArrayList的时候执行添加删除,会出现什么问题

  当移除某个元素时,上次计算出来的长度超过了当前列表长度,故而会出现越界错误。

两个float类型数据相减会丢失精度,尾部带着常常的一串数字

  两个float类型数据相减会丢失精度,尾部带着常常的一串数字。如果实际场景要做计算我给你两个思路:第一可以用bigdecimal来计算,第二先将单位做成整数再做除法。

你可能感兴趣的:(Java基础,java)