- D 编程基础
- D 编程 - 主页
- D 编程 - 概述
- D 编程 - 环境
- D 编程 - 基本语法
- D 编程 - 变量
- D 编程 - 数据类型
- D 编程 - 枚举
- D 编程 - 文字
- D 编程 - 运算符
- D 编程 - 循环
- D 编程 - 决策
- D 编程 - 函数
- D 编程 - 字符
- D 编程 - 字符串
- D 编程 - 数组
- D 编程 - 关联数组
- D 编程 - 指针
- D 编程 - 元组
- D 编程 - 结构
- D 编程 - 联合
- D 编程 - 范围
- D 编程 - 别名
- D 编程 - Mixins
- D 编程 - 模块
- D 编程 - 模板
- D 编程 - 不可变
- D 编程 - 文件 I/O
- D 编程 - 并发
- D 编程 - 异常处理
- D 编程 - 合同
- D - 条件编译
- D 编程 - 面向对象
- D 编程 - 类和对象
- D 编程 - 继承
- D 编程 - 重载
- D 编程 - 封装
- D 编程 - 接口
- D 编程 - 抽象类
- D 编程 - 有用的资源
- D 编程 - 快速指南
- D 编程 - 有用的资源
- D 编程 - 讨论
D 编程 - 文字
作为源代码的一部分在程序中键入的常量值称为文字。
文字可以是任何基本数据类型,可以分为整数、浮点数字、字符、字符串和布尔值。
同样,文字的处理方式与常规变量一样,只是它们的值在定义后不能修改。
整数文字
整数文字可以是以下类型 -
十进制使用正常的数字表示形式,第一位数字不能为 0,因为该数字被保留用于指示八进制系统。这不包括 0 本身:0 为零。
八进制使用 0 作为数字前缀。
二进制使用 0b 或 0B 作为前缀。
十六进制使用 0x 或 0X 作为前缀。
整数文字还可以具有 U 和 L 的组合后缀,分别表示无符号和长整型。后缀可以是大写或小写,并且可以是任何顺序。
当您不使用后缀时,编译器本身会根据值的大小在 int、uint、long 和 ulong 之间进行选择。
以下是整数文字的一些示例 -
212 // Legal 215u // Legal 0xFeeL // Legal 078 // Illegal: 8 is not an octal digit 032UU // Illegal: cannot repeat a suffix
以下是各种类型整数文字的其他示例 -
85 // decimal 0213 // octal 0x4b // hexadecimal 30 // int 30u // unsigned int 30l // long 30ul // unsigned long 0b001 // binary
浮点文字
浮点文字可以用十进制系统(如 1.568)或十六进制系统(如 0x91.bc)指定。
在十进制中,指数可以通过在字符 e 或 E 后面加上一个数字来表示。例如,2.3e4 表示“2.3 乘以 10 的 4 次方”。可以在指数值之前指定“+”字符,但没有任何作用。例如 2.3e4 和 2.3e + 4 是相同的。
在指数值之前添加的“-”字符将含义更改为“除以 10 的次方”。例如,2.3e-2 表示“2.3 除以 10 的 2 次方”。
在十六进制系统中,该值以 0x 或 0X 开头。指数由 p 或 P 指定,而不是 e 或 E。指数并不表示“10 的次方”,而是“2 的次方”。例如0xabc.defP4中的P4表示“abc.de乘以2的4次方”。
以下是浮点文字的一些示例 -
3.14159 // Legal 314159E-5L // Legal 510E // Illegal: incomplete exponent 210f // Illegal: no decimal or exponent .e55 // Illegal: missing integer or fraction 0xabc.defP4 // Legal Hexa decimal with exponent 0xabc.defe4 // Legal Hexa decimal without exponent.
默认情况下,浮点文字的类型为 double。f 和 F 表示浮点数,L 说明符表示实数。
布尔文字
有两个布尔文字,它们是标准 D 关键字的一部分 -
true值代表 true。
false值代表 false。
您不应将 true 值视为等于 1,将 false 值视为等于 0。
字符文字
字符文字用单引号括起来。
字符文字可以是普通字符(例如“x”)、转义序列(例如“\t”)、ASCII 字符(例如“\x21”)、Unicode 字符(例如“\u011e”)或作为命名字符(例如 '\©','\♥', '\€' )。
D 中有一些字符,当它们前面有反斜杠时,它们将具有特殊含义,它们用于表示换行符 (\n) 或制表符 (\t)。在这里,您有一些此类转义序列代码的列表 -
转义序列 | 意义 |
---|---|
\\ | \ 特点 |
\' | ' 特点 |
\" | “ 特点 |
\? | ?特点 |
\A | 警报或铃声 |
\b | 退格键 |
\F | 换页 |
\n | 新队 |
\r | 回车符 |
\t | 水平制表符 |
\v | 垂直标签 |
以下示例显示了一些转义序列字符 -
import std.stdio; int main(string[] args) { writefln("Hello\tWorld%c\n",'\x21'); writefln("Have a good day%c",'\x21'); return 0; }
当上面的代码被编译并执行时,它会产生以下结果 -
Hello World! Have a good day!
字符串文字
字符串文字用双引号括起来。字符串包含与字符文字类似的字符:普通字符、转义序列和通用字符。
您可以使用字符串文字将长行分成多行,并使用空格将它们分隔开。
以下是字符串文字的一些示例 -
import std.stdio; int main(string[] args) { writeln(q"MY_DELIMITER Hello World Have a good day MY_DELIMITER"); writefln("Have a good day%c",'\x21'); auto str = q{int value = 20; ++value;}; writeln(str); }
在上面的例子中,你可以发现使用 q"MY_DELIMITER MY_DELIMITER" 来表示多行字符。另外,您可以看到 q{} 代表 D 语言语句本身。