Haskell-유형 및 유형 클래스

Haskell은 기능적 언어이며 엄격하게 형식화되어 있으므로 전체 응용 프로그램에서 사용되는 데이터 형식이 컴파일 타임에 컴파일러에 알려집니다.

내장형 클래스

Haskell에서 모든 문장은 수학적 표현으로 간주되며이 표현의 범주는 Type. "Type"은 컴파일 타임에 사용 된 표현식의 데이터 유형이라고 말할 수 있습니다.

에 대해 자세히 알아 보려면 Type, ": t"명령을 사용합니다. 일반적인 방법으로Type 값으로 간주 할 수 있지만 Type Class유사한 유형의 집합으로 간주 될 수 있습니다. 이 장에서는 다양한 내장 유형에 대해 알아 봅니다.

Int

IntInteger 유형 데이터를 나타내는 유형 클래스입니다. 2147483647에서 -2147483647 사이의 모든 정수는Int유형 클래스. 다음 예에서 함수fType() 정의 된 유형에 따라 작동합니다.

fType :: Int -> Int -> Int 
fType x y = x*x + y*y
main = print (fType 2 4)

여기에서 함수의 유형을 설정했습니다. fType() 같이 int. 이 함수는 두 가지가 필요합니다.int 값과 하나를 반환 int값. 이 코드를 컴파일하고 실행하면 다음 출력이 생성됩니다.

sh-4.3$ ghc -O2 --make *.hs -o main -threaded -rtsopts 
sh-4.3$ main
20

정수

Integer 다음의 상위 집합으로 간주 될 수 있습니다. Int. 이 값은 숫자로 제한되지 않으므로 Integer는 제한없이 모든 길이가 될 수 있습니다. 기본적인 차이점을 보려면IntInteger 위의 코드를 다음과 같이 수정하겠습니다.

fType :: Int -> Int -> Int 
fType x y = x*x + y*y 
main = print (fType 212124454 44545454454554545445454544545)

위의 코드를 컴파일하면 다음과 같은 오류 메시지가 나타납니다.

main.hs:3:31: Warning:            
   Literal 44545454454554545445454544545 is out of the Int range -
   9223372036854775808..9223372036854775807 
Linking main ...

이 오류는 함수 fType ()이 하나의 Int 유형 값을 예상하고 실제 큰 Int 유형 값을 전달하기 때문에 발생했습니다. 이 오류를 방지하기 위해 "Integer"를 사용하여 "Int"유형을 수정하고 차이점을 살펴 보겠습니다.

fType :: Integer -> Integer -> Integer 
fType x y = x*x + y*y 
main = print (fType 212124454 4454545445455454545445445454544545)

이제 다음과 같은 출력이 생성됩니다.

sh-4.3$ main
1984297512562793395882644631364297686099210302577374055141

흙손

다음 코드를 살펴보십시오. 그것은 Haskell에서 Float 유형이 어떻게 작동하는지 보여줍니다-

fType :: Float -> Float -> Float 
fType x y = x*x + y*y 
main = print (fType 2.5 3.8)

이 함수는 두 개의 float 값을 입력으로 사용하고 다른 float 값을 출력으로 생성합니다. 이 코드를 컴파일하고 실행하면 다음과 같은 출력이 생성됩니다.

sh-4.3$ main
20.689999

더블

Double끝에 배정 밀도가있는 부동 소수점 숫자입니다. 다음 예를 살펴보십시오-

fType :: Double -> Double -> Double 
fType x y = x*x + y*y 
main = print (fType 2.56 3.81)

위의 코드를 실행하면 다음과 같은 출력이 생성됩니다.

sh-4.3$ main 
21.0697

부울

Bool부울 유형입니다. True 또는 False 일 수 있습니다. 다음 코드를 실행하여 하스켈에서 Bool 유형이 작동하는 방식을 이해합니다.

main = do  
   let x = True 
   
   if x == False 
      then putStrLn "X matches with Bool Type" 
   else putStrLn "X is not a Bool Type"

여기서는 변수 "x"를 부울로 정의하고 다른 부울 값과 비교하여 독창성을 확인합니다. 다음과 같은 출력이 생성됩니다.

sh-4.3$ main
X is not a Bool Type

Char는 문자를 나타냅니다. 작은 따옴표 안의 모든 것은 문자로 간주됩니다. 다음 코드에서 이전fType() Char 값을 받아들이고 Char 값을 출력으로 반환하는 함수.

fType :: Char-> Char 
fType x = 'K' 
main = do  
   let x = 'v' 
   print (fType x)

위의 코드는 다음을 호출합니다. fType() 기능 char'v'의 값이지만 다른 char 값, 즉 'K'를 반환합니다. 출력은 다음과 같습니다.

sh-4.3$ main 
'K'

Haskell은 선언되기 전에 유형을 잡을 수있을만큼 지능적이므로 이러한 유형을 명시 적으로 사용하지 않을 것입니다. 이 튜토리얼의 다음 장에서는 다양한 유형과 유형 클래스가 Haskell을 강력한 유형의 언어로 만드는 방법을 살펴볼 것입니다.

EQ 유형 클래스

EQ유형 클래스는 표현식의 동등성을 테스트하는 기능을 제공하는 인터페이스입니다. 표현식의 동등성을 확인하려는 모든 유형 클래스는이 EQ 유형 클래스의 일부 여야합니다.

위에서 언급 한 모든 표준 유형 클래스는 이것의 일부입니다. EQ수업. 위에서 언급 한 유형 중 하나를 사용하여 평등을 확인할 때마다 실제로 다음을 호출합니다.EQ 유형 클래스.

다음 예에서 우리는 EQ "=="또는 "/ ="작업을 사용하여 내부적으로 입력합니다.

main = do 
   if 8 /= 8 
      then putStrLn "The values are Equal" 
   else putStrLn "The values are not Equal"

다음과 같은 출력이 생성됩니다.

sh-4.3$ main 
The values are not Equal

Ord 유형 클래스

Ord주문 기능을 제공하는 또 다른 인터페이스 클래스입니다. 모든types 우리가 지금까지 사용한 것은 이것의 일부입니다 Ord상호 작용. EQ 인터페이스와 마찬가지로 Ord 인터페이스는 ">", "<", "<=", "> =", "compare"를 사용하여 호출 할 수 있습니다.

이 유형 클래스의 "비교"기능을 사용한 아래 예를 찾으십시오.

main = print (4 <= 2)

여기서 Haskell 컴파일러는 4가 2보다 작거나 같은지 확인합니다. 그렇지 않기 때문에 코드는 다음 출력을 생성합니다.

sh-4.3$ main 
False

보여 주다

Show인수를 문자열로 인쇄하는 기능이 있습니다. 인수가 무엇이든 항상 결과를 문자열로 인쇄합니다. 다음 예에서는이 인터페이스를 사용하여 전체 목록을 인쇄합니다. "show"를 사용하여이 인터페이스를 호출 할 수 있습니다.

main = print (show [1..10])

콘솔에 다음 출력이 생성됩니다. 여기서 큰 따옴표는 문자열 유형 값임을 나타냅니다.

sh-4.3$ main 
"[1,2,3,4,5,6,7,8,9,10]"

읽다

Readinterface는 Show와 동일한 작업을 수행하지만 결과를 String 형식으로 인쇄하지 않습니다. 다음 코드에서 우리는read 인터페이스를 통해 문자열 값을 읽고 동일한 값을 Int 값으로 변환합니다.

main = print (readInt "12") 
readInt :: String -> Int 
readInt = read

여기에서 문자열 변수 ( "12")를 readInt변환 후 차례로 12 (Int 값)를 반환하는 메서드입니다. 출력은 다음과 같습니다.

sh-4.3$ main 
12

열거 형

EnumHaskell에서 순차적 또는 정렬 된 기능을 가능하게하는 또 다른 유형의 Type 클래스입니다. 이 유형 클래스는 다음과 같은 명령으로 액세스 할 수 있습니다.Succ, Pred, Bool, Char

다음 코드는 12의 후속 값을 찾는 방법을 보여줍니다.

main = print (succ 12)

다음과 같은 출력이 생성됩니다.

sh-4.3$ main
13

경계

상한과 하한이있는 모든 유형은이 유형 클래스에 속합니다. 예를 들면Int 유형 데이터의 최대 경계는 "9223372036854775807"이고 최소 경계는 "-9223372036854775808"입니다.

다음 코드는 Haskell이 Int 유형의 최대 및 최소 경계를 결정하는 방법을 보여줍니다.

main = do 
   print (maxBound :: Int) 
   print (minBound :: Int)

다음과 같은 출력이 생성됩니다.

sh-4.3$ main
9223372036854775807
-9223372036854775808

이제 Char, Float 및 Bool 유형의 최대 및 최소 경계를 찾으십시오.

Num

이 유형 클래스는 숫자 연산에 사용됩니다. Int, Integer, Float 및 Double과 같은 유형은이 유형 클래스에 속합니다. 다음 코드를 살펴보십시오-

main = do 
   print(2 :: Int)  
   print(2 :: Float)

다음과 같은 출력이 생성됩니다.

sh-4.3$ main
2
2.0

완전한

IntegralNum Type Class의 하위 클래스로 간주 될 수 있습니다. Num Type 클래스는 모든 유형의 숫자를 보유하는 반면 Integral 유형 클래스는 정수에만 사용됩니다. Int 및 Integer는이 Type 클래스 아래의 유형입니다.

떠 있는

Integral과 마찬가지로 Floating도 Num Type 클래스의 일부이지만 부동 소수점 숫자 만 보유합니다. 그 후,FloatDouble 이 유형 클래스에 속합니다.

커스텀 타입 클래스

다른 프로그래밍 언어와 마찬가지로 Haskell을 사용하면 개발자가 사용자 정의 유형을 정의 할 수 있습니다. 다음 예에서는 사용자 정의 유형을 만들어 사용합니다.

data Area = Circle Float Float Float  
surface :: Area -> Float   
surface (Circle _ _ r) = pi * r ^ 2   
main = print (surface $ Circle 10 20 10 )

여기에서 우리는 Area. 다음으로이 유형을 사용하여 원의 면적을 계산합니다. 위의 예에서 "surface"는Area 입력으로 생성하고 Float 출력으로.

여기서 "데이터"는 키워드이며 Haskell의 모든 사용자 정의 유형은 항상 대문자로 시작합니다.

다음과 같은 출력이 생성됩니다.

sh-4.3$ main
314.15927