이쿠의 슬기로운 개발생활

함께 성장하기 위한 보안 개발자 EverNote 내용 공유

반응형

분류 전체보기 415

WinDBG Symbol File 이란?

Symbol File (심볼 파일) 이란? 디버그 심볼 파일이란 실행 파일을 빌드할 때 생성되는 디버그용 파일. 심볼 파일이 or 심볼이라고 불러짐 심볼 파일에 포함되는 정보 실행 파일안에 존재하는 함수, 변수의 이름, 위치, 소스 파일, 소스 라인 정보. Visual studio나 WinDbg 같은 비거거는 이 심볼 파일을 이용해 소스 라인 디버깅을 가능하게 함 심볼 파일 생성법 Visual studio 의 경우 Debug 빌드 시 자동 생성 Release 빌드는 생성 되지 않음 하지만 Release 빌드라도 심볼 파일은 생성해놔야 함 (디버깅을 위해) Relase 빌드에서 심볼 생성 방법 1. 프로젝트 메뉴의 속성 2. 상단의 구성(Configuration) 을 [Release] or [All Con..

WinDBG 사용법

WinDbg란? Windows OS에서 실행되는 제품을 개발한 후 사용중인데 프로그램이 갑자기 종료되거나 오류가 발생하는 경우가 생길 수 있음. 이런 경우 개발자는 본인이 만든 제품에 문제가 있을 시 원인을 찾아야하는데 이러한 오류를 분석하는 과정을 디버깅이라고 함. Windows 경우에는 프로그램이 runtime error가 발생하거나 원인 불명으로 종료되는 경우 당시의 상황을 파일형태로 남겨놓을 수 있는데 그 파일을 Dump파일이라고 함. 그렇다면 개발자는 이러한 Dump파일을 분석해야 정확한 오류의 원인을 파악하고 프로그램을 수정할 수 있음. WinDbg는 개발자가 Dump파일을 분석할 때 사용할 수 있는 Tool임. MS에서 배포하는 Windows OS 전용 디버깅 툴로 유져모드 어플리케이션, 드..

SVN Revision 주석 다는 법

SVN Revision 주석 다는 법 C, C++, JAVA등 각종 언어에서 주석을 추가하여 commit에 대한 정보를 자동으로 남길 수 있음 1. 관리 하고자 하는 파일에서 마우스 우클릭 -> TortoiseSVN 2. Properties 클릭 3. 창이 나오면 우측 하단의 New.. 클릭 4. Other 클릭 5. 창이 나올 것 6. 상단의 Property name : 을 svn:keywords 선택 7. Property value: 에 항목 추가 Id Revision LastChangedBy 8. 저장 후 창 모두 닫기 9. 완료가 된 상태에서 주석에 다음과 같이 추가 $Id$ $LastChangedBy$ $Revision$ 10. 완료 후 SVN commit 하면 commit 정보가 주석에 저장됨..

Tool 사용법/SVN 2020.09.11

SVN 이란?

SVN SubVersion 의 줄임말로 형상관리툴임 프로젝트 소스는 Trunk 라는곳에 위치 자신의 로컬에 Trunk 소스를 다운받아(update) 수정 및 추가 후 다시 업로드(commit) 하는 방식 형상관리란? 프로젝트를 진행할 때 각자 업무를 나눠서 맡은 부분을 개발하게 되는데 각자가 개발한 코드 혹인 문서들을 하나의 관리 도구에서 통합적, 버전별로 관리하게 되는 것을 형상관리 혹은 버전관리라고 부름 SVN 용어 Repository 프로젝트 파일 및 변경 정보가 저장되는 저장소 모든 프로젝트의 프로그램 소스들, 변경 사항이 저장됨 네트워크를 통해서 여러 사람이 접근 할 수 있음 Trunk 개발 소스를 commit 했을 때 개발 소스가 모이는 곳으로 프로젝트에서 가장 중심이 되는 디렉토리, 소스와 ..

Tool 사용법/SVN 2020.09.11

Git 코드를 잠깐 저장하고 다른 브랜치로 이동하기

Git 코드를 잠깐 저장하고 다른 브랜치로 이동하기 (STASH) 브랜치에서 작업이 아직 완료가 안됐는데 치명적인 버그가 발생하여 현재 작업 중이던 브랜치를 잠시 중단하고 다른 브랜치를 만들어서 작업을 해야할 때가 있음 바로 브랜치를 이동하기 위해 checkout 을 하게 되면 지금까지 작업 내용이 모두 날아가고 브랜치를 이동하기 전에 현재 작업하던 내용을 commit 해서 저장해야 하는데 commit 하기에는 작업이 많이 안되어서 애매할 때 STASH를 사용하면 해결됨 명령어 1.) git stash 새로운 stash를 스택에 만들어하던 작업을 임시로 저장 2.) git stash list 여러 번 stash를 했다면 저장한 stash 목록을 확인할 수 있음 3.) git stash apply --in..

Tool 사용법/Git 2020.09.07

Git add, commit, push 취소하기

Git add, commit, push 취소하기 git add 취소하기 실수로 git add * 명령을 사용하여 모든 파일을 스토리지 영역에 넣은 경우 취소하고 싶은 상황이 발생함 명령어 git reset HEAD 해당 파일만 git add 를 취소 git reset HEAD 파일 전체를 add 취소 git commit 취소하기 너무 일찍 commit 한 경우 어떤 파일을 빼먹고 commit 한 경우 취소하고 싶은 상황이 발생 명령어 1) git reset --soft HEAD^ commit을 취소하고 해당 파일들은 staged 상태로 워킹 디렉터리에 보존 즉 add 한 상태 staged 상태 2) git reset ---mixed HEAD^ commit 을 취소하고 해당 파일들 unstaged 상태로 ..

Tool 사용법/Git 2020.09.07

Git 원격 저장소에 pull하는 과정

Git 원격 저장소에 pull하는 과정 원격 저장소로 부터 내려받기 : fetch 내려받은 데이터를 병함 : merge 위의 두 명령을 한번에 처리하는 명령 : pull 1. pull 원격 저장소로부터 필요한 파일을 다운 + 병합 지역 브랜치와, 원격 저장소 origin/master 가 같은 위치를 가리킴 pull 은 로컬 저장소와 비교하여 병합을 하고 로컬 저장소에 add 까지 수행 git pull = git fetch + git merge [주의] 본인이 수정하고있던 파일과 동일한 파일이 원격저장소에서 수정되서 pull 되어질때 충돌할 가능성이 있으므로 확인해줘야함 [명령어] git pull origin master 예) git pull 2. fetch 원격 자장소로부터 필요한 파일을 다운 지역 브랜..

Tool 사용법/Git 2020.09.07

Git 브랜치 방법 (Branch)

Git 브랜치 방법 (Branch) master branch는 배포용. client들이 직접 사용하게 되는 배포 version. 그래서 필요한 기능은 병렬적으로 개발하게 되는 데 사용되는 기능이 branch 여러 버전을 관리할 수 있는 구조 1. 브랜치 생성 1.1. 먼저 현재 브랜치 목록을 확인 [명령어] git branch 현재 프랜치에는 ( * ) 가 붙음 이것은 브랜치가 master 것이고 현재 프랜치고 master 임을 나타내는 것 1.2. 브랜치 생성 [명령어] git branch 예) git branch subTest01 1.3. 브랜치 지점 이동 [명령어] git checkout 예) git checkout subTest01 1.4. 참고) 위 명령을 한번에 처리 [명령어] git chec..

Tool 사용법/Git 2020.09.07

Git 원격 저장소에 Push 하는 과정

Git 원격 저장소에 push 하는 과정 1. 원격 저장소 init or clone 원격저장소 종류 GitHub 명령어 git init 현재 디렉토리를 새로운 Git 저장소를 만드는 명령 git clone 현재 디렉토리에 기존의 git 저장소를 내려받는 명령 예) git clone http://github.com/~~ 2. Git 서명 작성 누가 어떤 수정을 하였는지 남기기 위해 자신만의 서명을 남겨야함 명령어 git config --global user.name="Iksoon.Park" git config --global user.email="test@naver.com" Git 설정파일을 적용을 함 유저 이름은 무엇이고 이메일 주소는 무엇인지 설정 3. Git 스테이지 영역에 추가 스테이지 영역이란? ..

Tool 사용법/Git 2020.09.07

Git 이란?

Git 소스코드의 효율적인 관리를 위한 형상 관리 도구 중 하나 형상관리란? 프로젝트를 진행할 때 각자 업무를 나눠서 맡은 부분을 개발하게 되는데 각자가 개발한 코드 혹인 문서들을 하나의 관리 도구에서 통합적, 버전별로 관리하게 되는 것을 형상관리 혹은 버전관리라고 부름 GitHub 소프트웨어 개발 프로젝를 위한 소스코드 관리 서비스 Git 과 SVN 차이점 SVN : 중앙 집중식 버전 관리 시스템 저장소가 serve r에 있음 관리되는 모든 파일을 저장하는 사나의 서버와 이 중앙 서버에서 파일을 가져오는 다수의 클라이언트가 존재 장점 1. (직관적) 모든 사람이 중앙서버에 있는 같은 자료를 받아오고 내가 한 업무가 commit 하는 순간 모두에게 공유됨 단점 1. 중앙 서버가 잘못되면 모든 것이 잘못된..

Tool 사용법/Git 2020.09.07
반응형