Java写入的常用技巧
生活随笔
收集整理的這篇文章主要介紹了
Java写入的常用技巧
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
一.批量寫入
Java寫入大量數據到磁盤/數據庫等其它第三方介質時,由于IO是比較耗費資源的操作,通常采用攢一批然后批量寫入的模式
//通常構造一個緩存池,一個限制指標,可以是內存大小也可以是時間 ByteArrayOutputStream byteBuffer = new ByteArrayOutputStream();int size = 0;for (byte[] aByte : bytes) {//緩存池超過最大Size,進行一次刷新操作if (size > SIZE_LIMIT) {doWrite(args);size = 0;byteBuffer.reset();}size += aByte.length;try {byteBuffer.write(aByte);} catch (IOException e) {e.printStackTrace();}}//如果循環結束,但byte數組不為空,則進行最后一次刷新操作if (byteBuffer.size() != 0) {doWrite(args);byteBuffer.reset();}二.寫入的重試
寫入第三方介質時由于網絡傳輸問題,可能出現數據丟失等問題,需要重傳
基本的邏輯是只要捕捉到異常將isException置為True就進行重傳,直到傳輸成功,將isException置為False
//是否需要重傳的標記,我這里時捕捉到了異常,也可能來自其它的response boolean isException=false;try {writeData(args);} catch (Exception e) {log.error(e);isException=true;}while (isException) {try {writeData(args);isException=false;log.info("retry->success");} catch (Exception e) {log.error("retry->failed",e);isException=true;}}?
轉載于:https://www.cnblogs.com/wangbin2188/p/11555730.html
總結
以上是生活随笔為你收集整理的Java写入的常用技巧的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 列表怎么有限的初始化为零_《零基础学习A
- 下一篇: 并发执行变成串行_网易Java研发面试官