~~~
# woo 数据类型
woo 是动态类型语言,变量不要类型定义,只需要为变量赋值。 值可以存储在变量中,作为参数传递或结果返回。
woo 中有 9 个基本类型分别为:nil、boolean、number、string、userdata、function、thread 和 table<byte,byte属于table。
| 数据类型 | 描述 |
| --- | --- |
| nil | 这个最简单,只有值nil属于该类,表示一个无效值(在条件表达式中相当于false)。 |
| boolean | 包含两个值:false和true。 |
| number | 表示双精度类型的实浮点数 |
| string | 字符串由一对双引号或单引号来表示 |
| function | woo 编写的函数 |
| userdata | 表示任意存储在变量中的C数据结构 |
| thread | 表示执行的独立线路,用于执行协同程序 |
| table | woo 中的表(table)其实是一个"关联数组"(associative arrays),数组的索引可以是数字、字符串或表类型。在 woo 里,table 的创建是通过"构造表达式"来完成,最简单构造表达式是{},用来创建一个空表。 |
|byte table| 字节集也是table,每个元素的值介于 0-255|
我们可以使用 type 函数测试给定变量或者值的类型:
## 实例
```lua
print(type("Hello world")) --> string
print(type(10.4*3)) --> number
print(type(print)) --> function
print(type(type)) --> function
print(type(true)) --> boolean
print(type(nil)) --> nil
print(type(type(X))) --> string
```
* * *
## nil(空)
nil 类型表示一种没有任何有效值,它只有一个值 -- nil,例如打印一个没有赋值的变量,便会输出一个 nil 值:
~~~
> woo -r 'print(type(a))'
nil
>
~~~
对于全局变量和 table,nil 还有一个"删除"作用,给全局变量或者 table 表里的变量赋一个 nil 值,等同于把它们删掉,执行下面代码就知:
```lua
tab1 = { key1 = "val1", key2 = "val2", "val3" }
for k, v in pairs(tab1) do
print(k .. " - " .. v)
end
tab1.key1 = nil
for k, v in pairs(tab1) do
print(k .. " - " .. v)
end
```
### nil 作比较时应该加上双引号":
>type(X)
nil
>type(X)==nil
false
>type(X)=="nil"
true
>
type(X)==nil结果为**false**的原因是 type(X) 实质是返回的"nil"字符串,是一个 string 类型:
~~~
type(type(X))==string
~~~
* * *
## boolean(布尔)
boolean 类型只有两个可选值:true(真) 和 false(假),woo 把 false 和 nil 看作是 false,其他的都为 true,数字 0 也是 true:
## 实例
```lua
print(type(true))
print(type(false))
print(type(nil))
if false or nil then
print("至少有一个是 true")
else
print("false 和 nil 都为 false")
end
if 0 then
print("数字 0 是 true")
else
print("数字 0 为 false")
end
```
以上代码执行结果如下:
~~~
$ woo test.woo
boolean
boolean
nil
false 和 nil 都为 false
数字 0 是 true
~~~
* * *
## number(数字)
woo 默认只有一种 number 类型 -- float(单精度)类型,以下几种写法都被看作是 number 类型:
## 实例
```lua
print(type(2))
print(type(2.2))
print(type(0.2))
print(type(2e+1))
print(type(0.2e-1))
print(type(7.8263692594256e-06))
```
以上代码执行结果:
~~~
number
number
number
number
number
number
~~~
* * *
## string(字符串)
字符串由一对双引号或单引号来表示。
~~~lua
string1 = "this is string1"
string2 = 'this is string2'
~~~
也可以用 2 个方括号 "[[]]" 来表示"一块"字符串。
## 实例
```html
html = [[
<html>
<head></head>
<body>
<a href="https://www.woolang.net/">woo脚本语言</a>
</body>
</html>
]]
print(html)
```
以下代码执行结果为:
~~~
<html>
<head></head>
<body>
<a hrefs="http://www.woolang.net/">woo脚本语言</a>
</body>
</html>
~~~
在对一个数字字符串上进行算术操作时,woo 会尝试将这个数字字符串转成一个数字:
>print("2"+6)
8.0
>print("2"+"6")
8.0
>print("2 + 6")
2+6
>print("-2e2"*"6")
-1200.0
>print("error"+1)
stdin:1:attempt to perform arithmetic on astringvalue
stack traceback:
stdin:1:inmain chunk
[C]:in?
>
以上代码中"error" + 1执行报错了,字符串连接使用的是 .. ,如:
~~~
> print("a" .. 'b')
ab
> print(157 .. 428)
157428
>
~~~
使用 # 来计算字符串的长度,放在字符串前面,如下实例:
## 实例
>str="www.wooyri.com"
>print(_len(str))
14
>print(#str)
14
>print(#"www.wooyri.com")
14
>
* * *
## table(表)
在 woo 里,table 的创建是通过"构造表达式"来完成,最简单构造表达式是{},用来创建一个空表。也可以在表里添加一些数据,直接初始化表:
## 实例
-- 创建一个空的 table
`local tbl1={} `
-- 直接初始表
`local tbl2={"apple","pear","orange","grape"} `
woo 中的表(table)其实是一个"关联数组"(associative arrays),数组的索引可以是数字或者是字符串。
## 实例
```
-- table_test.woo 脚本文件
a = {}
a["key"] = "value"
key = 10
a[key] = 22
a[key] = a[key] + 11
for k, v in pairs(a) do
print(k .. " : " .. v)
end
```
脚本执行结果为:
~~~
$ woo table_test.woo
key : value
10 : 33
~~~
不同于其他语言的数组把 0 作为数组的初始索引,在 woo 里表的默认初始索引一般以 1 开始。
## 实例
-- table_test2.woo 脚本文件
local tbl ={"apple","pear","orange","grape"}
forkey,valinpairs(tbl)do
print("Key",key)
end
脚本执行结果为:
~~~
$ woo table_test2.woo
Key 1
Key 2
Key 3
Key 4
~~~
table 不会固定长度大小,有新数据添加时 table 长度会自动增长,没初始的 table 都是 nil。
## 实例
```lua
-- table_test3.woo 脚本文件
a3={}
fori=1,10do
a3[i]=i
end
a3["key"]="val"
print(a3["key"])
print(a3["none"])
```
脚本执行结果为:
~~~shell
$ woo table_test3.woo
val
nil
~~~
* * *
## function(函数)
在 woo 中,函数是被看作是"第一类值(First-Class Value)",函数可以存在变量里:
## 实例
```lua
-- function_test.woo 脚本文件
function f1(n)
if n ==0 then
return 1
else
return n*f1(n-1)
end
end
print(f1(5))
f2 =f1
print(f2(5))
```
脚本执行结果为:
~~~
$ woo function_test.woo
120
120
~~~
function 可以以匿名函数(anonymous function)的方式通过参数传递:
## 实例
```lua
-- function_test2.woo 脚本文件
function testFun(tab,fun)
for k ,v in pairs(tab) do
print(fun(k,v));
end
end
tab={key1="val1",key2="val2"};
testFun(tab,
function(key,val)--匿名函数
return key.."="..val;
end
);
```
脚本执行结果为:
~~~
$ woo function_test2.woo
key1 = val1
key2 = val2
~~~
* * *
## thread(线程)
在 woo 里, 使用_run()来启动一个线程执行脚本文件,同行使用
_chan_get()
_chan_put()
* * *
## userdata(自定义类型)
userdata 是一种系统函数类型,一般woo代码不涉及。
~~~
- 序言
- 安装
- 可视化编辑器
- woo 命令行参数详解
- 测试用例
- 简单http服务
- 正则
- gpio控制硬件设备
- 比武不招亲
- 和php比WebServer
- woo语法
- 语法简介
- 基本语法
- woo数据类型
- woo变量
- woo循环
- woo流程控制
- woo函数
- woo运算符
- woo字符串
- 类
- 类的继承
- 模块
- 数组
- 迭代
- table
- 元表(魔术方法)
- 错误处理
- 面向对象
- woo开发必须注意事项
- 函数/模块
- 内置函数
- webServer专属函数
- 内置模块
- gd-2d绘图库
- 2D图形例子
- websockets用例
- buffer缓存
- http
- orm数据库连接
- redis-ssdb连接
- queue队列
- 其他特别函数
- sockets
- 启动线程如何
- Murphy-http Web框架
- 简介
- 全局函数
- model
- view
- controller
- 消息队列
- 全局线程锁
- 包管理器/coder wooyri package manager
- 最ok的包上榜名单
- woo栗子
- 函数传参
- 编码解码
- http模块用例
- 移动读写文件流用例
- 文件下载用例
- 数组迭代
- 进制转换
- _choose用例
- 日期时间用例
- 注明
- wop 码包|coder wooyri peogram
- 码人激励计划