




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
Haskell中的類型與類型系統(tǒng)編程語(yǔ)言分類編程語(yǔ)言Domain
Specific
Language
(特定領(lǐng)域語(yǔ)言)General
Purpose
programming
language
(通用編程語(yǔ)言)
SQL,
HTML
命令式語(yǔ)言
C/C++,
Java,
Python,
C#
混合范式型語(yǔ)言Scala,
OCaml,
F#
函數(shù)型語(yǔ)言
Haskell,
Coq,
Agda,
Lisp,
Clojure,
ML什么是Haskell?一個(gè)強(qiáng)類型的、純的、惰性的函數(shù)式編程語(yǔ)言第一個(gè)編譯器的版本于1990年4月發(fā)布每年有相當(dāng)多的博士在改進(jìn)它,進(jìn)化速度非??靤ee
什么是Haskell?每個(gè)值都有嚴(yán)格的類型,不能任意轉(zhuǎn)型,也沒(méi)有隱式轉(zhuǎn)型。對(duì)于純函數(shù)只要輸入確定結(jié)果必然確定,與計(jì)算機(jī)當(dāng)前的狀態(tài)無(wú)關(guān)。Haskell可以嚴(yán)格求值,7.10前需要我們
手動(dòng)控制,但7.12中會(huì)有-XStrict擴(kuò)展演示用SMT
Solver解百雞問(wèn)題公雞每只5元,母雞每只3元,小雞3只1元,用100元錢買100只雞,求公雞、母雞、小雞各有多少只。函數(shù)反應(yīng)式編程模擬小球下落函數(shù)/運(yùn)算符(位置、結(jié)合性、
優(yōu)先級(jí))值
Haskell中的主要概念
Kind(多態(tài)kind、實(shí)體kind、data
kind)類型(多態(tài)類型、類型類限定類型、實(shí)體類型)類型類Haskell中的值‘1’,
True函數(shù)not
::
Bool
->
Boolid
::
a
->
ashow
::
Show
a
=>
a
->
String運(yùn)算符只是有優(yōu)先級(jí)的函數(shù),它們可以相互轉(zhuǎn)化(+)
1
2與1
+
2相同mod
19
7與19
`mod`
7相同Haskell中的類型基本類型:Int,
Integer,
Char,
type
String
=
[Char]基于基本類型的函數(shù)ord
::
Char
->
Intchr
::
Int
->
Char多態(tài)類型:[a],
Maybe
a,
(a,b)多態(tài)類型函數(shù):id
::
a
->
a,const
::
a
->
b
->
alength
::
[a]
->
Intsize
::
Tree
a
->
Intfst
::
(a,b)
->
a所以的值都有精確的類型,
‘1’
::
Char,
True
::
Bool
代數(shù)類型枚舉類型data
Bool
=
False
|
True
deriving
(Eq,
Show,
Ord,
Enum,
Bounded,
Read)參數(shù)化類型類似于Java中的泛型data
Maybe
a
=
Nothing
|
Just
a
deriving
(Eq,
Show,
Ord,
Read)
--
解決了Tony
Hoare的十億美元的null問(wèn)題!遞歸類型data
Nat
=
Zero
|
Succ
Nat
deriving
(Eq,
Show,
Ord,
Read)構(gòu)造類型data
Pair
a
b
=
Pair
a
b--
類型構(gòu)造器與數(shù)據(jù)構(gòu)造器名字一樣data
Person
=
Person
{name
::
String,
age::
Int}data
List
a
=
Nil
|
Cons
a
(List
a)--
data
[]
a
=
[]
|
a
:
[a]deriving
(Eq,
Show,
Ord,
Read)基于這些類型的函數(shù)每個(gè)模式實(shí)際上是匹配的構(gòu)造器與參數(shù)。not
::
Bool
->
Boolnot
False
=
Truenot
True
=
FalsefromJust
::
Maybe
a
->
afromJust
(Just
x)
=
xfromJust
Nothing
=
error
“cannot
get
value
from
nothing”error的類型是什么?
基于這些類型的函數(shù)每個(gè)模式實(shí)際上是匹配的構(gòu)造器與參數(shù)。not
::
Bool
->
Boolnot
False
=
Truenot
True
=
FalsefromJust
::
Maybe
a
->
afromJust
(Just
x)
=
xfromJust
Nothing
=
error
“cannot
get
value
from
nothing”error的類型是什么?error
::
String
->
a基于這些類型的函數(shù)add
::
Nat
->
Nat
->
Natadd
Zero
n
=
nadd
(Succ
n)
m
=
add
n
(Succ
m)foo
::
Person
->
Stringfoo
(Person
n
s)
=
n
++
if
s
>
18then
“
is
an
adult”else
“
is
a
child”sum
::
[Int]
->
Intsum
[]
=
0sum
(x:xs)
=
x
+
sum
xs
類型類相當(dāng)于多種類型的公共屬性
(==)
::
Eq
a
=>
a
->
a
->
Bool類型類間的有依賴關(guān)系
class
Eq
a
=>
Ord
a
(>=),(>),(<=),(<)
::
Ord
a
=>
a
->
a
->
Boolshow
::
Show
a
=>
a
->
String函數(shù)的重載(+)
::
Num
a
=>
a
->
a
->
a
Int,
Integer,
Double,
Float都可相加Show,
Eq,
Ord,
Enum,
Read,
Bounded定義類型類class
Eq
a
where(==)
::
a
->
a
->
Bool(/=)
::
a
->
a
->
Bool(==)
x
y
=
not
(x
/=
y)(/=)
x
y
=
not
(x
==
y){-#
MINIMAL
(==)
|
(/=)
#-}class
Show
a
where
show
::
a
->
Stringdata
Person
=
Person
Name
Intinstance
Eq
Person
where(Person
n1
i1)
==
(Person
n2
i2)
=
n1
==
n2
&&
i1
==
i2instance
Show
Person
whereshow
(Person
name
age)
=
name
++
show
ageFunctor函子類型類中的fmap函數(shù)data
List
a
=
Nil
|
Cons
a
(List
a)class
List<T>{T
e
=
null;List<T>
list
=
null;}data
Tree
a
=
Leaf
|
Node
a
(Tree
a)
(Tree
a)list
::
List
Intlist
=
Cons
10
(Cons
11
(Cons
6
(Cons
1
Nil)))tree
::
Tree
Inttree
=
Node
10
(Node
11
Leaf
Leaf)
(Node
6
(Node
1
Leaf
Leaf)Leaf)Functor函子類型類中的fmap函數(shù)class
Functor
f
wherefmap
::
(a
->
b)
->
f
a
->
f
binstance
Functor
List
wherefmap
f
Nil
=
Nilfmap
f
(Cons
a
l)
=
Cons
(f
a)
(fmap
f
l)instance
Functor
Tree
wherefmap
f
Leaf
=
Leaffmap
f
(Node
v
l
r)
=
Node
(f
v)
(fmap
f
l)
(fmapf
r)可以使用DeriveFunctor編譯器擴(kuò)展自動(dòng)生成數(shù)學(xué)對(duì)于Functor的指導(dǎo)意義F(g)
?
F(f)
=
F(g
?
f)fmap
g
.
fmap
f
=
fmap
(g.f)fmap
g
(fmap
f
v)
=
fmap
(g.f)
v{-#
RULE
“fmap”forall
g
f
v
fmap
g
(fmap
f
v)
=
fmap
(g.f)
v
#-}fmap
(+10)
(fmap
(*2)
[1..10])
=
fmap
((+10).(*2))
[1..10]int[]
arrfor(int
i
=
0
;
i
<
arr.length;
i++){arr[i]
=
arr[i]
*
2;}for(int
i
=
0
;
i
<
arr.length;
i++){arr[i]
=
arr[i]
+
10;}類型類與Java的接口的不同1、接口在Haskell相當(dāng)于是一個(gè)字典,函數(shù)調(diào)用會(huì)根據(jù)不同的類型來(lái)傳遞。多幾個(gè)類型類限定相當(dāng)于是多傳入了幾個(gè)字典。Java中要把接口合并起來(lái)有些啰嗦。2、由于Haskell的類型是代數(shù)數(shù)據(jù)類型,即全部可以用單位元、類型加法、類型乘法、類型復(fù)合來(lái)定義,所以類型類實(shí)例可以自動(dòng)實(shí)現(xiàn)能力極強(qiáng),而且方法特別多——通用編程、摒棄模板化編程、元編程。3、還有很多其他不同。演示:處理JSON數(shù)據(jù)的aeson庫(kù)、漂亮打印的generic-pretty庫(kù),類型的序列化。interface
Show<T>{
String
show
(T
a);}interface
Eq<T>{
boolean
eq(T
a);}interface
ShowEq<T>
extends
Eq<T>,
Show<T>{}class
Person
implements
Eq<Person>,
Show<Person>{
String
name
;
int
age;
Person(String
name,
int
age){
=
name;
this.age
=
age;}
public
boolean
eq(Person
a)
{
return
.equals()
&&
this.age
==
a.age;}
public
String
show()
{return
+
“
”
+
this.age;}}foo
::
(Show
a,
Eq
a)
=>
a
->
a
->
(Bool,
String)類型系統(tǒng)與Java的不同1、Java中沒(méi)有“高階泛型”
高階Kindclass
Mk<T,K>{T<K>
m
;
}new
Mk<Vector,
Integer>()new
Mk<ArrayList,
Node>()2、沒(méi)有“多態(tài)泛型”
Kind多態(tài)
類型的Kind類型的類型為kind,類型把值分類,class給類型賦予了屬性,kind把類型分類。*代表一個(gè)實(shí)體的kind如:3
::
Int
,
Int
::
*Just
3
::
Maybe
Int,Maybe
::
*
->
*,
Maybe
Int
::
*
--
只有kind為*的類型下面才有值
--
沒(méi)有一個(gè)值的類型是Maybe,只有Maybe
Int或Maybe
Char等Either
::
*
->
*
->
*
--
同理也沒(méi)有一個(gè)值的類型是Either(,)
::
*
->
*
->
*--
元組類型的構(gòu)造器--
RNodea
([]
(RoseTree
a))>:kind
[]*
->
*data
BinTree
a
=
BLeaf
a
|
BNode
a
(Pair
(BinTree
a))--
(a,a)data
Pair
a
=
MkPair
a
a>:kind
Pair*
->
*
高階Kinddata
RoseTree
a
=
RLeaf
a
|
RNode
a
[RoseTree
a]高階Kinddata
Tree
k
a
=
Leaf
a
|
Node
a
(k
(Tree
k
a))type
RoseTree
a
=
Tree
[]
atype
BinTree
a
=
Tree
Pair
atype
AnnTree
a
=
Tree
AnnPair
adata
Pair
a
=
MkPair
a
adata
AnnPair
a
=
AnnPair
String
a
a>:kind
Tree(*
->
*)
->
*
->
*Kind多態(tài)Typeableclass
Typeable
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年度高校畢業(yè)生就業(yè)見(jiàn)習(xí)基地協(xié)議
- 二零二五年度帶小孩保姆與兒童健康監(jiān)測(cè)協(xié)議
- 二零二五年度廠房租賃安全與環(huán)保技術(shù)合作協(xié)議
- 二零二五年度退股股權(quán)變更與收益分配協(xié)議
- 2025年山東駕??荚囏涍\(yùn)從業(yè)資格證考試題庫(kù)
- 水電安裝工程簡(jiǎn)單版的合同
- 2024年簡(jiǎn)單房屋租賃協(xié)議
- 競(jìng)選班主任發(fā)言稿
- 2024年浙江省建筑安全員B證考試題庫(kù)及答案
- 建筑隔墻用輕質(zhì)條板施工合同
- 醫(yī)院培訓(xùn)課件:《多發(fā)性骨髓瘤》
- 【新】部編人教版小學(xué)4四年級(jí)《道德與法治》下冊(cè)全冊(cè)教案
- 2025年湖南省長(zhǎng)沙市單招職業(yè)傾向性測(cè)試題庫(kù)及參考答案
- 《產(chǎn)業(yè)轉(zhuǎn)移》課件:機(jī)遇與挑戰(zhàn)
- 十八項(xiàng)核心制度培訓(xùn)課件
- 2024年遠(yuǎn)程教育行業(yè)市場(chǎng)運(yùn)營(yíng)現(xiàn)狀及行業(yè)發(fā)展趨勢(shì)報(bào)告
- 2025年2月上海市高三聯(lián)考高考調(diào)研英語(yǔ)試題(答案詳解)
- 三好學(xué)生競(jìng)選12
- 2024-2025學(xué)年六年級(jí)上學(xué)期數(shù)學(xué)第三單元3.1-搭積木比賽(教案)
- DeepSeek從入門到精通
- 植保機(jī)械技術(shù)培訓(xùn)課件
評(píng)論
0/150
提交評(píng)論