GHCi Prelude学习
参考:http://www.cse.unsw.edu.au/~en1000/haskell/inbuilt.html
http://www.cse.unsw.edu.au/~en1000/haskell/hof.html
在GHCi中,可以使用:type来查看对象的类型,与http://www.cnblogs.com/long123king/p/3837686.html中说到的一样,
Haskell中,函数也是一种特殊的对象,对象就有类型,函数作为一种对象,可以作为参数传递,也可以赋值,创建和销毁。
- Prelude> :type (+)
- (+) :: Num a => a -> a -> a
这个类似要怎么解释呢,"::"的前面是函数的名称,后面是函数对象的类型,或者说原型。
"=>"前面的Num a是表明参数的类型,
- Prelude> :type 1
- 1 :: Num a => a
后面是函数的输入与输出类型声明。
之所以会有多个->,那是因为(+)函数对象中其实包含一个更加简单的函数,比如(+) 2,这个函数的意思是“在使用(+)函数对象时,将第一个参数固定为2,这与boost中的bind类似”,而这个函数对象的类型是Num a => a->a,
再把另外一个参数传递给这个简单的函数,得到的结果也是a类型,因此(+)是一个复合函数。
凡是需要多个参数的函数对象,都可以分解成一步一步的简单函数组成的复合函数。
- Prelude> (+) 2
- <interactive>:35:1:
- No instance for (Num a0) arising from a use of `+'
- The type variable `a0' is ambiguous
- Possible fix: add a type signature that fixes these type variable(s)
- Note: there are several potential instances:
- instance Num Double -- Defined in `GHC.Float'
- instance Num Float -- Defined in `GHC.Float'
- instance Integral a => Num (GHC.Real.Ratio a)
- -- Defined in `GHC.Real'
- ...plus three others
- In the expression: (+) 2
- In an equation for `it': it = (+) 2
- <interactive>:35:1:
- No instance for (Show (a0 -> a0)) arising from a use of `print'
- Possible fix: add an instance declaration for (Show (a0 -> a0))
- In a stmt of an interactive GHCi command: print it
- Prelude> :type (+) 2
- (+) 2 :: Num a => a -> a
特殊符号需要显式地用括号来表明这是个函数对象,
对于普通的函数对象,也可以使用括号来表明其函数对象的身份。
- Prelude> :type +
- <interactive>:1:1: parse error on input `+'
- Prelude> :type (+)
- (+) :: Num a => a -> a -> a
- Prelude> :type names
- names :: [Char]
- Prelude> :type head
- head :: [a] -> a
- Prelude> :type (head)
- (head) :: [a] -> a
再来看一个更加复杂的函数对象
- Prelude> :type map
- map :: (a -> b) -> [a] -> [b]
这个函数对象包含了两个简单函数对象, (a -> b)是一个函数,可以将类型a的对象转换成类型b的对象;
(a -> b) -> [a],是另外一个函数,它的意思是“在执行整体函数对象时,将第一个参数固定为[a]”。
这种将复合函数对象(包含了多个参数的函数对象)分解成几个简单函数对象的思想,是为了支持“函数作为一种对象”的这种设计理念,
这样就可以将上面分解出的简单的函数作为参数,传递给复合函数对象。
比如
- Prelude> let nums = [1..100]
- Prelude> map ((*) 2) nums
- [2,4,6,8,10,12,14,16,18,20,22,24,26,28,30,32,34,36,38,40,42,44,46,48,50,52,54,56,58,60,62,64,66,68,70,72,74,76,78,80,82,84,86,88,90,92,94,96,98,100,102,104,106,108,110,112,114,116,118,120,122,124,126,128,130,132,134,136,138,140,142,144,146,148,150,152,154,156,158,160,162,164,166,168,170,172,174,176,178,180,182,184,186,188,190,192,194,196,198,200]
虽然,像(+) 2这样的函数对象在多数时候,看起来并不是一个常见的用法。
怎样在Prelude中得到当前运行环境的信息
- Prelude> :help
- Commands available from the prompt:
- <statement> evaluate/run <statement>
- : repeat last command
- :{\n ..lines.. \n:}\n multiline command
- :add [*]<module> ... add module(s) to the current target set
- :browse[!] [[*]<mod>] display the names defined by module <mod>
- (!: more details; *: all top-level names)
- :cd <dir> change directory to <dir>
- :cmd <expr> run the commands returned by <expr>::IO String
- :ctags[!] [<file>] create tags file for Vi (default: "tags")
- (!: use regex instead of line number)
- :def <cmd> <expr> define command :<cmd> (later defined command has
- precedence, ::<cmd> is always a builtin command)
- :edit <file> edit file
- :edit edit last module
- :etags [<file>] create tags file for Emacs (default: "TAGS")
- :help, :? display this list of commands
- :info [<name> ...] display information about the given names
- :issafe [<mod>] display safe haskell information of module <mod>
- :kind <type> show the kind of <type>
- :load [*]<module> ... load module(s) and their dependents
- :main [<arguments> ...] run the main function with the given arguments
- :module [+/-] [*]<mod> ... set the context for expression evaluation
- :quit exit GHCi
- :reload reload the current module set
- :run function [<arguments> ...] run the function with the given arguments
- :script <filename> run the script <filename>
- :type <expr> show the type of <expr>
- :undef <cmd> undefine user-defined command :<cmd>
- :!<command> run the shell command <command>
- -- Commands for debugging:
- :abandon at a breakpoint, abandon current computation
- :back go back in the history (after :trace)
- :break [<mod>] <l> [<col>] set a breakpoint at the specified location
- :break <name> set a breakpoint on the specified function
- :continue resume after a breakpoint
- :delete <number> delete the specified breakpoint
- :delete * delete all breakpoints
- :force <expr> print <expr>, forcing unevaluated parts
- :forward go forward in the history (after :back)
- :history [<n>] after :trace, show the execution history
- :list show the source code around current breakpoint
- :list identifier show the source code for <identifier>
- :list [<module>] <line> show the source code around line number <line>
- :print [<name> ...] prints a value without forcing its computation
- :sprint [<name> ...] simplifed version of :print
- :step single-step after stopping at a breakpoint
- :step <expr> single-step into <expr>
- :steplocal single-step within the current top-level binding
- :stepmodule single-step restricted to the current module
- :trace trace after stopping at a breakpoint
- :trace <expr> evaluate <expr> with tracing on (see :history)
- -- Commands for changing settings:
- :set <option> ... set options
- :seti <option> ... set options for interactive evaluation only
- :set args <arg> ... set the arguments returned by System.getArgs
- :set prog <progname> set the value returned by System.getProgName
- :set prompt <prompt> set the prompt used in GHCi
- :set editor <cmd> set the command used for :edit
- :set stop [<n>] <cmd> set the command to run when a breakpoint is hit
- :unset <option> ... unset options
- Options for ':set' and ':unset':
- +m allow multiline commands
- +r revert top-level expressions after each evaluation
- +s print timing/memory stats after each evaluation
- +t print type after evaluation
- -<flags> most GHC command line flags can also be set here
- (eg. -v2, -fglasgow-exts, etc.)
- for GHCi-specific flags, see User's Guide,
- Flag reference, Interactive-mode options
- -- Commands for displaying information:
- :show bindings show the current bindings made at the prompt
- :show breaks show the active breakpoints
- :show context show the breakpoint context
- :show imports show the current imports
- :show modules show the currently loaded modules
- :show packages show the currently active package flags
- :show language show the currently active language flags
- :show <setting> show value of <setting>, which is one of
- [args, prog, prompt, editor, stop]
- :showi language show language flags for interactive evaluation
- Prelude> :show modules
- Prelude> :show context
- Prelude> :show bindings
- names :: [Char] = "Daniel King"
- nums :: [Integer] = 1 : 2 : 3 : 4 : 5 : ....
- it :: [Integer] = 2 : 4 : 6 : 8 : 10 : ....
- Prelude> :show imports
- import Prelude -- implicit
- Prelude> :show packages
- active package flags: none
- Prelude> :show languages
- base language is: Haskell2010
- with the following modifiers:
- -XNoDatatypeContexts
- -XNondecreasingIndentation
- Prelude> foldl ((+)) 0 [1..100]
- 5050
- Prelude> :type map
- map :: (a -> b) -> [a] -> [b]
- Prelude> :type filter
- filter :: (a -> Bool) -> [a] -> [a]
- Prelude> :type foldr
- foldr :: (a -> b -> b) -> b -> [a] -> b
- Prelude> :type foldl
- foldl :: (a -> b -> a) -> a -> [b] -> a
- Prelude> filter ((>) 50) nums
- [1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49]
- Prelude> :type foldr
- foldr :: (a -> b -> b) -> b -> [a] -> b
- Prelude> foldr (:) "King" ['D','a','n','i','e','l', ' ']
- "Daniel King"
但是用foldl就不行。
使用子模块功能
- Prelude> map Data.Char.isDigit ((++) ['0'..'9'] ['a'..'z'])
- [True,True,True,True,True,True,True,True,True,True,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False]
- Prelude> map Data.Char.isDigit (concat [['0'..'9'],['a'..'z']])
- [True,True,True,True,True,True,True,True,True,True,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False,False]
另外,(++) 与concat的功能不相同,它们的原型也不相同,因此在使用一个函数之前,一定要明确这个函数的原型。
GHCi Prelude学习的更多相关文章
- 「Haskell 学习」二 类型和函数(上)
随着学习的深入,笔记会补充和修订.当然,这个补充修订也许会鸽,但我一定会坚持写完. 这个笔记假定你至少学过C/C++及Python,或与这两种语言类型相同的语言. 类型系统概述 “Haskell’s ...
- Haskell语言学习笔记(47)Arrow(2)
Function, Monad, Arrow f :: Int -> (Int, Int) f = \x -> let y = 2 * x z1 = y + 3 z2 = y - 5 in ...
- JTSL/EL Expression学习
最早的一个学习笔记,时间过去了久了,供java web初学者参考. JTSL/EL Expression学习安排 学习目标:掌握几个常见标签的使用,通晓工作原理,详细到代码层面,遇到问题时能查得出异常 ...
- Haskell ghci中调用pandoc的API进行markdown转换
所用环境:Windows Server 2008 + ghc 7.6.3(Haskell Platform 2013.2.0.0自带的) + pandoc 1.12.4 操作步骤: 1. 安装Hask ...
- 「Haskell 学习」一 环境与大致了解
感谢<Real World Haskell>在网上的免费发布,可以白嫖学Haskell这个久闻大名的函数式编程语言了. 本文运行于openSUSE Tumbleweed下,运行相关命令时留 ...
- Emacs 学习之旅
**Emacs 的使用过程,就像是程序员的生涯一样--路漫漫其修远兮,吾将上下而求索.** ## 万物始于 Emacs 最早知道 _Emacs_ 是从编辑器的圣战开始的,即编辑器之神--Vi,和神的编 ...
- 从直播编程到直播教育:LiveEdu.tv开启多元化的在线学习直播时代
2015年9月,一个叫Livecoding.tv的网站在互联网上引起了编程界的注意.缘于Pingwest品玩的一位编辑在上网时无意中发现了这个网站,并写了一篇文章<一个比直播睡觉更奇怪的网站:直 ...
- Angular2学习笔记(1)
Angular2学习笔记(1) 1. 写在前面 之前基于Electron写过一个Markdown编辑器.就其功能而言,主要功能已经实现,一些小的不影响使用的功能由于时间关系还没有完成:但就代码而言,之 ...
- ABP入门系列(1)——学习Abp框架之实操演练
作为.Net工地搬砖长工一名,一直致力于挖坑(Bug)填坑(Debug),但技术却不见长进.也曾热情于新技术的学习,憧憬过成为技术大拿.从前端到后端,从bootstrap到javascript,从py ...
随机推荐
- MFC---导出 Excel 方法
本方法通过Excel驱动写入 请添加头文件 #include"afxdb.h" 第一步创建Excel文件 安装驱动 CString FileName = L"first. ...
- [BZOJ3932][CQOI2015]任务查询系统(差分+主席树)
题面 分析 对于一个区间修改(s,e,v),我们可以将它差分,这样就变成了单点修改s和e+1(s插入,t+1删除) 我们用主席树维护差分数组的前缀和,第i棵主席树维护区间[1,i]之间的所有差分值 那 ...
- #python# error:urllib.error.URLError: <urlopen error [Errno 11001] getaddrinfo failed>
设置代理后访问网页报错,百度有人说地址拼写不对,确认拼写后依然报错 因为使用的是xici免费代理,想到可能代理不可用造成getaddrinfo failed, 更换其他代理,error消失
- vue-cli3脚手架的安装
如果之前有安装过其他的版本的话,要先卸载 卸载:npm uninstall vue-cli-g 或 yarn global remove vue-cli 安装:npm i @vue/cli -g ...
- Django 项目环境搭建
环境 mkvirtualenv -p python3.6 mytest # 创建虚拟环境 workon mytest # 进入虚拟环境 # 按照基础环境依赖 pip install django==1 ...
- try、catch、finally--try块里有return,finally还执行吗?
finally块的作用是,保证无论出现什么情况,finally块里的代码一定会被执行. 由于程序执行return就意味着结束对当前函数的调用并跳出这个函数体,所以任何语句要执行都只能在return之前 ...
- 【LeetCode】随机化算法 random(共6题)
[384]Shuffle an Array(2019年3月12日) Shuffle a set of numbers without duplicates. 实现一个类,里面有两个 api,struc ...
- spring整合Quartz2持久化任务调度
转摘 https://blog.csdn.net/qwe6112071/article/details/50999386 因为通过Bean配置生成的JobDetail和CronTrigger或Simp ...
- MySQL MHA + Ifconfig管理vip
前期的安装步骤,还是参照:http://www.cnblogs.com/yiyuf/p/4104354.html进行,只需要把appxxx.cnf中定义的相关.sh脚本(如:master_ip_fai ...
- grep正则表达式(一)
新建一批 txt 文件: [me@linuxbox ~]$ ls /bin > dirlist-bin.txt [me@linuxbox ~]$ ls /usr/bin > dirlist ...