메뉴 건너뛰기

OBG

Programming

API/MFC
2013.07.28 03:39

__cdecl , __pascal, __stdcall

MoA
조회 수 334 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

윈도우즈의 역사

 

win16에서는 속도와 크기가 아주 중요시 되던 시절(win3.0 3.1)에 OS/2와 윈도우 설계자들이

API 함수를 설계할때 프로그램이 느려지고 크기가 커지는 C 방식을 사용하지 않고

pascal이나 fortran이 사용하고 있는방식으로 스택 프레임을 설계하게 되었고,

 

win32에서는 가변 매개인자를 지원하는 함수를 사용하기 위해 __stdcall방식을 사용한다.

 

만약c 방식의 함수호출을 원한다면 __cdecl을 명시해주어야 한다(API 프로그래밍중)

 

 

- C방식과 pascal 방식의 함수호출의 차이점

 

1. 함수 호출후 종료시점에 호출한 함수의 스택을 정리하는 주체

 

 - pascal 호출을 당하는 쪽이 스택공간을 정리

 - stdcall : 호출을 당하는 쪽이 스택공간을 정리

 - cdecl 호출을 하는 쪽이 스택공간을 정리

 

2. 매개인자를 스택에 넣는 방향

 

pascal 인수를 왼쪽에서 오른쪽순으로 스택에 저장한다

stdcall 인수를 오른쪽에서 왼쪽순으로 스택에 저장한다

cdecl 인수를 오른쪽에서 왼쪽순으로 스택에 저장한다.

 

여기서 알 수 있는 것은 stdcall은 cdecl과 pascal을 혼합한 형태를 취한다는 것이다.

 

임의의 함수를 호출해서 호출방식을 설정한후 디스어셈블 해보면

cdecl은 호출을 하는쪽에서 스택공간을 정리하므로 스택을 정리해주는 코드가

추가된다. 그 부분이 pascal에서는 사용되지 않고 단순히 리턴 시키므로

속도도 빨라지고 크기가 줄어든다.

 

두번째는 매개인자를 스택에 넣는 방향인데 이것이 중요한 이유는 바로

가변 매개인자를 사용할 수 있다는 것이다.

 

오른쪽에서 왼쪽순으로 스택에 저장되면 인자의 첫번째가 어디인지 확실하다는 것,

즉 알려진 장소에서 첫번째 인자를 찾아 낼 수 있다는 장점으로 가변인자를

허용할 수 있다는 것이다.

(오른쪽에서 왼쪽순이라는 말은 일반적인 스택이라고 생각했을때 상위에서 아래로)

 

단 함수호출이 끝난후 스택을 정리할때 호출한쪽에서 정확하게 스택을 사용한 사이즈를

알고 있기 때문에 문제가 되지 않으나 당한쪽에서는 또다른 정보를 가지고 사용한

스택 사이즈를 알아야 하기 때문에 문제가 발생할 수 있다는 것이다.

 

그런 이유로 stdcall은 함수호출방식은 파스칼이지만 가변매개인자는 지원하지 못하는 것이다.

가변 매개인자를 꼭 사용해야 한다면 cdecl을 사용해야 한다.

 

 

 

--------------------------   참고 ---------------------------

 

참고로 예전에는 파스칼 언어가 사용하는 함수호출 방식 pascal을 사용하기 위해

(호환성 및 안정성)C++에서는 pascal이라는 키워드를 지원했었다.

 

현재 지금은 사용되지 않으며 WINAPI 키워드를 사용하도록 변경되어있다.

 

그리고 pascal 키워드의 본래 기능을 사용하고 싶으면 WINAPI 사용후

링커 옵션에서 예전 옵션과 유사한 기능을 선택 할수 있도록 되어있다


http://blog.naver.com/sorkelf/40132292058

?

  1. Programming 게시판 관련

    Date2014.11.01 CategoryTool/etc ByMoA Views1708
    read more
  2. 컨텍스트 스위칭 (Context Switching)

    Date2013.07.28 CategoryTool/etc ByMoA Views1039
    Read More
  3. __cdecl , __pascal, __stdcall

    Date2013.07.28 CategoryAPI/MFC ByMoA Views334
    Read More
  4. fopen 함수가 Multi Thread 에서 안전한가?

    Date2013.07.28 CategoryC/C++ ByMoA Views585
    Read More
  5. memset vs for 초기화. 속도 차이가 얼마나 날까?

    Date2013.07.28 CategoryC/C++ ByMoA Views687
    Read More
  6. unsigned char <-> 유니코드(unicode) 및, string 변환 매크로 - USES_CONVERSION

    Date2013.07.28 CategoryAPI/MFC ByMoA Views1331
    Read More
  7. Redmine 설치

    Date2013.07.28 CategoryTool/etc ByMoA Views400
    Read More
  8. MFC 클래스 멤버함수 설명서

    Date2013.07.28 CategoryAPI/MFC ByMoA Views1513
    Read More
  9. Direct3D 9 compile

    Date2013.07.28 CategoryGraphic ByMoA Views267
    Read More
  10. Data Conversions

    Date2013.07.28 CategoryC/C++ ByMoA Views613
    Read More
  11. 다른 스레드에서 메인다이얼로그 포인터 받아오기 AfxGetMainWnd()

    Date2013.07.28 CategoryAPI/MFC ByMoA Views1615
    Read More
  12. 파일 입출력

    Date2013.07.28 CategoryC/C++ ByMoA Views487
    Read More
  13. char*, String, CString

    Date2013.07.28 CategoryAPI/MFC ByMoA Views367
    Read More
  14. CreateThread, ExitThread, GetExitCodeThread ...

    Date2013.07.28 CategoryAPI/MFC ByMoA Views373
    Read More
  15. Thread와 SendMessage를 통해 DeadLock을 만드는 방법

    Date2013.07.28 CategoryAPI/MFC ByMoA Views2625
    Read More
  16. 작업자 스레드(Worker Thread) 와 사용자 인터페이스 스레드(User Interface Thread)

    Date2013.07.28 CategoryAPI/MFC ByMoA Views446
    Read More
  17. WaitForSingleObject와의 삽질..

    Date2013.07.28 CategoryAPI/MFC ByMoA Views429
    Read More
  18. 스레드(CreateThread), EVENT 동기화

    Date2013.07.28 CategoryAPI/MFC ByMoA Views614
    Read More
  19. 스레드 강좌 + CreateThread() 와 _beginthreadex() 함수의 차이

    Date2013.07.28 CategoryAPI/MFC ByMoA Views416
    Read More
  20. 비주얼 스튜디오 2005 단축키

    Date2013.07.28 CategoryAPI/MFC ByMoA Views355
    Read More
  21. VC의 소스 파일, sln파일 관리

    Date2013.07.28 CategoryAPI/MFC ByMoA Views334
    Read More
Board Pagination Prev 1 ... 4 5 6 7 8 9 10 11 12 13 ... 15 Next
/ 15
위로