디시인사이드 갤러리

갤러리 이슈박스, 최근방문 갤러리

갤러리 본문 영역

잠 안와서 적는 C계열 이중 for문이 row-major로 작성된 이유

ㅆㅇㅆ(124.216) 2025.02.08 05:27:01
조회 878 추천 8 댓글 9
														





38bf8168f5dc3f8650bbd58b3685716cf9

(row-major)


38bf8268f5dc3f8650bbd58b368577684f

(col-major)



사실 코딩을 하다보면 이중 for문을 하고, 나서 왜 행(row,가로) 먼저 하고, 열(col,세로)을 하는지 의문을 가지지 않고 배우는 경우가 많다.


하지만 실제로 프로그래밍쪽이 아닌 순수 과학이나 데이터 사이언스의 할 경우


Col-major을 쓰는 언어가 있다.


그럼 왜 메이저 언어들은 row-major가 메인이 됐을까?



38bf8368f5dc3f8650bbd58b3685736c64da

그 답은 컴퓨터 시스템의 책의 명저중의 명저 Computer Systems: A Programmer's Perspective에 자세히 나와있다.


우선 들어가기 앞서 우리는 컴퓨터의 캐시에 대해서 알아야한다.


38bf8668f5dc3f8650bbd58b36837d64baf5

캐시란?


캐시는 메모리 데이터를 블록 단위로 저장하는데


각 블록은 일반적으로 32바이트에서 128 바이트 사이의 크기를 가지고


이 블록은 태그,인덱스, 오프셋으로 구성된다 


태그: 메모리 주소 상위 비트로, 캐시 블록이 어떤 메모리 주소를 저장하고 있는지 식별


인덱스:캐시 내에서 블록의 위치를 지정


오프셋:블록 내에서 특정 바이트를 선택


캐시 블록은 메모리 접근 요청이 들어오면 해당 주소의 데이터가 캐시에 있는지 확인하는데, 데이터가 있을 경우 히트했다고 하고, 없을 경우 미스했다고 한다.


일반적으로 캐시 미스(데이터가 캐시에 없으면) 해당 데이터를 포함한 캐시 블록 전체를 메모리에서 캐시로 로드한다.


캐시 블록의 크기가 커질수록 공간 지역성(spatial locality)을 더 잘 활용할 수 있으나, 캐시 용량과 더불어 캐시 미스의 패널티가 커진다.



38bf8768f5dc3f8650bbd58b36867d6f8899

우선 책의 3장에서 보듯 C 배열이 연속적으로 저장되는데


배열의 요소가 연속된 메모리 블록에 저장되있고, 


C에서 배열은 모든 요소가 메모리에 연속적으로 할당되고, 각 요소의 주소가 기본 주소에서 일정 간격(L,즉 데이터의 타입 크기 만큼)떨어져 있다는 사실인데


이게 바로 C 배열이 행(row) 연속적이라는 뜻이다.



자, 그럼 이 2가지 사실을 합치면 다음과 같은 결론이 나온다.


배열이 row-major order로 저장되므로 한 행의 데이터가 메모리상에서 연속되어 있게 되고,

캐시 블록이 연속된 메모리 주소를 가져오기 때문에,

하나의 캐시 블록은 보통 한 행의 연속된 일부분(또는 전체)을 포함하게 된다라는 것.


그래서 캐시 친화적인 코드를 작성하면 다음과 같다.




38bf8568f5dc3f8650bbd58b3680746c9962





이후, 캐시 친화적인 코드를 설명할때 Row-major로 캐시친화적이게 하는데


여기서 Row-major order가 다차원 배열을 메모리에 저장할때 행단위로 연속적으로 저장하는 방식을 이야기하는데


이는 '공간적 지역성(Spatial locality)를 극대화한다. 즉 연속된 메모리 주소를 접근할때 캐시 효율성이 높아진다.


a[i][j]의 캐시 동작은 행단위로 접근되므로, 한번의 캐시 미스로 연속된 여러 요소를 캐시에 로드 할 수 있다.


예시로 들자면


a[0][0]에 접근할때 a[0][0]부터 a[0][[3]까지의 블록이 캐시에 로드 되는데, 이후 a[0][1],a[0][2],a[0][3]은 캐시 히트가 발생한다


따라서 캐시미스율이 낮아진다.


반대로 열단위로 접근해서


a[j][i]의 캐시 동작은 열단위 접근으로 서로 다른 캐시 블록을 필요로 하고, a[0][0]에 접근한 후 a[1][0]은 다른 캐시 블록에 있고, 결과적으로 캐시 미스율이 높아지는데


이러한 접근은 행에서 접근할때 캐시미스율에 비해서 열에서 접근할때 캐시미스율이 매우 높아짐을 알 수 있다.


즉, 행 우선순서로 배열을 스캔하면, 인접한 데이터가 동일한 캐시블록에 로드되어 효율적 처리가 가능하다는 것이다.



38bfde68f5dc3f8650bbd58b36877768edfc



자, 그럼 이제 C계열의 언어에서 배열의 저장방법이 row-major라서 이중 for문을 작성할때, a[i][j]로 작성한다면


포트란,매틀랩 과학에서는 왜 a[j][i]로 작성하는가?


그것은 포트란과 매틀랩이 열(column)-major 로 배열을 저장하기때문이다.


캐시 메모리 자체는 단순히 연속된 메모리 블록(캐시 라인)으로 읽히기때문에, 그저 메모리상의 연속성, 즉 배열이 어떻게 저장됐는지가 중요한 것이다.


그래서 각 배열의 저장방식에 따라서


이중 포문의 바깥을 행으로 할지, 이중 포문의 바깥을 열로 할지 선택해서 더 효율적인 방식을 고려하는 것이고.


참고로 C의 배열방식이 저렇게 되는 이유는 row major order를 채택한 것은 포인터 산술 주소가 row - major-order를 선택하는게 표기하는 게 훨씬 쉬워서였고


포트란- 매틀랩과 같이 과학에서 쓰이는 언어가 col major order를 채택한 것은 선형 대수에서 수학적 표기할때 벡터를 열벡터로 표기하는 경우가 많아서였다.


즉 공학에 가까운 계열이면 row-major를 과학에 가까운 계열이면 col-major를 쓰는 경우가 많다! 라고 이해하면 편하다


따라서 프붕이들도 이중 포문을 쓰기전에 배열의 저장방식때문에 이렇게 쓰는구나 생각하면서 써보는 것은 어떨까?






추천 비추천

8

고정닉 2

2

댓글 영역

전체 댓글 0
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 시구, 시축 했다가 이미지가 더 나빠진 스타는? 운영자 25/08/11 - -
AD 가전디지털, 휴대폰 액세서리 SALE 운영자 25/08/08 - -
공지 프로그래밍 갤러리 이용 안내 [92] 운영자 20.09.28 46319 65
2881532 '19) 기룡이 복귀 방송중 프갤러(112.186) 22:20 2 0
2881530 내일부터 찬물샤워 미라클모닝 할거야 재현갤로그로 이동합니다. 22:19 2 0
2881529 '틱톡에 우아, 태이 떡방박제됨 ㅋ 짤리기 전에 봐ㄱㄱ 프갤러(112.186) 22:16 3 0
2881528 나님 쉬야완⭐+ ♥냥덩이♥갤로그로 이동합니다. 22:16 4 0
2881523 크롬창 뒤로 보내니까 유튜브 렉걸리는데 ㅇㅇ(106.241) 21:58 7 0
2881521 수학 넘 잼씀 ♥냥덩이♥갤로그로 이동합니다. 21:48 11 0
2881520 우연치 않게 엄청난 걸 발견해 버렸다... 프갤러(221.154) 21:36 16 0
2881517 8.14 국회 국제 심포지엄 생중계 / 전후 80년, 세계 그리고 한국 발명도둑잡기갤로그로 이동합니다. 21:24 9 0
2881513 모기 있는거 같당.. ♥냥덩이♥갤로그로 이동합니다. 21:18 11 0
2881507 퐁퐁남 석열이 도축 엔딩 뜨노 ㅠㅠ [1] 아스카영원히사랑해갤로그로 이동합니다. 21:08 29 0
2881503 이때 모모링은 귀여웠는데 ㅠ ♥냥덩이♥갤로그로 이동합니다. 21:03 14 0
2881502 도쿄 외곽 4인가족 집이 아스카영원히사랑해갤로그로 이동합니다. 21:01 21 0
2881500 나님 주무실게양⭐+ ♥냥덩이♥갤로그로 이동합니다. 20:54 13 0
2881499 데뷔 1년차 신입 걸그룹 스케줄 [1] 발명도둑잡기갤로그로 이동합니다. 20:53 12 0
2881498 결단력없이 떠내려온 결과가 지금입니다. 프갤러(220.84) 20:51 13 0
2881496 오 씨발 살려다오 [1] 골방외톨이갤로그로 이동합니다. 20:47 20 0
2881495 형들 파이썬 무료강의 둘중에 뭐가 더 좋아요? 프갤러(86.48) 20:37 11 0
2881494 요새 애니메이숀 색칠 쉬워졌겠지? 발명도둑잡기갤로그로 이동합니다. 20:36 9 0
2881493 MC Sniper / 인생 (Feat. 웅산) 발명도둑잡기갤로그로 이동합니다. 20:04 13 0
2881492 용산 갔다 왔다 외국인 사장님들 내 질문에도 답해주셔서 [4] 넥도리아(220.74) 19:56 18 0
2881491 영화 <살인자 리포트> 나왔대서 생각나는 예전 글 발명도둑잡기갤로그로 이동합니다. 19:48 15 0
2881490 한국 곳곳에서 숨 막히는 추격전이 시작된다! #버터플라이 발명도둑잡기갤로그로 이동합니다. 19:40 20 0
2881489 최종면접 봤는데 제발 붙었으면 좋겠다 [1] 프갤러(14.12) 19:28 24 0
2881488 광복절 알빠노 ㅇㅅㅇ 저녁은 초밥먹어야징 ㅇㅅㅇ 류류(118.235) 19:08 15 0
2881487 나님 낼 뛰뛰 해야징 같이 하실분 구함 [1] ♥냥덩이♥갤로그로 이동합니다. 19:06 22 0
2881486 프갤 좆같아서 슬슬 멀티함 [2] 아스카영원히사랑해갤로그로 이동합니다. 19:05 44 1
2881485 특이점 온다 노동해방시대 온다 ㅇㅇ [2] 뒷통수한방(1.213) 18:59 20 1
2881484 공부를 해도 또 까먹음 [4] 밀우갤로그로 이동합니다. 18:57 36 0
2881483 멍유는 내일도 출근해라 ㅇㅅㅇ [2] 류류(118.235) 18:51 31 0
2881482 사람은 변하지않음 뒷통수한방(1.213) 18:48 18 0
2881481 면접 존나 힘들다 ㅅㅂ;;; 프갤러(220.85) 18:39 28 0
2881480 조센징 개센징 씹센징 똥싼징 춍센징 손발이시립디다갤로그로 이동합니다. 18:35 19 0
2881479 조직스토킹으로부터 안전한나라를 만듭시다 [4] 손발이시립디다갤로그로 이동합니다. 18:30 25 0
2881478 패전기념일 연휴가 시작되었습니다 아스카영원히사랑해갤로그로 이동합니다. 18:29 24 0
2881477 바나나 ♥냥덩이♥갤로그로 이동합니다. 18:26 18 0
2881476 졸피뎀 ♥냥덩이♥갤로그로 이동합니다. 18:22 19 0
2881475 코딩 너무 어렵다 프갤러(119.194) 18:22 21 0
2881473 DI에 빠져부럿다 깃깃갤로그로 이동합니다. 17:36 33 0
2881472 나님 냥덩원 비밀요원.. [1] ♥냥덩이♥갤로그로 이동합니다. 17:33 32 0
2881471 패배자처럼 살기 싫으면 뭘 어떻게 해야하는걸까... [1] ㅇㅇ(223.39) 17:30 27 0
2881470 애널의달성 2.1/1/3 ♥냥덩이♥갤로그로 이동합니다. 17:29 28 0
2881469 커뮤에서 비전 있는 종목과 돈버는 방법을 알려주면 ㅇㅇ갤로그로 이동합니다. 17:26 26 0
2881468 형들 이거 왜이래..? [2] 프갤러(211.192) 17:22 33 0
2881467 전한길 심리분석 발명도둑잡기갤로그로 이동합니다. 17:04 30 0
2881466 좇센에서 태어나서 러스트??ㅋㅋ그새끼가 비정상적인거아님??? 뒷통수한방(1.213) 17:04 20 0
2881464 러스트 까는 친구들 보면 좀 안타깝다. [1] 프갤러(218.154) 16:40 41 0
2881463 비전이 확실하지만 무보수인 기획, 개발자분들 의견이 궁금합니다 [15] 프갤러(1.242) 16:38 110 0
2881462 디시에서 조언은 99% 잘못된 조언이다. [2] ㅆㅇㅆ(124.216) 16:07 51 0
2881461 비전공 국비 자바 취업했다. [3] 프갤러(220.117) 16:01 80 0
뉴스 이창섭, 27일 영화 ‘첫사랑 엔딩’ 컬래버 음원 ‘한번 더 이별’ 발매 디시트렌드 08.13
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2