정보) 컴퓨터공학과 과목 맛보기 - 2. 시스템프로그래밍(1)
어제 쓴 글이 별 반응은 없었으나.. 일단 적기 시작했으니까 계속 가보려고 합니다.
오늘은 '시스템프로그램'이라는 과목입니다.
(다른 학교에서는 어떻게 부르는지 잘 모르겠네요.)
필자가 이 과목을 수강했던 학기는 2020년(2학년) 1학기, 평점은 A+였습니다.
자료구조는 솔직히 전공이라고 봐주기에는 애교 수준이고
이 과목을 듣기 시작해야 '아 내가 컴퓨터공학과에 왔구나'하는 느낌이 좀 듭니다.
'시스템프로그램 - 컴퓨터구조 - 운영체제'로 이어지는 시스템 과목 중 가장 앞 과목입니다.
이 과목에서는 뒤의 두 과목을 듣기 위한 기본 지식을 배운다고 보시면 됩니다.
시스템이 도대체 뭐냐?고 물으신다면 마지막에 있는 '운영체제'를 떠올리시면 됩니다.
윈도우, 안드로이드, iOS 같은 운영체제 또한 소프트웨어이고,
흔히 우리가 앱이라고 부르는 어플리케이션 소프트웨어는 시스템 소프트웨어 위에서 동작하기 때문에
시스템에 대해 아는 것이 굉장히 중요하다고 볼 수 있습니다.
우리가 많이 쓰는 프로그램들도 시스템 단에서 최적화되어있는 부분이 많습니다.
시스템에 대해 잘 알아야 다른 소프트웨어도 잘 만들 수 있다는 것이죠.
-------------------------------------------
컴퓨터하면 뭐가 떠오르시나요? 아무래도 2진법 아닐까요?
컴퓨터는 모든 정보를 0과 1로만 저장합니다.
이 과목에서는 이런 비트에 관한 내용을 먼저 배웁니다.
비트에 관해서는 signed와 unsigned의 차이, 2의 보수,
& / | / ~ / ^ / << / >>와 같은 비트 관련 연산자, overflow 등 매우 많은 것을 배우지만,
여기서는 숫자를 어떻게 저장하는 지에 대해서 살펴보죠.
근데 우리가 주로 쓰는 체계는 10진법입니다.
근데 컴퓨터는 이러한 10진법 숫자를 어떻게 저장하고 계산할 수 있을까요?
또한 정수가 아닌 소수들은 어떻게 저장할까요?
정수는 다들 어떻게 바꾸는 지는 대충은 아시니까.. (2로 계속 나눠서..)
소수를 2진법으로 바꾸는 방법을 보면, 이것도 정수를 바꾸는 것과 크게 다르지 않습니다.
소수점에서 멀어질 수록 1/2배가 되도록 바꾸면 됩니다. (정수와 반대로 2를 계속 곱합니다.)
예를 들어 7/8은 1/2+1/4+1/8과 같으므로 2진법으로 쓰면 0.111이 되는거죠.
그럼 이렇게 2진법으로 바꾼 숫자를 어떻게 저장할까요?
C언어를 배우다 보면 float라는 자료형을 배우게 됩니다.
이건 소수점을 저장하기 위해 사용하는데요.. 근데 왜 이름이 float일까요?
그것은 바로 컴퓨터가 소수점을 저장하는 방식과 관련 있습니다.
바로 부동소수점(floating point)라는 방식을 사용하거든요.
영문을 보시면 아시겠지만 뜰 부(浮), 움직일 동(動)입니다.
떠다니면서 움직인다는 건데요, 과연 무엇이 떠다닌다는 뜻일까요?
바로 소수점이 움직인다는 것입니다. 소수점이 움직인다는 게 무슨 뜻인지 감이 안 오시죠?
부동소수점의 반대 개념인 고정소수점을 먼저 설명해야 이해가 쉬울 듯 합니다.
고정소수점(fixed point) 방식은 말 그대로 아까 바꾼 숫자를 그대로 저장하는 방식입니다.
6.875라는 소수를 저장한다고 예를 들어보죠.
6.875를 2진수로 바꾸면 110.111이 될 것입니다.
이렇게 바꾼 정수부와 소수부를 결과 그대로 110, 111로 저장하는 게 고정소수점 방식입니다.
이러한 방식은 제한적인 메모리 공간을 효율적으로 사용할 수가 없습니다.
만약에 정수부 소수부가 각각 4비트씩 있으면,
정수부는 0000(=0) ~ 1111(=15), 소수부는 0000(=0) ~ 1111(=15/16) 범위 내에서만 사용 가능하거든요.
그래서 이러한 문제를 해결하기 위해 부동소수점이라는 방식을 도입하게 됩니다.
이 방식은 숫자를 저장하기 전에 한 가지 연산을 더 해야해요.
아까 6.875를 다시 끌고 오죠.
얘는 2진수로 110.111인데 이는 11.0111에 2를 곱한 것과 같고,
1.10111에 4를 곱한 것과 같습니다. (10진수 10.1이 1.01의 10배인 것과 같습니다.)
6.875 = 110.111(2) = 1.10111(2) * 2^2 라는거죠. ((2)는 2진수라는 뜻)
이렇게 110과 111 사이에 찍혀있던 소수점을
1과 10111 사이로 옮겨버렸습니다. 이래서 우리는 이 방식을 부동소수점이라고 부릅니다.
이렇게 변형한 숫자를 어떻게 저장하냐면
1.10111이라는 앞에 곱해진 가수(fraction/mantissa)와
2에 붙어있는 지수(exponent)인 2를 저장합니다.
이런 지수를 이용하는 방식으로 저장하기 때문에
매우 큰 범위의 수를 적은 수의 비트로도 저장할 수 있는 거죠.
(로그라고 하기는 뭐한데 비슷하게 생각하시면 됩니다. 스케일을 줄이는 거죠.)
컴퓨터에 관심이 있으신 분들 중에 IEEE라는 곳을 들어보신 적이 있으실 겁니다.
IEEE는 Institute of Electrical and Electronics Engineers라는 조직으로
전자전기공학에 대한 표준을 제정하는 곳입니다.
우리가 많이 쓰는 Wi-Fi 있죠? 그것도 여기서 제정한 표준 규격입니다. IEEE 802.11이라고 부르죠.
부동소수점도 대부분의 컴퓨터가 이곳에서 제정한 방식(IEEE 754)으로 저장합니다.
단, 이 방식에는 단점도 분명 존재합니다.
가장 큰 문제는 아무래도 저장하고 싶은 숫자를 정확하게 저장할 수 없을 때도 있다는 겁니다.
가수부의 비트가 무한정하지는 않기 때문이죠.
또한, 고정소수점 방식에 비해 덧셈/뺄셈이 느릴 수 밖에 없습니다.
-------------------------------------------
반 학기 동안 이것 외에도 비트에 대한 많은 내용을 배우고 씨름하게 됩니다.
글이 너무 길어져서 여기서 끊고 계속 작성해보겠습니다.
제가 적은 글 (클릭하면 연결)
(현재 글) 3. 컴퓨터공학과 과목 맛보기 - 2. 시스템프로그래밍(1)
4. 컴퓨터공학과 과목 맛보기 - 2. 시스템프로그래밍(2)
0 XDK (+0)
유익한 글을 읽었다면 작성자에게 XDK를 선물하세요.
-
안녕하세요. 장시인입니다. 장시인 모의고사 0회 12번 문항 정답이 ⑤번으로 잘못...
-
안녕하세요. 장시인입니다. 드디어 장시인 모의고사 0회가 무료 배포됩니다. 공통 +...
-
제목이 곧 내용
-
뇌절 모의고사에서 그나마 쓸만한 문제들을 가져와 보았습니다 아래는 해설입니다! 7....
-
정시이런 거 하나도 모르는대 대성 들어가보니까 패키지로 팔던데 이거 사야하나요..?...
-
매일 아침 모고 푸는거 추천함?
-
참고로 14수능 (당시 사탐/과탐 중 2과목 선택)이었음 (오답률 62.4%)...
-
나락덕후 파이널 모의고사 등급컷 & 오답률 TOP 5 2
수능 전 배포했던 나락덕후 파이널 모의고사 (세계사 영역)의 등급컷과 오답률 TOP...
-
오늘 사설 마지막으로 세개중에 하나 푸려는데 뭐 풀까요? 이감 파이널1 1,2,3차중에요!
-
설맞이 3회 2
22 29 30 틀 다들 난이도 어땠나요? 1컷 아시는 분 있으면 댓글 남겨주심...
-
이해원 시즌3 1, 2회 샤인미 2, 3회 누가 남는대서 한 회차만 가져가려는데...
-
일부러 모래주머니 가득한 실모들만 풀고 있음 점수는 당연히 평소보다 낮은데 응...
-
더프 수학 2
더프 수학 10월보다 11월이 더 쉬웠나요?
-
11 20 22 30 틀.. 84점..88이 1컷이라 하시니..2등급이네요 9평때...
-
22 30 틀 흠 1회보다 쉬운듯.. 아 ㅈ밥 ㅋㅋ 이정도는 아니고 본인이 푼...
-
히카 시즌6 2
히카 시즌6 난이도 회차별로 어떻게되나요? 젤 어려운회차 좀 알려주세용
-
어느 정도 표본이 모여서 등급컷과 오답률을 공개하려 합니다. 근데 생각보다 표본이...
-
26요청) 세계사 파이널 모의고사 자체 홍보하러 왔읍니다 0
https://orbi.kr/00064948195/2024%ED%95%99%EB%85...
-
https://forms.gle/bnmokpmGm98WCxzr8 답안지에...
-
10월 중으로 올라갑니다 (현재 시험지 검토 중) 해설지도 만들었으니 많은 관심 부탁드립니다 __
-
..요즘 3회로 힐링하면서 88 92 맞아서 와 내가 이런 날도 오는 구나 햇는데...
-
지도 출처: https://youtu.be/evXdxx2HZDE 정답은...
-
정답은 아래에...
-
올해 모의고사 푼거는 킬캠1,2 히카4,5인데요. 히카6 풀어보신 분 어떤가요?...
-
6모 76 9모 84 10 76 수능 안정권 2등급이 목표인 학생입니다 마무리로...
-
(긴급, D-2) [Epsilon] 2024학년도 Epsilon 모의고사 2회 배포 공지 3
안녕하세요~ 성균관대학교 수학교육과 문제연구학회 엡실론(Epsilon)입니다! 저희...
-
참고로 이 두 문항은 전체 문항 중 평이한 편에 속해요 정답은...
-
민웅쌤 모고 시즌1브터 파이널2 (파2는 하는 중) 햇고 파2 1회 시간 딱 맞춰서...
-
미적분 나만 어렵나? ㅠㅠㅠ 도형은 강한데 연산이 약해서 그런지 난 너무 어려웠음...
-
[공지] 2024수능대비 정법정야 모의고사 오류 정정 안내 0
안녕하세요! 2024수능대비 정법정야 모의고사를 구매하셨던 분들께 진심으로...
-
N제 vs 실모 6
차영진 선생님 n제게임 입문이랑 라스트오브라스트 모의고사 중 하나만 고르면 뭐가...
-
11차 푸는데 ㄹㅇ 9모인줄; 반박시 내말맞
-
실모 추천좀 해주십샤요 킬캠 서바 하고있고 이로운 할건데 3개정도 추가할까 합니다...
-
수학이랑 사탐(생윤,사문) 1일 1실모 할려고 하는데 하시는 분 있음?...
-
킬캠,서바 풀거고 12회차정도 더 풀 수학실모 찾고있는데 일단...
-
저 2개 투표값이계속 똑같이 나오네 라스트 투표 한 번씩만요
-
킬캠시즌2 다풀어가고 강k하고있음 그다음 꿀모1,2,3 히카5,6는 무조건 풀거임...
-
알부케르크를 본 적이 없어서 제가 직접 만들었습니다 (사실 NS 모의고사 1회에...
-
3번 (오답률: 75%) 제후만 보고 봉건제로 착각하고 주나라를 찍기 좋은...
-
이감 파이널2 6-5회차 96점 킹아~ 원준이형 싸랑해요!!! 그나저나 100점...
-
https://orbi.kr/00064595459/%EC%84%B8%EA%B3%84%...
-
20번에 2번 선지가 수정되었습니다 ↓ 정답입력...
-
현재 김종익t 풀커리중 임정환 라트 하트 이지영 샤프 김종익 모고 어떤게 젤 나음?
-
익숙한 얼굴이....
-
24 강대k 국어 7,8,9회차 등급컷 아시는 분들 좀 알려주세요 등급컷 궁금한데ㅡ알 방법이 없네요
-
9모 대비 세계사에 이어 동아시아사 실모도 발표하겠습니다. 목차 1. 등급컷 2....
-
요즘은 텍스트가 많아져서 이런 문제는 안나올듯 정답은...
-
파이널2 6~10회차만 풀 거 같은데 1~5회차는 당근에 올리면 잘 팔릴까요..?
-
영어 실모 1
조정식쌤 TDYD 1.5는 할 생각인데 실모형식으로도 풀어보고 싶어서요! 영어 실모...
-
메인글 읽어봤는데 지금까지 과탐은 틀렸던문제 잘라서 따로 노트에 붙여놓고 수시로...
꾸준하시네요..
아.. 섰다
끼요옷
1.2 == 1.2
이 과목을 들으면 왜 이렇게 되는지 알 수 있습니다.
제발 갈등 메타 이딴 글 메인으로 올리지 말고
이런 칼럼 좀 메인으로 올립시다!!