디시인사이드 갤러리

갤러리 이슈박스, 최근방문 갤러리

갤러리 본문 영역

Ada의 신뢰성과 안전성앱에서 작성

나르시갤로그로 이동합니다. 2025.08.22 11:10:14
조회 110 추천 0 댓글 0

신뢰성과 안전성 (reliability and safety)

소프트웨어 시스템에서 신뢰성(reliability)은 명시된 기간 동안 의도된 기능을 오류 없이 수행하는 확률을 나타내며, 안전성(safety)은 오작동이 치명적인 사고로 이어지지 않도록 하는 시스템의 속성을 의미합니다. Ada는 이를 위해 언어 차원에서 컴파일 타임 안전성과 런타임 안전성을 지원합니다.

컴파일 타임 안전성은 프로그램 실행 전 소스 코드를 정적으로 분석하여 오류를 탐지 및 방지하는 개념입니다. Ada 컴파일러는 타입 불일치, 서브프로그램 호출 시의 매개변수 오류, 패키지의 비공개(private) 영역 접근 위반, 초기화되지 않은 변수의 사용 가능성 등 다양한 종류의 결함을 컴파일 단계에서 검출합니다.

이러한 정적 분석의 기반은 Ada의 강타입 시스템(strong type system)입니다. 이 시스템은 서로 다른 데이터 타입 간의 연산을 허용하지 않습니다. 예를 들어, Meters로 정의된 거리 타입과 Kilograms로 정의된 무게 타입 변수 간의 산술 연산은 컴파일 시점에 오류로 처리되어 데이터를 의미에 맞지 않게 잘못 사용하는 것을 방지합니다. 이러한 정적 검증은 개발 초기 단계에서 논리적 오류를 식별하여 소프트웨어의 견고성(robustness)과 신뢰성을 향상시킵니다.

정적 분석만으로 탐지하기 어려운 동적 오류에 대응하기 위해, Ada는 프로그램 실행 중 발생하는 예외적 상황을 처리하는 런타임 안전성 기능을 갖추고 있습니다. 언어 표준에 명시된 런타임 검사(runtime check)는 배열 인덱스 범위 초과, 정수 오버플로 또는 0으로 나누기와 같은 산술 오류, 데이터의 유효 범위 위반 등 메모리 및 데이터 무결성을 저해할 수 있는 동작을 감지합니다. 런타임 검사가 실패하면, 시스템은 미정의 상태(undefined state)가 되는 대신 제어된 방식으로 예외(exception)를 발생시킵니다. 개발자는 예외 처리 구문을 통해 이러한 상황에 체계적으로 대응할 수 있습니다.

또한, Ada는 선언적 명세를 통해 서브프로그램의 동작을 정의하는 계약 기반 프로그래밍(Programming by Contract)을 지원합니다. 개발자는 서브프로그램 실행 전에 만족해야 할 사전조건(precondition)과 실행 후에 보장해야 할 사후조건(postcondition)을 명시할 수 있습니다. 이러한 계약은 런타임에 검증되어 프로그램의 논리적 정확성을 보증합니다.

Ada의 안전성 모델은 테스트와 동적 검사를 넘어, 프로그램의 특정 속성을 수학적 논리로 증명하는 정형 검증(formal verification)으로 확장됩니다. 그 예시인 SPARK는 Ada의 검증 가능한 부분집합(verifiable subset)으로, 코드에 명시된 계약이 모든 실행 경로에서 만족된다는 것을 정적 분석 도구를 통해 증명할 수 있습니다.

---
아직 검토 중인 글입니다.

https://nimfsoft.art/ko/books/ada-programming/#13-ada%EC%9D%98-%EC%A3%BC%EC%9A%94-%ED%8A%B9%EC%A7%95

ㄹㅓ스트 빠돌이들의 헛소리에 속지 마십시오.
그리고 Ada도 메모리 세이프 언어입니다. 책 쓰다보니 알게된 사실인데 언어의 여러 특징 때문에 memory safe 특성이 나타나는 것이죠. 메모리 세이프만 딱 짚어서 설명하는게 이상하더라고요. 하지만 러스트는 메모리 세이프만 딱 짚어서 설명하는 이상한 태도를 취하는거죠. 그러한 서술 빛 홍보 방식으로 인하여 집단 환각 증상이 나타나나 봅니다. 타 언어들 자바, 루비, 파이선 등은 그런 식으로 서술 안 합니다. 또한 그런 식으로 홍보 안 해요. 러스트만 그짓거리하고 있는 겁니다. 왜? 입지가 불안하거든요 ㅎㅎ
저런 식으로 과장된 홍보를 해도 사람들이 러스트를 안 써요. 러스트 써 본 사람들은
1. 니도 함 엿먹어봐라는 심정으로 러스트를 설파하고
2. 또 다른 gc 없는 메모리 안전 언어는 없는가 알아보니다가 메모리 안전 뿐만 아니라 폭넓은 안전을 보장하는 Ada로 넘어오게 되죠.

추천 비추천

0

고정닉 0

0

댓글 영역

전체 댓글 0
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 현대물보다 사극에서 더 빛나는 남자 배우는? 운영자 25/09/08 - -
AD 신학기 레벨업~!! 운영자 25/09/05 - -
2887676 나님 외계인한테 호출 왓당.. ♥뽀송냥덩♥갤로그로 이동합니다. 09.08 36 0
2887675 [설계자 The Plot] 메인 예고편, [암수살인] 30초 예고편 발명도둑잡기(118.216) 09.08 35 0
2887674 [단독] 故김정주, 사후에 코인계좌 해킹당해… 85억어치 털렸다 발명도둑잡기(118.216) 09.08 49 0
2887670 컴공 4학년인데 언어 파이썬 몰빵하는 거 리스크 너무 큰가요? [9] ㅇㅇ(118.235) 09.08 146 0
2887667 짱구만봐도 일본여자 진실 알수있지않나 [1] ㅇㅇ(175.197) 09.08 55 0
2887663 이직하고 싶은데 언제쯤 나아지려나 ㅇㅇ(211.234) 09.08 43 0
2887662 펀쿨섹좌 차기 일본 총리 뭐노 [4] 아스카영원히사랑해갤로그로 이동합니다. 09.08 95 0
2887658 커널 드라이버 개발하는 게이 없냐 [2] 루도그담당(211.184) 09.08 57 0
2887657 아스카의 일일선행) [2] 아스카영원히사랑해갤로그로 이동합니다. 09.08 78 0
2887653 요즘 리눅스도 버그 존나 많음ㅋㅋ근데 리눅스뉴스에서는 소식이 아무도없음ㅋ 타이밍뒷.통수한방(1.213) 09.08 48 0
2887652 일 못쳐내는 동료 땜에 화딱지나네 [6] ㅇㅇ(211.234) 09.08 78 0
2887651 유닉스 환경(FreeBSD, 리눅스, 솔라리스) 30년 사용자가 말한다 [10] 나르시갤로그로 이동합니다. 09.08 76 0
2887649 개발자시상은 망하는데 판사연예인스포츠선수기상캐스터는 [1] 타이밍뒷.통수한방(1.213) 09.08 33 0
2887648 코딩 하나도 모르는 비전공자가 앱개발하려면 얼마나 걸림? [3] ㅇㅇ(114.202) 09.08 79 0
2887641 대도서관씨가 죽었다는게 믿어지지 않습니다 [2] 헬마스터갤로그로 이동합니다. 09.08 84 0
2887640 아 개발하기 귀찮다 [1] 프갤러(172.218) 09.08 60 0
2887639 어후 배아파 루도그담당(211.184) 09.08 39 0
2887638 개발용으로 리눅스 쓰는 사람들은 왜 쓰는거야? [16] 프갤러(14.52) 09.08 118 0
2887637 애플 이벤트 D - 2 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 09.08 41 0
2887636 태연 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 09.08 34 0
2887635 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 09.08 58 0
2887625 나르시님의 OOP에 대한 몰이해 비판 나르시갤로그로 이동합니다. 09.08 47 0
2887623 와 개발자 취업 시장 개망하니깐 여기도 싹 사라졌네 [2] 프갤러(221.153) 09.08 197 1
2887621 개좇센은 ai로 대체해야할 판사연예인기득권재벌새끼들은 뒷통수한방(1.213) 09.08 34 0
2887618 기득권들은 할줄아는게 뒷통수한방(1.213) 09.08 43 0
2887616 20세기 언어 Ada는 상속도 지원합니다. 나르시갤로그로 이동합니다. 09.08 38 0
2887615 러스트 상속 안된다고 상속이 쓰레기라능 ㅎㅎ [3] 나르시갤로그로 이동합니다. 09.08 72 0
2887610 [개꿀팁] 남자라면 꼭 알고 있어야 하는 유흥 팁 ㅇㅇ(118.235) 09.08 54 0
2887606 금융권 개발자가 안정적이란게 [1] 프갤러(180.70) 09.08 74 0
2887599 앱 만들어서 월수익 500찍는거 [5] zian갤로그로 이동합니다. 09.07 132 0
2887595 쿵쾅~ 예쁜여자가 싫은 사람? 류류(118.235) 09.07 54 1
2887592 기득권이 싫은 사람? [2] 류류(118.235) 09.07 61 1
2887588 왜 사람은 한두군데 역겨운 면모를 가지고 있을까 [2] 아스카영원히사랑해갤로그로 이동합니다. 09.07 59 0
2887580 TSP 문제 풀다 인생 백트레킹 할뻔 ㅋㅋ 프갤러(114.205) 09.07 44 0
2887549 우연히 유튜브 알고리즘에 떠서 봤는데 [5] 아스카영원히사랑해갤로그로 이동합니다. 09.07 104 0
2887547 나는 왜 같은 일 하는것보다 처음 해보는게 좋을까 [1] ㅆㅇㅆ(124.216) 09.07 59 0
2887536 파이참과 아나콘다의 차이점에 대해서 궁금합니다 [6] ㅇㅇ갤로그로 이동합니다. 09.07 63 0
2887529 인삼사탕보다 프갤러(125.240) 09.07 50 0
2887519 맥주한잔햇읍니다.. ㅎ [6] 개멍청한유라갤로그로 이동합니다. 09.07 73 0
2887517 아무것도 하기 싫을 땐 일단 움직이십시오. [2] 프갤러(110.8) 09.07 67 0
2887505 요즘 공부도 질림 [3] 루도그담당(58.239) 09.07 72 0
2887504 저 아래 글 봐서 호기심에 들어가서봤는데 [3] ㅆㅇㅆ(124.216) 09.07 76 0
2887475 나 의뢰 맡기고싶다 인강 추출 [8] ㅇㅇ(118.235) 09.07 108 0
2887468 약간 이런식으로 이해해라 프로그래머는 게을러 빠진 족속이라 ㅆㅇㅆ(124.216) 09.07 77 0
2887467 상속은 쓰레기입니다. 가능한 쓰지 마십시오. [1] 프갤러(110.8) 09.07 68 0
2887466 상속은 다형성을 위해서 존재함. 다형성의 구현이 상속임.. [4] ㅆㅇㅆ(124.216) 09.07 86 0
2887465 이게 다형성이라는 걸 알아야하는데 그 다형성을 배제하고 [1] ㅆㅇㅆ(124.216) 09.07 43 0
2887464 이게 살짝 미안하다..내가 설명을 너무 못하노.. [6] ㅆㅇㅆ(124.216) 09.07 71 0
2887462 니가 준 코드가 틀린건 아닌데 [1] 루도그담당(58.239) 09.07 64 0
2887461 와 근데 씨발 존나 쉽게 생각했는데 설명이라는 그자체가 어렵노 [3] ㅆㅇㅆ(124.216) 09.07 63 0
뉴스 '푹 쉬면 다행이야' 성훈, ‘해루질에 삼치 손질까지 척척’... 지치지 않는 무한 체력! 경이로움의 연속! 디시트렌드 09.09
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2