ByteBuffer를 이용한 "빠른" 내용 복사
글쓴이: dohuon / 작성시간: 금, 2009/04/17 - 10:12오전
안녕하세요? 한 3일쩨 고생하고 있네요 ^^;
run length로 압축된 파일을 읽어서 압축을 푼 다음에 ByteBuffer에 너야 합니다.
파일은 filechannel을 이용해 빠르게 잘 읽었습니다. 압축을 푸는 부분에서 시간이 너무 오래 걸립니다.
압축된 파일을 ByteBuffer로 받아서
1바이트 - 시그널 (데이터가 몇번 반복되어 있나)
4바이트 - 데이터
이렇게 무수히 반복되는 데이터를 ByteBuffer에 풀어 넣어 리턴 하면 됩니다.
1. 바이트 어레이를 써서 복사하면 무지 느립니다.
2. 아래 예제와 같이 바이트 버퍼를 여러개 쓰는 방법을 써도 느립니다
ㅠㅠ
int repetition; private ByteBuffer unCompress(FileChannel bbuf){ ByteBuffer output = ByteBuffer.allocateDirect(1048576); ByteBuffer index = ByteBuffer.allocateDirect(1); ByteBuffer rawData = ByteBuffer.allocateDirect(4); try{ bbuf.position(0); while(bbuf.position() > bbuf.size() ){ bbuf.read(index); // 시그널(인덱스) 읽기 bbuf.read(rawData); // 반복될 데이터 repetition = (int)(index.get() & 0xff); // 몇번 반복해야 할까? while(repetition > 0) { output.put(rawData); // 데이터를 내보낼 bytebuffer에 반복하며 기록 repetition--; } } output.position(0); return output; } catch (Exception e){ return output; } }
Forums:
압축을 푸는 시간이란...
제일 안쪽 while문에 있는 output.put을 말하는 건가요? 만약 맞다면,
한번의 index와 rawData를 읽고 이에 대한 출력을 만드는 것을 한 단계라고 했을 때,
이 단계에서 출력을 따로 따로 하지 마시고 어느 정도 메모리에 모은 다음 그 모은 묶음을 출력하셔서 출력횟수를 줄여 보시는 건 어떨까 생각됩니다.
출력 부분이 오버헤드라 생각하고 그 횟수를 줄일 수 있는 제 부족한 소견을 말씀 드린 거예요.^^ 잘 안되더라도 용서를... 근데 워낙 라이브러리 전문가들이 라이브러리를 오버헤드까지 생각해서 잘 만들었을 터인지라... output.put 내부에서 알아서 버퍼를 만들어 출력을 지혜롭게 하고 있는지 모르겠군요--;; 아마 그럴 확률이 큼...
댓글 달기