📌 etc
C++ / 동적 배열
#pragma once #include "assert.h" // 동적 배열 클래스 템플릿 template class DynamicArray { private: T* adress;// 배열의 첫번째 인덱스 주소 int dataCount; // 배열에 저장된 요소의 개수 int maxCount; // 현재 배열에 저장할 수 있는 최대 요소의 개수 public: void push_back(const T& data); void resize(int size); T& operator [] (int index); public: DynamicArray(); ~DynamicArray(); }; template DynamicArray::DynamicArray() : adress(nullptr) , dataCount(0) ..
C++ / 포인터
// 포인터 변수 앞의 자료형은 특정 변수의 주소에서 얻은 값을 해석하는 단위이다. // 다음의 경우는 short(2byte) 타입의 변수를 int 즉, 4바이트의 단위로 값을 해석하겠다는 의미이다. short s = 100; int* ptr = (int*)&s; // 배열이란 메모리가 연속적으로 배치되어있는 자료구조이다. // 포인터 배열의 경우 포인터를 1증가시키면 실질적으로는 포인터 변수의 자료형의 크기에 따라 주소값이 증가한다. // 즉 char형일 경우에는 1byte, short 형일 경우에는 2byte, int 형일 경우에는 4byte 씩 증가한다. int arr = {1, 2, 3, 4, 5}; int* ptr = arr;// 배열의 이름은 해당 배열의 시작 주소를 나타냄(arr = arr[..
C++ / Visual Studio 단축키
// 유용한 Visual Studio 단축키 // 지정한 구문 주석 처리 : Ctrl + k, c // 지정한 구문 주석 해제 : Ctrl + k, u // Alt + Drag // 디버깅 시작 : F5 // 다음 중단점까지 코드 실행 : F5 // 디버깅 중단점 생성 및 해제 : F9 // 디버깅 중, 구문 수행 : F10 // 디버깅 중, 구문 수행(함수 진입, 좀 더 섬세한 작업 가능) : F11 // 디버깅 중, 디버깅 종료하기 : Shift + F5
C++ / 비트 연산자
#define HUNGRY = 0x1// 16진수를 사용하여 표현하는 것이 일반적임 #define THURSTY = 0x2// 0x1, 0x2, 0x4, 0x8, 0x10, 0x20, 0x40, ... #define ... = 0x4 . . . #define ... = 0x10 #define ... = 0x20 #define ... = 0x40 #define ... = 0x80 #define ... = 0x100 #define ... = 0x200 . . . // 비트 곱(&), 합(|), xor(^), 반전(~) // 비트 단위로 연산을 진행 // & : 둘 다 1인 경우 1 // | : 둘 중 하나라도 1인 경우 1 // ^ : 같으면 0, 다르면 1 // ~ : 1은 0으로, 0은 1로 // 특정 ..