Loading...

메모리 관리

메모리 관리 구현 선택, 구현의 모순, 동적 할당 문서 옵션 이 페이지 출력 이 페이지를 이메일로 보내기 제안 및 의견 피드백 난이도 : 초급 Jonathan Bartlett, 기술 디렉터, New Media Worx 2004 년 11 월 16 일 리눅스 프로그래머들이 사용할 수 있는 메모리 관리 기술을 살펴본다. C 언어 중심으로 설명 하겠지만 다른 언어들에도 적용할 수 있다. 메모리 관리가 어떻게 수행되는지, 메모리를 수동으로 관리하는 방법, 카운팅(counting) 또는 풀링(pooling)을 반-수동으로 관리하는 방법, 가비지 컬렉션을 사용하여 메모리를 자동으로 관리하는 방법을 설명한다. 메모리가 관리되어야 하는 이유 메모리 관리는 컴퓨터 프로그래밍의 가장 근본적인 분야 중 하나이다. 스크립팅 ..

호출규약

함수 호출 규약 2006-09-01 신영진 원문 : http://www.jiniya.net/lecture/techbox/callconv.html 함수를 호출하는 형태에는 여러 가지 방법이 있다. Visual C++에서는 네 가지 형태의 호출 규약을 지원한다. __cdecl, __fastcall, __stdcall, __thiscall이 그것이다. 각 호출 규약은 비슷하지만 약간 씩 차이를 가지고 있다. 각각의 호출 규약에 대한 특징을 살펴 보도록 하자. __cdecl C언어 표준 호출 규약이다. 파라미터는 오른쪽에서 왼쪽으로 스택을 통해 전달되며, 호출한 곳에서 스택을 정리한다. 특징적인건 호출한 쪽에서 스택을 정리하기 때문에 가변 인자를 지원한다는 것이다. view plaincopy to clipboa..

pascall stdcall cdecl

데브피아 비주얼씨 강좌에서 고임이라는 분이 쓴글입니다. 자 이제 제가 이야기 할건.. 무엇이냐면.. 보시죠. 역사성을 좀 가미해서.. Borland c++ Version 3.1이 나온 당시에는 cdecl과 pascal 호출 규약만이 존재했습니다. 그 이후에 cdecl과 pascal의 장점만을 따온 _stdcall이 나오게 된거구요. 따라서 비슷하게 보이는데 서로 틀리게 보이는 건 ^^ 바로 이런 연유에서 비롯됩니다. 이 넘들에는 두 가지의 다른 점이 있습니다.(또 있으면 리플 달아주세요..) (언더바는 생략할께요.. ) ●인수를 스택에 집어넣는 방향에 따라서 다음과 같이 나뉘고 pascal : 인수를 스택에 저장하는 순서를 왼쪽에서 오른쪽으로 한다. cdecl : 인수를 스택에 저장하는 순서를 오른쪽에서..

EC++ 2. define 대신 const, enum, inline 쓰기

const에 대한 이야기 나는 싱글톤을 쓰면서 항상 아래와 같은 방식으로 설정했다. #define g_pDevice MgDevice::GetInstance() 그래서 편리하게 g_pDevice를 마치 변수처럼 사용할 수 있었다. 하지만 이를 const로 바꾸면서 하나를 알게 되었다. const MgDevice* const g_pDevice = MgDevice::GetInstance(); 처음 생각은 이 클래스를 가리키는 g_pDevice 변수(define처럼 매크로가 아닌)는 값도 가리키는 클래스도 바뀌지 않고 주소도 바뀌지 않을 거라 생각해서 위와 같이 하였다. const로 바꾸고자 했던 이유는 define는 기호 테이블에 이름이 들어가지 않으며 컴파일러에서도 에러체크를 해주기 때문이다. 게다가 def..

How to Use __declspec(dllexport) in an MFC Extension DLL

이 기사의 정보는 다음에 적용된다 : 다음을 포함하는 Microsoft Foundation Classes(MFC) : Microsoft Visual C++, 32bit Edition, 버전 2.0, 2.1, 4.0 SUMMARY 이 기사는 MFC 기술노트 #33을 보충한다. 그것은 약간의 중복된 정보, 약간의 수정을 포함하며, 클래스와 멤버를 확장 DLL로부터 익스포트하기 위해 도움을 주는 보충 정보들을 제공한다. MORE INFORMATION 확장 DLL 생성하기 MFC Extension DLL 프로젝트를 생성하기 위해 AppWizard를 사용할 수 있으며, 그것은 자동으로 적절한 컴파일러와 링커 설정을 생성한다. 더 세부적인 정보를 원한다면 AppWizard entry in the MFC Encyco..

stl set

내가 애용하려는 C++ 라이브러리 중 STL 이란 것이 있다. 어찌보면 C++ 의 꽃이라고도 할 수 있는 이 라이브러리 중 내가 주로 쓰는 것은 vector 와 map 타입인데, 가끔 이것들이 가진 데이터의 중복허용이라는 기능상 제한으로 인해 곤란할 때가 있다. 이를 위해 해결책으로 set 이란 타입을 사용할 수 있다고 되어 있기에 어떻게 이 타입을 쓰는 것인 지 알아보려 하였는데, 실망스럽게도 딱 한눈에 잘 설명해 놓은 사이트가 잘 없어 고생을 한 끝에 별 것도 아닌 사용법을 익히게 되어 여기 정리를 해둔다. set 은 vector 처럼 data 만을 key 없이 추가할 수 있는 반면, vector 나 map 과는 달리 중복된 데이터를 허용하지 않는다. 1. 선언 예를 들어, integer 의 set ..

2009. 7. 20. 19:03

bitarray 제작, 활용

bitarray 간단버전. 물론 gpg 1.10장 조낸 베낀거임. bitarray에 대한 활용은 여러가지 생각해 볼 수 있을 것 같다. 나열된 수열에서 중복제거나 sorting, 중복갯수 알아내기등 간단한 테스트를 위한 코드. int _tmain(int argc, _TCHAR* argv[]) { int iList[] = {5,3,2,11,3,7,4,5,2,4,18,17,3,15,17,18,6,9,19,11}; MgBitArray mybit(20); mybit.Clear(); for(int i=0; i

bitarray

개념은 간단합니다. 말 그대로 비트(bit)열을 배열처럼 다루게 해주는 클레스입니다. 예를들어 '00100101101011'의 비트열이 있다고 할때, 오른쪽에서 5번째 비트값을 조사하려고 하면 'BitArray[4]' 와 같은 형식으로 참조할 수 있습니다. 특정 비트를 셋트할 때도 역시 마찬가지로 수행할 수 있습니다. (ex: BitArray[n] := True) 그럼 이걸 어디에 써먹을 수 있을까요? 제 경우는 숫자의 중복을 검사하기 위해서 이 클레스를 활용했습니다. 가령, 0 ~ 999 중에서의 숫자들로 만들어진 수열이 있다고 할 때, 이 수열에서 중복된 수가 있는지 검사하려고 할때 Bit Array를 이용하면 간단하고 빠르게 처리할 수 있습니다. 우선 BitArray의 크기를 1000으로 잡고 생성..