zoukankan      html  css  js  c++  java
  • Java 代码细节与优化(一)

    前言

      这篇博客是用来记录自己在写代码的过程中遇到的一些问题,以及解决方法,做一个总结,并且会一直更新,算是笔记吧。


    版权说明

    著作权归作者所有。
    商业转载请联系作者获得授权,非商业转载请注明出处。
    本文作者:Coding-Naga
    发表日期: 2015年1月13日
    本文链接:http://blog.csdn.net/lemon_tree12138/article/details/42672451
    来源:CSDN
    更多内容:分类 >> 重构与优化


    奇技淫巧

    1.byte类型的强制转换问题

    在byte类型中,为什么0x4a不需要强转类型,而0xc2而必须进行强转,写成(byte) 0xc2?

    其实在byte类型的强转中远不是一个0xc2。我们要知道byte最小值是-128,最大值是127。也就是说byte的数值大于0x7f就会溢出,这时就需要对其进行强转。


    2.字符的格式化问题

    将两个一位或两位数显示成00:00格式.

    String.format("%02d", hour) + ":" + String.format("%02d", minute);


    3.对于转化byte[]数组到String的过程中丢位问题的解决

    上述问题一般出现在加密和解密的过程中。例如,我们对一个明文密码“123456”进行SMS4加密,结果返回byte[]数组。而这里的byte[]数组就会有一些位会丢失。其原因是因为在Java中对于byte[]中连续三个为负数则选择丢弃。

    解决方案:

    可以先进行SMS4加密后,再进行一次Base64加密。这样做的原因在于,Base64加密过后的全是可见字符,这样就不会出现位丢失了。示例代码:

    byte[] encodePasswd;
    try {
    	encodePasswd = SMS4.encode("123456", "1234567887654321".getBytes());
    	String encode = new String(Base64.encode(encodePasswd, Base64.DEFAULT));
    	} catch (Exception e) {
    		e.printStackTrace();
    	}
    }


    4.判断字符首尾

    不要总是依赖str.substring(start, end),对于判断一个字符的开头和结尾,我们有更好的办法。

    判断开头:string.startWith(prefix);

    判断结尾:string.endsWith(suffix);

    String a = "abcfsdfasdfwe";
    System.out.println(a.startsWith("abc"));
    System.out.println(a.endsWith("we"));


    5.修改文件中的指定内容

    这里,我们Demo的功能是把文件中的第8个到16个字节的文件内容全部更换成"BBBBBBBBBBBBBBBB".

    import java.io.IOException;
    import java.io.RandomAccessFile;
    
    public class TestRandomAccessFile {
    
        static final String PATH = "F:/Temp/test.txt";
        static final String STRING_1 = "AAAAAAAAAAAAAAAA";
        static final String STRING_2 = "BBBBBBBBBBBBBBBB";
    
        public static void main(String[] args) throws IOException {
            RandomAccessFile rf = new RandomAccessFile(PATH, "rw");
            for (int i = 0; i < 3; i++) {
                rf.write(STRING_1.getBytes());
            }
            rf.close();
    
            rf = new RandomAccessFile(PATH, "rw");
            //直接移动文件指针到相应的字节
            rf.seek(2 * 8);
            //覆盖
            rf.write(STRING_2.getBytes());
            rf.close();
        }
    }
    操作后的文件内容如下:


    通过WinHex打开文件的结果显示,我们可以知道,这里是操作成功了。


    6.文件重命名

    /**
             * 文件重命名
             * @param path 文件目录
             * @param oldName  原来的文件名
             * @param newName 新文件名
             */
            public static void renameFile(String path, String oldName, String newName) {
    
                //新的文件名和以前文件名不同时,才有必要进行重命名
                if(!oldName.equals(newName)){
                    File oldFile=new File(path + "/" + oldName);
                    File newFile=new File(path + "/" + newName);
    
                    // 重命名文件不存在
                    if(!oldFile.exists()){
                        return;
                    }
    
                    //若在该目录下已经有一个文件和新文件名相同,则不允许重命名
                    if(newFile.exists()) {
                        System.out.println(newName + "已经存在.");
                    } else{
                        oldFile.renameTo(newFile);
                    }
                }else{
                    System.out.println("新文件名和旧文件名相同");
                }
            }


    另一篇总结性博客:Android细节问题总结

  • 相关阅读:
    第十四周学习进度
    团队十日冲刺17
    团队十日冲刺16
    找水王
    搜狗输入法评价
    团队十日冲刺15
    团队十日冲刺14
    团队十日冲刺13
    团队十日冲刺12
    团队十日冲刺11
  • 原文地址:https://www.cnblogs.com/fengju/p/6336124.html
Copyright © 2011-2022 走看看