ref

2025. 10. 21. 18:49·⭐C Sharp/10. 참조

C# ref 완전 정리

ref 는 값이 저장된 위치 ( 메모리 주소 ) 를 직접 전달하는 키워드이다.

호출자가 가진 변수를 복사하지 않고 그 원본을 그대로 함수나 다른 변수에게 넘긴다

  • 수정 가능 : 피호출자가 값을 바꾸면 호출자 변수도 함께 바뀐다
  • 복사 비용 절감 : 특히 큰 struct ( 값 형식 ) 전달 시 복사 오버헤드 감소
  • out : 반드시 초기화해서 돌려주기 ( 입력은 의미 없다 )
  • in : 읽기 전용 ( by - ref 로 가져오되 수정 금지 , 복사 최소화 )
  • ref : 읽고 / 쓰고 모두 가능 ( 원본 수정 )

 

 

1. 매개변수로 사용

void Foo(ref int x) { x += 10; }

int a = 5;
Foo(ref a); // a == 15

호출부에도 ref 가 필요하다 ( 둘 다 작성해야 한다 )

 

 

 

2. ref 지역변수 ( ref local )

int[] arr = { 1, 2, 3 };
ref int r = ref arr[1]; // r은 arr[1]의 "별칭"
r = 42;                 // arr[1] == 42

 

 

 

3. ref 반환 ( ref return )

ref int Find(ref int[] xs, int value) {
    for (int i = 0; i < xs.Length; i++)
        if (xs[i] == value) return ref xs[i]; // 요소 "주소"를 반환
    throw new InvalidOperationException();
}

int[] data = { 10, 20, 30 };
ref int spot = ref Find(ref data, 20);
spot = 99;                 // data[1] == 99

반환 타입 앞 , return 에도 ref 가 필요하다

 

 

 

4. ref readonly

주소는 넘기되 읽기 전용으로 보장한다 ( 수정 불가 , 복사도 회피 )

ref readonly int ro = ref arr[0];

 

 

 

5. in / out 

  • ref T : read / write by - ref ( 초기화된 값 요구 )
  • in T : read - only by - ref ( 초기화된 값 요구 , 복사 최소화 )
  • out T : write - only by - ref ( 호출 전 초기화 불필요 , 반드시 설정해서 반환 )

 

 

 

6. ref struct , ref readonly struct

  • Span<T> 처럼 스택 한정 타입 , 힙으로 못나간다 ( 캡처 / 박싱 금지 )
  • 성능 안전 ( 범위 제약 ) 목적 , ref 와 자주 함께 등장한다

 

 

예시 코드

▼ Swap

static void Swap(ref int a, ref int b)
{
    int tmp = a;
    a = b;
    b = tmp;
}

int x = 1, y = 2;
Swap(ref x, ref y);  // x=2, y=1

 

 

▼ 큰 구조체 복사 줄이기

struct Big
{
    public fixed byte buffer[1024]; // 예시: 매우 큰 값 형식
}

static void Touch(ref Big b) { /* b 수정 */ }

Big big = default;
Touch(ref big);  // 큰 복사 없음(주소만 전달)

 

 

▼ ref return 으로 컬렉션 내부 직접 수정

static ref int ElementRef(int[] xs, int index)
{
    if ((uint)index >= (uint)xs.Length) throw new ArgumentOutOfRangeException();
    return ref xs[index];
}

int[] a = { 5, 6, 7 };
ref int e = ref ElementRef(a, 2);
e++;                 // a[2] == 8

 

 

▼ ref readonly 로 안전하게 노출

static ref readonly int MaxRef(in int x, in int y)
    => ref (x >= y ? ref x : ref y);

int i = 10, j = 20;
ref readonly int m = ref MaxRef(in i, in j);
// m = 0;   // 컴파일 에러( 읽기 전용 )
Console.WriteLine(m); // 20

 

 

▼ foreach ref + Span<T> 로 in - place 변환

int[] nums = { 1, 2, 3, 4 };
Span<int> s = nums;

foreach (ref int v in s)
    v *= 2;           // 원본 배열이 직접 수정됨

// nums == {2,4,6,8}

 

 

 

주의할 점

  • 호출부에도 ref 를 명시해야 한다 ( 헷갈리면 컴파일 에러로 알려준다 )
  • ref 인수는 변수여야 하며 , 읽기 / 쓰기 가능한 저장 위치여야 한다
  • ref 매개변수는 호출 시 이미 초기화되어 있어야 한다 ( out 과 다르다 )
  • 선택적 매개변수 ( 기본값 ) 로 ref / oun / in 은 사용할 수 없다
  • ref 로 넘긴 값을 여기저기서 수정하면 가시성 / 추적이 어려워진다

 

 

정리

ref 는 원본 값의 주소를 직접 넘겨서 복사 없이 읽고 쓰게 해주는 키워드이다.

큰 struct 성능 최적화와 in - place 수정에 유용하지만

수명 , 불변성 , 쓰레드 안전을 꼭 관리해야 한다.

'⭐C Sharp > 10. 참조' 카테고리의 다른 글

참조 ( Reference Type )  (0) 2025.09.28
'⭐C Sharp/10. 참조' 카테고리의 다른 글
  • 참조 ( Reference Type )
DevHoChan
DevHoChan
맨땅에서 시작하는 코딩 도전
  • DevHoChan
    Debugging Life
    DevHoChan
  • 전체
    오늘
    어제
    • 분류 전체보기 (374)
      • 🕹️Game Life (1)
      • 🖥️Computer Science (5)
      • 📖TIL (141)
        • 🔥Projects (16)
        • 💡DevTips (5)
        • 🤔발생한 문제와 해결 (5)
        • 🔮Unity Graphics (5)
        • 🎤Interview (3)
        • ✅CodingTest (9)
      • 🚀Game Release (4)
      • 🧊Unity Basic (58)
        • 📌용어 사전 (1)
        • 에디터&인터페이스 (3)
        • 디버그 (1)
        • 라이프사이클 (4)
        • 게임오브젝트 (4)
        • 프리팹 (1)
        • 오브젝트풀링 (4)
        • 애트리뷰트 (2)
        • 트랜스폼 (4)
        • 물리&충돌 (1)
        • 프레임&델타타임 (4)
        • 코루틴&이벤트 (7)
        • 수학&보정함수 (3)
        • 디자인패턴 (9)
        • UGUI (3)
        • 벡터 ( Vector ) (3)
        • 씬 ( Scene ) (2)
        • 데이터 관리 (2)
      • ⭐C Sharp (99)
        • 📌용어 사전 (1)
        • 📌문법 사전 (6)
        • 메모리 관리 (3)
        • 00. 문법 (17)
        • 01. 변수 (3)
        • 02. 자료형 (2)
        • 03. 연산자 (6)
        • 04. 조건문 (2)
        • 05. 반복문 (2)
        • 06. 배열 (3)
        • 07. 메서드(함수) (7)
        • 08. 열거형 (3)
        • 09. 구조체 (2)
        • 10. 참조 (2)
        • 11. 객체 지향 (11)
        • 12. 델리게이트 (3)
        • 13. 디자인 패턴 (7)
        • 14. LINQ (1)
        • 📂▼자료구조 (2)
        • 15-1. 제네릭 (3)
        • 15-2. 배열 (4)
        • 15-3. 리스트 (2)
        • 15-4. 스택과 큐 (2)
        • 15-5. 딕셔너리 해시테이블 (2)
        • 15-6. 트리와 그래프 (3)
      • 📊Algorithm (16)
        • BigO (2)
        • 정렬 (4)
        • 셔플 (2)
        • 탐색 (6)
        • 최적화 (1)
      • 📝Game Design (16)
      • 🤖​AI Tools (12)
        • AI 리뷰 분석 (6)
        • Player2 (0)
        • 3D 모델링 (1)
        • 2D 스프라이트 (0)
        • 이미지 (2)
        • 사운드 (1)
        • 동영상 (1)
        • 문서 (1)
      • 🌍Network (6)
      • 🌱Github (11)
        • 기본 개념 (7)
        • 명령어 (1)
        • 도구 활용 (1)
      • ⚙️Visual Studio (5)
        • 🔧설치 및 환경설정 (2)
        • ⌨️HotKey (1)
        • 🚨디버깅 (1)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    GitHub
    csharp
    디자인패턴
    게임기획
    유니티
    OOP
    gamedesign
    부트캠프
    기획
    자료구조
    til
    게임디자인
    자료형
    c#
    객체지향
    문법
    CodingTest
    algorithm
    unity
    메모리관리
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.4
DevHoChan
ref
상단으로

티스토리툴바