ShovelingLife
A Game Programmer
ShovelingLife
전체 방문자
오늘
어제
  • 분류 전체보기 (1072)
    • 그래픽스 (57)
      • 공통 (19)
      • 수학 물리 (22)
      • OpenGL & Vulkan (1)
      • DirectX (14)
    • 게임엔진 (183)
      • Unreal (69)
      • Unity (103)
      • Cocos2D-X (3)
      • 개인 플젝 (8)
    • 코딩테스트 (221)
      • 공통 (7)
      • 프로그래머스 (22)
      • 백준 (162)
      • LeetCode (19)
      • HackerRank (2)
      • 코딩테스트 알고리즘 (8)
    • CS (235)
      • 공통 (21)
      • 네트워크 (44)
      • OS & 하드웨어 (55)
      • 자료구조 & 알고리즘 (98)
      • 디자인패턴 (6)
      • UML (4)
      • 데이터베이스 (7)
    • 프로그래밍 언어 (348)
      • C++ (167)
      • C# (90)
      • Java (9)
      • Python (33)
      • SQL (30)
      • JavaScript (8)
      • React (7)
    • 그 외 (9)
      • Math (5)
      • 일상 (5)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

  • Source Code 좌측 상단에 복사 버튼 추가 완료
  • 언리얼 엔진 C++ 빌드시간 단축 꿀팁
  • 게임 업계 코딩테스트 관련
  • 1인칭 시점으로 써내려가는 글들

인기 글

태그

  • 그래픽스
  • 함수
  • 프로그래머스
  • Unity
  • 티스토리챌린지
  • 오블완
  • 포인터
  • 클래스
  • C
  • 백준
  • 파이썬
  • C++
  • c#
  • 유니티
  • SQL
  • string
  • 문자열
  • 배열
  • 언리얼
  • 알고리즘

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
ShovelingLife

A Game Programmer

프로그래밍 언어/C#

C# 오버플로우(Overflow), 언더플로우(Underflow)

2023. 5. 21. 18:15

오버플로우

변수는 데이터를 담는 그릇과 같다. 그릇에 용량을 넘어사는 양의 물을 담으면 넘치는 것처럼,
변수에도 데이터 형식의 크기를 넘어서는 값을 담으면 넘쳐 흐른다. 이런 현상을 "오버플로우(Overflow)"라고 한다.

using System;


namespace FlowExam
{
    class FlowExample
    {
        static int Main(string[] args)
        {
            byte variable = byte.MaxValue;

            Console.WriteLine($"{variable}");

            // 오버플로우 발생
            variable++;

            Console.WriteLine($"{variable}");

            return 0;
        }
    }
}

/* 결과

255
0

*/

byte의 최대값은 255이다. 255는 이진수로 변환하면 1111 1111이다. 이진수 1111 1111에 1을 더하면 1 0000 0000이된다. 허나 byte는 1바이트, 즉 8개의 비트만 담을 수 있으므로 넘쳐 흘른 왼쪽의 비트는 버리고 오른쪽 8개의 비트만 보관한다. 그래서 최대값을 가진 byte형식 변수가 오버플로우되면 0이 되는 것이다. 

언더플로우

각 데이터 형식의 최대값을 넘어가는 데이터를 저장할 때는 오버플로우가 일어나지만, 최저값보다 작은 데이터를 저장하면 언더플로우(Underflow)가 일어 난다. 가령 byte 형식 변수에 -1을 담으려는 시도가 일어나면 실제로는 이 변수에 255가 담긴다.
오버플로우나 언더플로우를 적절하게 코드에 이용하는 프로그래머들도 있지만, 기본적으로는 조심해야 하는 현상들이기 때문에 수 데이터를 다루는 코드를 작성할 때는 다루려는 데이터의 범위와 변수의 형식을 적절하게 맞춰주는 것이 필요하다.

using System;


namespace FlowExam
{
    class FlowExample
    {
        static int Main(string[] args)
        {
            sbyte variable = sbyte.MinValue;

            Console.WriteLine($"{variable}");

            // 언더플로우 발생
            variable--;

            Console.WriteLine($"{variable}");

            return 0;
        }
    }
}

/* 결과

-128
127

*/

signed byte의 최저값 -128에서 -1을 빼려고 시도하니 signed byte의 최고값이 나왔다.
그 이유는, -128의 이진수는 1000 0000이다. -1의 이진수 1111 1111이다. 이 두개의 비트를 더하면 0111 1111 (127) 이라는 값이 도출된다. 이렇게 언더플로우 발생하여 sbyte의 최고값이 나타났다.

 

출처 : https://nomad-programmer.tistory.com/138

저작자표시 (새창열림)

'프로그래밍 언어 > C#' 카테고리의 다른 글

C# 문자열 공백 기준으로 분할  (0) 2023.06.13
C# _ Discard (변수 무시)  (0) 2023.06.07
C# Thread 클래스 (스레드)  (0) 2023.03.24
C# Task 클래스  (0) 2023.03.24
C# foreach 사용법과 다양한 예제  (0) 2023.01.08
    '프로그래밍 언어/C#' 카테고리의 다른 글
    • C# 문자열 공백 기준으로 분할
    • C# _ Discard (변수 무시)
    • C# Thread 클래스 (스레드)
    • C# Task 클래스
    ShovelingLife
    ShovelingLife
    Main skill stack => Unity C# / Unreal C++ Studying Front / BackEnd, Java Python

    티스토리툴바