일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | ||||
4 | 5 | 6 | 7 | 8 | 9 | 10 |
11 | 12 | 13 | 14 | 15 | 16 | 17 |
18 | 19 | 20 | 21 | 22 | 23 | 24 |
25 | 26 | 27 | 28 | 29 | 30 | 31 |
- c++
- MultiCore
- 디자인패턴
- thread
- stl
- 한국산업기술대학교
- C
- vector
- 게임공학과
- 프레임워크
- 옵저버 패턴
- observer pattern
- Multithread
- 멀티쓰레드
- Unreal
- EFFECTIVE C++
- multi-core
- 복사생성자
- 유니크포인터
- 멀티코어 프로그래밍
- 멀티코어
- 옵저버
- 스마트포인터
- Design Pattern
- Atomic
- material
- sequential
- 쓰레드
- 메모리관리
- random access
- Today
- Total
목록c++ (19)
태크놀로지

다음의 멀티쓰레드 프로그램에 어떠한 문제점이 있을까? bool data_ready = false; int g_data; void Consumer() { while (data_ready == false); int my_data = g_data; cout

옵저버 패턴의 단점 옵저버 패턴을 구현시 알림이 있을 때마다 동적할당을 하거나 큐잉하기 때문에 실제로 느릴 수 있습니다. 하지만 인터페이스를 통해 동기적으로 메서드를 간접호출할뿐 메시지용 객체를 할당하지도 않고, 큐잉도 하지 않습니다. 주의해야할점은 동기적이라는 점입니다. 대상이 관찰자 메서드를 직접 호출하기 때문에 모든 관찰자가 알림 메서드를 반환하기 전에는 다음 작업을 진행할 수 없습니다. 관찰자 중 하나라도 느리면 대상이 블록될 수 도있기 때문입니다. 이벤트에 동기적으로 반응한다면 최대한 빨리 작업을 끝내고 제어권을 넘겨주어 프로그램이 멈추지 않도록 해야합니다. ( 멀티쓰레드 사용시 이벤트 큐를 이용해 비동기적으로 상호작용하는것을 추천 ) 동적할당이 많이 일어날까? 게임에선 옵저버 개수가 정적인것이..

옵저버 패턴이란? 객체 사이에 일 대 다의 의존 관계를 정의해두어, 어떤 객체의 상태가 변할때 그 객체에 의존성을 가진 다른 객체들의 그 변화를 통지받고 자동으로 업데이트될 수 있게 만듭니다. 즉 한명의 상태가 변화될때 이로 인해서 변경되어야 할 다른 이벤트들을 수행해야할때 사용됩니다. 업적시스템을 예로들어 구현해보겠습니다. 작동원리 Observer 인터페이스 class Entity; class Observer { public: virtual void OnNotify(int _event, const Entity& data) = 0; public: Observer() = default; virtual ~Observer() = default; }; Observer는 Subject에서 발생하는 이벤트를 기다리..

멀티쓰레드 프로그래밍으로 덧셈프로그램 만들기:1-taek-gameprogramming.tistory.com/27?category=889762 멀티쓰레드 프로그래밍으로 덧셈프로그램 만들기 한국산업기술대학교 게임공학부 정내훈 교수님 멀티코어 2주차 강의 멀티쓰레드 프로그래밍에서 중요한사항 올바른 결과가 나와야한다. 싱글 쓰레드보다 성능향상이 커야한다. 실습1 - 여러 쓰 1-taek-gameprogramming.tistory.com 이전 포스팅에서 로컬변수를 사용하여 멀티쓰레드 프로그래밍으로 덧셈프로그램을 만들었었다. 로컬 변수를 사용하지 않는 다른 방법이 있을까? -> 각 쓰레드마다 변수들을 만들어서 쓰레드 종료 후 값들을 더해보자. 방법에 대한 문제발생 쓰레드가 종료하는가? Cache Trashing I..

커맨드 패턴이란? 요청 자체를 캡슐화하는 것입니다. 이를 통해 요청이 서로 다른 사용자를 매개변수로 만들고, 요청을 대기시키거나 로깅하여, 되돌릴 수 있는 연산을 지원합니다. 쉬운말로 누가 무엇을 해야할지에 대한 명령을 객체로 만들어 관리한다는 말입니다. 이 패턴은 예시의 사진을 보고 바로 구현하며 이해해봅시다. 실습 AI는 로직에 따라 대상에게 명령들을 내리면, 명령들이 큐에 차례대로 싸여 명령이 내려진 순서대로 대상이 명령을 수행하게 됩니다. 실습코드 Command 인터페이스 class GameObject; class Command abstract { protected: GameObject* m_Subject; int m_Message; public: v..

싱글턴 패턴이란? 오직 한개의 클래스 인스턴스만을 갖도록 보장하고, 이에 대한 전역적인 접근점을 제공합니다. 즉 어플리케이션이 작동하는동안 딱 한번만 생성되고, 어디서나 클래스에 접근할 수 있어 static의 분위기를 갖고 있습니다. 싱글턴을 왜 사용하는가? 어디서나 접근할 수 있다는 가장 큰 장점을 갖고 있는동시에, 인스턴스를 여러개 만들수도 없기 때문에 메모리 낭비에 대한 걱정이 줄어든다. 또한 싱글턴은 처음 사용될때 초기화되므로, 게임 내에서 전혀 사용되지 않는다면 아예 초기화 되지 않는다. 싱글턴의 문제점 게임이 복잡해지면서 싱글턴을 많이 사용하게 된 대가가 따른다. 싱글턴 과다사용 혹은 잘못된 사용은 커플링을 조장한다. 협업 시 코드를 이해하기 어렵게 한다. 전역의 분위기를 갖고 있는 싱글턴 객..

한국산업기술대학교 게임공학부 정내훈 교수님 멀티코어 1주차 강의 교재소개 모리스 헐리히, 니르 샤비트 "멀티프로세서 프로그래밍" 한빛미디어, 2009 장점: 멀티프로세서 프로그래밍 기초를 전부 언밀하게 다룸 단점: 알고리즘 위주로 실제 구현과는 차이가 있음 기타: 치명적인 번역오류, 자바를 사용한 구현 좀더 쉬운책 -> 프로그래머가 몰랐던 멀티코어 CPU 이야기 강의의 흐름 1.멀티쓰레드 프로그래밍의 필요성 / 작성시 문제점 2. 논블록킹 알고리즘의 필요성 3. 논블로킹 알고리즘 작성 테크닉 및 실습 4. 정리 및 상용라이브러리 소개 왜 멀티코어 프로그래밍을 하냐? 요즘 멀티코어를 사용하지 않는곳이 없다. 컴퓨터의 종류 직렬 컴퓨터 (Serial computer = Single core computer)..

STL std::vector vector가 어떤 방식으로 작동하고 메모리를 관리하는지에 대해 이해해봅시다. vector 컨테이너는 자동으로 메모리가 할당되는 배열입니다. 랜덤 엑세스 구조로 순회하는데는 최고의 성능을 보여주지만, 중간값을 삽입 삭제시 복사 이동연산으로 인해 효율이 많이 떨어지게 됩니다. std::vector 메모리 할당 과정 #include #include using namespace std; class TEST { private: int data; public: // 복사 생성자 TEST(const TEST& other) { cout