경량 패턴

경량패턴의 핵심은 공유를 통한 최적화이다.

오브젝트 풀같은 경우 객체 자체를 재활용에 가까운 최적화라면 경량 패턴은 객체가 공유하는 하나의 객체를 참조하여 공유하는 것이다.

맵에 정말 많은 나무를 배치한다고 했을 때 유니티는 하나의 스프라이트 랜더러(나무 그림)를 공유하고 각각의 나무는 transform정도의 차이가 있다.

이미 GPU 인스턴싱이라는 기능이 유니티에 구현이 되어 있다.

GPU 인스턴싱

1
2
3
4
5
6
7
8
9
10
11
public class Tree
{
    private MeshRenderer mesh;
    private Texture bark;
    private Texture leaves;
    private Vector3 position;
    private double height;
    private double thickness;
    private Color barkTint;
    private Color leafTint;
}

기본적으로 맵에 배치되는 나무가 있다고 했을 때 간단하게 이 정도 클래스가 있다고 할 수 있다.

위 에서 말한 것 처럼 이 나무 클래스 객체를 100만개를 배치한다고 했을 때는 잡아먹는 메모리가 그 만큼 커지게 된다.

그렇다면 을 만들기 위해서 나무 객체가 공유할 수 있는 부분을 뽑아본다.

1
2
3
4
5
6
class TreeModel
{
    private Mesh mash;
    private Texture bark;
    private Texture leaves;
}

나무의 Mesh, Texture는 변하지 않는다 즉, 모든 나무는 한가지 객체만을 공유하여 화면에 보여주면 된다.

1
2
3
4
5
6
7
8
9
10
public class Tree
{
    private TreeModel model;
    
    private Vector3 position;
    private double height;
    private double thickness;
    private Color barkTint;
    private Color leafTint;
}

이제 위 Tree객체는 기본적으로 TreeModel을 참조하게 된다.


이 글은 게임 프로그래밍 패턴(로버트 나이스트롬 지음/ 박일 옮김)을 참고 하였습니다.

댓글남기기