github.com/kulics/lite 这次我们来看看 Lite 的函数和结构设计。
在 Lite 中,函数也是表达式,必须赋值给变量或常量,声明的格式为
# (->) {} # function : (->) { # 函数逻辑 # a = 1 + 1 }
这是一个没有参数也没有返回值的函数。
函数的调用方式和其它大部分语言一样。
# 调用 # function()
函数的参数定义与定义变量的方式一样,写在函数定义括号箭头前面部分,多个参数用逗号隔开。
# 声明参数 # processInt : (x int, y int ->) { a = x + y } # 调用传参 # processInt(1, 2)
函数可以输出返回值,这样就可以将处理后的数据返回给调用者去使用。
函数的返回值定义与参数定义相同,不同的是写在函数定义括号箭头后面部分,多个返回值用逗号隔开。
返回语法表示为 <- value。
# 声明返回值 # getInt : (-> x int, y int) { # 返回数据 # <- 1, 2 } a, b = getInt()
函数本身也存在类型,表示形式与声明的语法一致,只是不需要标识符和函数体。
通过这种方式可以将函数像数据一样传递,这样就可以把部分逻辑的实现交给外部定义。
doSomething : (x int ->) { print(x) } # do 为函数类型参数 # useFunction : (do (int->) ->) { # 调用外部传入的函数 # do(5) } # 传递函数 # useFunction(doSomething)
除了传递函数名称,我们也可以直接创建匿名函数作为参数。
useFunction( (x int ->) { print(x) })
当然了,这种方式有点嗦。我们既然知道了函数的具体类型,就可以交给编译器去分析声明,用更简单的 Lambda 语法来帮我们声明函数。
# lambda 语法为 { id -> expression } # useFunction( { x -> print(x) })
嗯,简单多了。
如果这个函数只有一个函数参数,我们甚至可以省略外面的括号。
useFunction{ x -> print(x) }
这样就很棒了是不是?
Lite 语言内置了部分常用的 lambda 语法,在某些场景下可以精简代码设计。 使用判断 lambda 可以简化一些传值代码,语法结构与判断语法一样,只需要函数标记 ?->
。
a = ?-> 1 + 1 == 2 { 5 } _ { 0 } b = a ?-> 5 { 2 } _ { 3 }
使用循环 lambda 可以简化一些列表构造,语法结构与循环语法一样,只需要函数标记 @->
。
arr = i @-> 0..<5 { i * 3 }
在 Lite 中,结构体是将一系列具有相同类型或不同类型的数据构成的数据集合。
结构体的声明格式为
# id := $ {} # Cat := $ { name str age int }
这样就把一个 name 字段和 age 字段包装在一个叫 Cat 的结构中,我们得到了一个新的类型 Cat,它就像 int 和 str 一样是一个可以被构建和传递的新数据类型。
我们不能直接使用 Cat 里面的属性,因为它只是一种类型的声明。我们需要通过实例化,构造出我们需要的独立数据。
# 构造表达式 type{} # a = Cat{}
和其它语言一样,Lite 也通过 .
语法来调用结构体里面的内容。
a.name = "fish" a.age = 10
函数也是数据,所以结构体也可以直接声明函数,如果需要调用自身,只是需要在前面附带一个参数标志符,表示它自身。
Cat := me $ { miao : (->) { print(me.name, me.age) } }
这样 Cat 类型就增加了一个 miao 函数,它一样可以被调用。
a.miao()
接口是一种特殊的结构,它的定义形式类似于结构体,但是并不是用来包装数据,而是用来限定结构体必须包含的字段,用来对功能进行抽象,因此里面的内容只需要标志符和类型,不需要初始化。
接口的声明格式为
# id := % {} # Pet := % { getMaster (-> str) }
这样就声明了一个 Pet 接口,它规定了对应的结构体必须实现 getMaster 函数。
这里的接口也是一个独立的类型,但这个类型只能用来抽象对应的结构体并且使用它们的功能,不能用来构造数据。
因此我们可以这样去使用接口
printMaster : (x Pet ->) { print(x.getMaster()) }
就像使用一个结构体一样去使用它的内容。
现在我们给 Cat 实现 Pet 接口,只需要在定义后面追加接口定义部分就可以了。
# 实现规定的函数 # Cat := $ { ...... } % Pet { getMaster : (-> name str) { <- "Kulics" } }
现在我们就可以将 Cat 传递给 Pet 对象使用它了。
a = Cat{} # 将 Cat 传递给 Pet # printMaster(a)
以上是 Lite 函数、结构体和接口的基本语法. 下一次我们会来看看如何表达异常处理和异步处理。
![]() | 1 ipwx 2019-08-31 10:08:24 +08:00 我觉得这个楼主是新一代的“辣个男人”。 自从 ApiJson 的辣个男人被站长制裁了,好久没见过辣个男人了,稍微有点小寂寞呢。(手动狗头 |
2 GM 2019-08-31 10:16:50 +08:00 也就是说,我为了知道一个函数的返回值类型,需要通读整个函数? |
3 GM 2019-08-31 10:18:37 +08:00 为了读懂代码,需要熟记各个特殊符号在*不*同*场*景*下*的含义? |
4 GM 2019-08-31 10:20:19 +08:00 建议这个语言改个名,叫做 Licate,来源是 compLicate |
![]() | 5 changdy 2019-08-31 10:44:37 +08:00 K 娘 牛逼 --->此条推广 2 毛钱. |
![]() | 6 crella 2019-08-31 12:18:26 +08:00 via iPhone 哪位大佬有空写个 js 和 py 互转的编译器? |
7 StarkWhite 2019-08-31 13:34:40 +08:00 @ipwx 确实在 v 站很久没看到 apijson 那个懒人了,不过在别的平台还很活跃。。。 |
![]() | 8 zeroDev 2019-08-31 14:32:28 +08:00 via Android v2ex 还不够垂直,建议弄个 rrs,新文章 rss 推送,挂项目主页上,免得天天有人喷 |
![]() | 9 ilovecqrwx 2019-08-31 17:59:56 +08:00 K 叔! |
![]() | 10 FrankHB 2019-09-01 11:34:17 +08:00 Features * Well designed grammar, easy to write and read. 咋没看到 formal grammar 呢。我还指望有点啥 adaptive grammar 啥的劳什子呢,结果 BNF 都没? 看了下 doc,作者似乎连 grammar 和 syntax 都没分清? * The rules are clear and uniform, in line with intuition. 只说 syntax rules 吧:连两句话都描述不清的、到处 overload punctuation (比如 {})的 syntax,好意思叫 clear and uniform ? |