전체 글 (774) 썸네일형 리스트형 buffer overflow 사례1 [1. 개요]버퍼 오버플로우를 유발 할 수 있는 사례들을 정리한다. 포인터를 전달할 때, 실제 메모리는 해당 포인터 타입에 해당하는 크기만큼의 공간이 할당되어 있어야 한다.아래와 같은 타입 캐스팅은 가급적 하지 않는 것이 좋다.int value = 0x1234;long long *ptr = reinterpret_cast(&value);왜 그런가, ptr 을 대상으로 발생하는 연산은 ptr 이 가리키는 공간이 8byte 만큼 할당되어 있다고 판단하고연산을 진행한다.그러나, 실제 메모리 공간은 4바이트 이므로 할당된 메모리 공간을 넘어서는 문제가 발생할 수 있다. 아래 코드를 보면, func() 에는 변수 a 의 주소만 넘기는데, b 의 값이 변경되어 버린다.#include void func(unsigned.. Segmentation fault 사례5 [1. 개요]strncpy 사용 시, 버퍼 오버플로우 발생.정확히는, strncpy 사용 시 마지막 3번째 인자의 계산 오류로 인해 발생한 문제임. 아래와 같은 코드의 문제점은?#include #include #define max(a, b) ((a) > (b) ? (a) : (b))int main(){ char buf[512]; char buf2[512]; strcpy(buf2, "hello"); strncpy(buf, buf2, max(static_cast(strlen(buf2)) - strlen("helloworld"), 0)); std::cout 바로, int 와 size_t 간 자료형의 연산이다.size_t 는 64bit 프로그램에서.. 스레드 풀 사용 관련 [1. 개요]병렬 처리 등을 위한 스레드 풀 사용 예제I/O Bound 적합CPU Bound 작업 처리를 위해선, ProcessPoolExecutor 사용기본적으로 메모리 구조는threading=> pthread_create 기반, 전역 변수 등은 공유 됨.multiprocessing=> fork() 기반, 값은 같을 수 있지만 공유되지 않음=> 변수 공유를 위해선 별도 처리가 필요. (multiprocessing.Value, )[2. 예제] 이전 1 ··· 7 8 9 10 11 12 13 ··· 258 다음