Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

C# - 지역 변수로 이해하는 메서드 매개변수의 값/참조 전달

간혹 메서드의 매개변수를 잘못 이해하고 계신 분들이 있는데요, 문법이 "메서드"라는 것에 엮여 있어 그런 것인지 혼란을 느끼는 듯합니다.

사실 간단하게 따져보면, 매개변수를 그냥 일반적인 지역 변수와 (기술적으로 복사 과정은 같기 때문에) 동일하게 생각해도 무방합니다. 예를 들어, 다음과 같은 메서드 호출을 볼까요?

internal class Program
{
    static void Main(string[] args)
    {
        int k = 5;

        Test(k);
    }

    static void Test(int i)
    {
        Console.WriteLine(i);
    }
}

인자 k를 Test 메서드의 매개변수 i에 전달하고 있는데요, 이것을 다음과 같이 일반적인 변수 대입으로 펼치셔도 됩니다.

internal class Program
{
    static void Main(string[] args)
    {
        int k = 5;

        Test(k);

        {
            int i = k;

            Console.WriteLine(i);
        }
    }
}

즉, 매개변수로 값이 복사되는 것과 저렇게 지역 변수로 값이 복사되는 것은 같은 동작입니다. 자, 그럼 이에 기반해서 문제를 풀어볼까요? ^^

internal class Program
{
    static void Main(string[] args)
    {
        MyClass instance = new MyClass { Id = 10 };

        Test(instance); // 출력 결과: 10 

        System.Console.WriteLine(instance.Id);
    }

    static void Test(MyClass parameter)
    {
        parameter = new MyClass { Id = 20 };
    }
}

class MyClass
{
    public int Id { get; set; }
}

위의 코드는 instance를 넘겨받은 Test 메서드의 parameter에 다시 new를 할당했습니다. 간혹, class가 참조 타입이라는 이유로 저런 경우 instance 변수도 바뀌어야 한다고 여기는 분들이 있는데요, 위의 것을 이전에 설명한 지역 변수로 다시 풀어서 보면 왜 그렇게 될 수 없는지 쉽게 파악할 수 있습니다.

internal class Program
{
    static void Main(string[] args)
    {
        var instance = new MyClass { Id = 10 };

        {
            MyClass parameter = instance;

            parameter = new MyClass { Id = 20 };
        }

        System.Console.WriteLine(instance.Id); // 출력 결과: 10
    }
}

class MyClass
{
    public int Id { get; set; }
}

위의 코드를 보면, parameter에 new로 새롭게 인스턴스를 대입한 것이 기존의 instance 변수에 영향을 미치지 못한다는 것을 쉽게 알 수 있습니다.

만약 넘긴 측의 인스턴스도 바꾸고 싶다면 다들 아시는 것처럼 매개변수에 ref를 적용하면 되는데요,

static void Main(string[] args)
{
    MyClass instance = new MyClass { Id = 10 };

    Test(ref instance);

    System.Console.WriteLine(instance.Id); // 출력 결과: 20
}

static void Test(ref MyClass parameter)
{
    parameter = new MyClass { Id = 20 };
}

마찬가지로 지역 변수를 이용해 위의 메서드 호출을 풀어보면 직관적으로 이해할 수 있습니다.

internal class Program
{
    static void Main(string[] args)
    {
        MyClass instance = new MyClass { Id = 10 };

        {
            ref MyClass parameter = ref instance;

            parameter = new MyClass { Id = 20 };
        }

        System.Console.WriteLine(instance.Id); // 출력 결과: 20
    }
}

대충 어떤 의미인지 아시겠죠? ^^




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 8/10/2023]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13945정성태6/7/2025332오류 유형: 960. 파이썬 + conda - mysqlclient 사용 시 "NameError: name '_mysql' is not defined" 에러
13944정성태6/7/2025336오류 유형: 959. The trust relationship between this workstation and the primary domain failed. - 네 번째 이야기
13943정성태6/6/2025453개발 환경 구성: 748. Windows + Foundry Local - 로컬에서 AI 모델 활용
13942정성태6/5/2025615오류 유형: 958. winget 설치 시 "0x80d02002 : unknown error"
13941정성태6/2/2025904닷넷: 2334. C# - cpuid 명령어를 이용한 CPU 제조사 문자열 가져오기파일 다운로드1
13940정성태6/1/20251292C/C++: 188. C++의 32비트 + Release 어셈블리 코드를 .NET으로 포팅할 때 주의할 점파일 다운로드1
13939정성태5/29/20251586오류 유형: 957. NVIDIA Triton Inference Server - version `GLIBCXX_3.4.32' not found (required by /opt/tritonserver/backends/python/triton_python_backend_stub)
13938정성태5/29/20251349개발 환경 구성: 747. 파이썬 - WSL/docker에 구성한 Triton 예제 개발 환경
13937정성태5/24/20251344개발 환경 구성: 746. Windows + WSL2 환경에서 (tensorflow 등의) NVIDIA GPU 인식
13936정성태5/23/20251173개발 환경 구성: 745. Linux / WSL 환경에 Miniconda 설치하기
13935정성태5/20/20251173파이썬 - pip 사용 시 "ImportError: cannot import name 'html5lib' from 'pip._vendor'" 오류
13934정성태5/20/20251701스크립트: 77. 파이썬 - 'urllib.request' 모듈의 명시적/암시적 로딩 차이
13933정성태5/19/20251270오류 유형: 956. Visual Studio 2022가 17.12 버전부터 업데이트 되지 않는다면?
13932정성태5/18/20251473스크립트: 76. 파이썬 - Version 문자열 다루기(semver 패키지)
13931정성태5/17/20251760스크립트: 75. 파이썬 - Cython 기본 예제 및 컴파일
13930정성태5/17/20251437개발 환경 구성: 744. 파이썬 - Windows embeddable package 환경에서 외부 패키지 사용하는 방법(ex: UFO² 환경 구성)
13929정성태5/16/20251467오류 유형: 955. 파이썬 - "Windows embeddable package" REPL 환경에서 "NameError: name 'exit' is not defined"
13928정성태5/15/20251523오류 유형: 954. UFO² - "'Invalid URL (POST /v1/chat/completions/chat/completions)'"
13927정성태5/15/20251521오류 유형: 953. OpenAI - The API request of HOST_AGENT failed: OpenAI API request exceeded rate limit: Error code: 429
13926정성태5/14/20251900개발 환경 구성: 743. LLM과 윈도우의 만남 - Desktop AgentOS UFO² 기본 환경 구성
13925정성태5/12/20251996닷넷: 2333. C# - (Console 유형의 프로젝트에서) Clipboard 연동파일 다운로드1
13924정성태5/8/20251731닷넷: 2332. C# - (JetBrains Omea Reader 대상으로) 런타임 시에 메서드 가로채기 [2]파일 다운로드1
13923정성태5/5/20251490스크립트: 74. 파이썬 - C# - Python.NET의 RunSimpleScript, Exec, Eval 차이점파일 다운로드1
13922정성태5/3/20251724스크립트: 73. 파이썬 - Windows embeddable package 버전에서 tkinter 환경 구성
13921정성태5/3/20252220오류 유형: 952. 듀얼 채널 메모리 정렬을 지키지 않은 컴퓨터의 Windows 비정상 종료 현상(Blue Screen) [2]
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...