필요한 캐시의 크기는 얼마인가?
글쓴이: tomahawk28 / 작성시간: 목, 2008/10/09 - 2:53오후
예전 삼x테x윈 면접 당시에 받았던 문제들 중의 하나였고 이 문제를 포함해서 6문제가 있었는데 다들 이건 안하더군요 '_'
임베디드 장치에서 다음과 같은 연산을 수행하려고 하는데..
int a[255][255] for(int i=0; i<255; i++) for(int j=0; j<255; j++) a[i][j]=i*j
위의 연산에 필요한 캐시 메모리 사이즈 크기는 얼마인가..
원래 문제는 저게 돌아갈 장비의 캐시 사이즈가 4Kbyte라고 했었나.. 수치가 잘 기억나지 않아서요
저게 컴파일 되었을때 바로 참조해야되는 건 a[i][j].. 이거 하나인지 아니면 그 일차원배열을 전부 MOV해서 쓰는것인지..
이게 몇개월동안 해답이 없네요 ^^;
Forums:
캐쉬가 필요없음
i, j는 register 사용하면 되고,
i * j 결과를 memory에 write만 하고
read를 하는게 없으니..
ㅎㅎ 이게 맞나요?
...
레지스터에 불러오려면 캐시 메모리에 들어와야 한다능....;
Can't stop watching this;;
흠.. 글쎄요.. 어떤
흠.. 글쎄요.. 어떤 답을 원한걸까요?
문제의 의도가 파악이 안되서 답하기가 어려운 문제일 듯 하네요.
캐시라는 것의 태생이 빠른 장치와 느린 장치 사이의 버퍼 역할인데,
저런거 한다고 꼭 캐시가 있어야 하는건 아니죠.
없어도 작동은 합니다. 캐시가 있는 경우, 캐시가 없는 것 보다 write 시간이 빠르겠지만요.
문제의 의도가 저 데이터를 모두 캐시에 담기 위해 필요한 캐시 사이즈라고 한다면
그냥 sizeof(int)*255*255 일테고요
댓글 달기