文档库 最新最全的文档下载
当前位置:文档库 › 数据类型

数据类型

数据类型
数据类型

如果您在变量表中进行赋值,则必须为每个局部变量定义数据类型。当您明确地为值指定数据类型时,您为 STEP 7-Micro/WIN SMART 提供清晰的指令,指明需要为值分配多少存储空间以及如何表示值。例如,值 100 可以存储为字节、字或双字。值 0 可解释为布尔状态或数字值。

每个指令或参数化子例程通过精确定义进行标识。该定义可被称为签名。对于所有的标准指令,每个指令操作数允许使用的数据类型集均从签名获得。对于参数化子例程,用户通过变量表创建子例程签名。

STEP 7-Micro/WIN SMART 执行简单的数据类型检查。将局部变量或全局变量提供给指令参数时,STEP 7-Micro/WIN SMART 确保这些变量对于指令参数为正确的数据类型。

STEP 7-Micro/WIN SMART 支持以下基本和复杂的数据类型:

基本数据

类型

数据

类型大

说明范围

BOOL 1 位布尔0 到 1 BYTE 8 位无符号字节0 到 255

BYTE 8 位有符号字节(SIMATIC 模式仅用于 SHRB

指令)

-128 到 +127

WORD 16 位无符号整数0 到 65,535

INT 16 位有符号整数-32768 到 +32767 DWORD 32 位无符号双整数0 到 4294967295

DINT 32 位有符号双整数-2147483648 到+2147483647

REAL 32 位IEEE 32 位浮点+1.175495E-38 至+3.402823E+38

-1.175495E-38 至-3.402823E+38

STRING 1 至

255 字

存储在 PLC 存储器中的 ASCII 字面字

符串,形式为 1 字符串长度字节后接

ASCII 数据字节

ASCII 字符代码 0

至 255

复杂数据类型1说明范围TON 接通延时定时器

1 ms T32、T96

复杂数据类型1说明范围

10 ms 100 ms T33 - T36, T97 - T100 T37 - T63, T101 -T255

TOF 断开延时定时器1 ms

10 ms

100 ms

T32、T96

T33 - T36, T97 - T100

T37 - T63, T101 - 255

TONR 保持型接通延时定时器1 ms

10 ms

100 ms

T0、T64

T1 - T4、T65 - T68

T5 - T31、T69 - T95

CTU 向上计数器0 到 255 0 到 255

CTD 向下计数器0 到 255 0 到 255

CTUD 增/减计数器0 到 255 0 到 255

变量表中的数据类型检查

变量表具有简单数据类型检查。在该模式下,当符号或变量被分配一种数据类型时,同时自动应用于与所选数据类型大小相匹配的所有数据类型。例如,如果用户选择 DINT 作为数据类型,局部变量会自动分配数据类型 DWORD,因为二者均为 32 位数据类型。但是不自动分配 REAL 数据类型,即使也是 32 位数据类型。REAL 数据类型被定义为无其他等同数据类型:其始终唯一。

用户选择的数据类型等同数据类型

BOOL BOOL

BYTE BYTE

WORD WORD, INT

INT WORD, INT

DWORD DWORD, DINT

DINT DWORD, DINT

REAL REAL

STRING STRING

符号表中无数据类型

符号表编辑器无数据类型。这是一种给地址分配名称的方法,而与该地址表示的数据无关。在该模式下,符号可引用所有等同大小的数据类型。例如,赋予 VD100 地址的符号可用于以下数据类型:DWORD、DINT 和 REAL。

针对符号由大小决定的数据类型

用户选择的地址等同数据类型

V0.0 BOOL

VB0 BYTE, STRING

VW0 WORD, INT

VD0 DWORD, DINT, REAL

编程时检查数据类型

必须注意,对有符号指令使用的无符号数字不要超过正负数界限,否则会产生无法预测的结果。例如,关系比较 < I是有符号指令。对有符号数据类型操作数来讲,-1 显然小于 0。但是,对 < I 指令使用无符号数据类型时,程序员应确保无符号数不用作有符号数。在程序运行时,对于 < I 指令,无符号值 40,000 被解释为小于 0。必须检查数字值是否位于该数据类型的有效范围内。

警告

请确保有符号指令的无符号数字的使用不超过正负数界限。

如果未能确保有符号指令的无符号数字不超过正负数界限,程序或控制器运行可能产生无法预测的结果。无法预测的控制器运行可能导致人员死亡或重伤和/或严重财产的损失。

请务必确保有符号指令的无符号数字不超过正负数界限。

使用数据类型转换指令

转换指令将一种数据类型移至另一种数据类型。STEP 7-Micro/WIN SMART 支持可在简单数据类型之间进行转换的下列转换指令。

转换指令说明变量表允许的操作数

B_I BYTE TO INT

IN :

OUT : BYTE WORD, INT

I_B INT TO BYTE

IN :

OUT : WORD, INT BYTE

I_DI INT TO DINT

IN :

OUT : WORD, INT DWORD, DINT

DI_I DINT TO INT

IN :

OUT : DWORD, DINT WORD, INT

DI_R DINT TO REAL

IN :

OUT : DWORD, DINT REAL

R_DI REAL TO DINT (ROUND)

IN :

OUT : REAL DWORD, DINT

S_I STRING TO INT

IN:

OUT : STRING,

DWORD(* 指向字符串的指针)WORD, INT

I_S INT TO STRING

IN :

OUT: WORD, INT

STRING,

DWORD(* 指向字符串的指针)

S_DI STRING TO DINT

IN:

OUT : STRING,

DWORD(* 指向字符串的指针)DWORD, DINT

DI_S DINT TO STRING

IN :

OUT: DWORD, DINT

STRING,

DWORD(* 指向字符串的指针)

S_R STRING TO REAL

IN :

OUT : STRING,

DWORD(* 指向字符串的指针)REAL

R_S REAL TO STRING

IN :

OUT :

REAL

STRING,

DWORD(* 指向字符串的指针)

有效常数范围如下: 不带符号的整数范围 带符号的整数范围

数据大小:

十进制:

十六进制: 十进制: 十六进制: B (字节) 0 到 255

16#0 到 16#FF

-128 到 +127

16#80 到 16#7F W (字) 0 到 65535 16#0 到 16#FFFF -32768 到 +32767 16#8000 到 16#7FFF D (双字)

0 到

4294967295 16#0 到

16#FFFF FFFF

-2147483648 到 +2147483647

16#8000 0000 到

16#7FFF FFFF

数据大小: 十进制实数(正数范围)

十进制实数(负数范围) D (双字)

+1.175495E-38 至 +3.402823E+38

-1.175495E-38 至 -3.402823E+38

常数格式标识符

程序可在许多指令中使用字节、字或双字大小的数据常数。 格式标识符控制如何显示常数数值(二进制数字、十进制数字、十六进制数字或 ASCII 字符)。 假设程序常数为十进制数字,除非您使用格式标识符: 2# 二进制数字 16#

十六进制数字

'abcd' ASCII 常数,使用单引号字符起始与结束 ASCII 字符。 对在参数列表

中指定“常数”(Constant) 的大多数指令都有效。 作为数据字节存

储。 "字符串"

ASCII 常数字符串,使用双引号字符起始与结束 ASCII 字符。 对在参数列表中指定常数字符串的指令参数有效。 以长度字节后接数据字节的形式存储。

二进制常数示例

示例

数字基数

分隔符

常数数值 2#1101 2 # 1101 2#1101_1111 2

#

11011111

十六进制常数示例

示例数字基数分隔符常数数值

16#3FB2 16 # 3FB2

16#A_1_C_D 16 # A1CD

说明

输入常数时可使用下划线增强可读性。

ASCII 常数字符范围

ASCII 常数字符的有效范围是 ASCII 32 至 ASCII 255,不包括 DEL 字符、单引号和双引号字符。在此范围之外的 ASCII 字符必须使用特殊 $ 字符格式。

ASCII 原义字符常数示例(单引号格式)

与允许将常数作为输入的指令合用

参数操作数数据类型IN1、IN2 IB, QB, MB, SMB, VB, SB, LB, AC, 常数, *VD, *LD, *AC BYTE

数据ASCII 常数输入的编辑

器支持

有效地址示

内存映射

无用于单引号格式的前导长度

字节

VB0VB1VB2VB3VB4VB5

'A' 程序和数据块VB0 A

'AB' 程序和数据块VB0, VW0 A B

'ABC' 数据块VB0 A B C

'ABCD' 程序和数据块VB0, VD0 A B C D

'ABCDE' 数据块VB0 A B C D E

'ABCDEF' 数据块VB0 A B C D E F ASCII 原义常数字符串示例(双引号格式)

与允许将常数字符串作为输入的指令合用

参数操作数数据类型IN VB, 常数字符串, *VD, *LD, *AC STRING

数据ASCII 常数字符串输入的

编辑器支持

有效地址

示例

内存映射

用于双引号格式的前导长度字

VB0V B1V B2V B3V B4V B5V B6

"A" 程序和数据块VB0 1 A

"AB" 程序和数据块VB0 2 A B

"ABC" 程序和数据块VB0 3 A B C

"ABCD" 程序和数据块VB0 4 A B C D "ABCDE" 程序和数据块VB0 5 A B C D E "ABCDEF" 程序和数据块VB0 6 A B C D E F

说明

对于 ASCII 常数,$ 是一个格式字符,用于在字符串中指明某特殊字符。

使用 $ 格式字符的字符串示例:

当您下载或上传数据块及主程序、子例程和中断例程时,使用 $ 格式字符修改ASCII 原义常数。

字符串条目存储在 PLC 存储器中的数据

'Cost $$50' "Cost $$50"Cost $50 Cost $50

'Enter $'name$'' "Enter $"name$""Enter 'name' Enter "name"

下表显示嵌套控制字符的方法。

代码解释$$ 单美元符号

$'单引号字符

$"双引号字符

$L 或 $l 换行字符

$N 或 $n 新行字符

$P 或 $p 换页,新页

代码解释

$R 或 $r 回车字符

$T 或 $t 制表符,即制表字符

$ 后的两个十六进制数字 1f 指定 ASCII 代码 1f。$1f

ASCII 1f 十六进制数字 = ASCII 31 十进制数字

C语言中数据类型

C语言中数据类型(整形,浮点型,字符型,无值型)2007年04月19日星期四上午11:29整型(int) 一、整型数说明 加上不同的修饰符, 整型数有以下几种类型; signed short int 有符号短整型数说明。简写为short或int, 字长为2字节共16位二进制数, 数的范围是-32768~32767。 signed long int 有符号长整型数说明。简写为long, 字长为4字节共32位二进制数, 数的范围是-2147483648~2147483647。 unsigned short int 无符号短整型数说明。简写为unsigned int, 字长为2字节共16位二进制数, 数的范围是0~65535。 unsigned long int 无符号长整型数说明。简写为unsigned long, 字长为4字节共32位二进制数, 数的范围是0~4294967295。 二、整型变量定义 可以用下列语句定义整型变量 int a, b; /*a、b被定义为有符号短整型变量*/ unsigned long c; /*c被定义为无符号长整型变量*/ 三、整型常数表示 按不同的进制区分, 整型常数有三种表示方法: 十进制数: 以非0开始的数 如:220, -560, 45900 八进制数: 以0开始的数 如:06; 0106, 05788 十六进制数:以0X或0x开始的数 如:0X0D, 0XFF, 0x4e 另外, 可在整型常数后添加一个"L"或"l"字母表示该数为长整型数, 如22L,0773L, 0Xae4l。 浮点型(float) 一、浮点数说明 Turbo C中有以下两种类型的浮点数: float 单浮点数。字长为4 个字节共32 位二进制数, 数的范围是3.4x10-38E~3.4x10+38E。double 双浮点数。字长为8个字节共64 位二进制数, 数的范围是1.7x10-308E~1.7x10+308E。 说明: 浮点数均为有符号浮点数, 没有无符号浮点数。 二、浮点型变量定义 可以用下列语句定义浮点型变量: float a, f; /*a, f被定义为单浮点型变量*/ double b; /*b被定义为双浮点型变量*/

数据库常用数据类型

(1) 整数型 整数包括bigint、int、smallint和tinyint,从标识符的含义就可以看出,它们的表示数范围逐渐缩小。 l bigint:大整数,数范围为-263 (-9223372036854775808)~263-1 (9223372036854775807) ,其精度为19,小数位数为0,长度为8字节。 l int:整数,数范围为-231 (-2,147,483,648) ~231 - 1 (2,147,483,647) ,其精度为10,小数位数为0,长度为4字节。 l smallint:短整数,数范围为-215 (-32768) ~215 - 1 (32767) ,其精度为5,小数位数为0,长度为2字节。 l tinyint:微短整数,数范围为0~255,长度为1字节,其精度为3,小数位数为0,长度为1字节。 (2) 精确整数型 精确整数型数据由整数部分和小数部分构成,其所有的数字都是有效位,能够以完整的精度存储十进制数。精确整数型包括decimal 和numeric两类。从功能上说两者完全等价,两者的唯一区别在于decimal不能用于带有identity关键字的列。 声明精确整数型数据的格式是numeric | decimal(p[,s]),其中p为精度,s为小数位数,s的缺省值为0。例如指定某列为精确整数型,精度为6,小数位数为3,即decimal(6,3),那么若向某记录的该列赋值56.342689时,该列实际存储的是56.3427。 decimal和numeric可存储从-1038 +1 到1038 –1 的固定精度和小数位的数字数据,它们的存储长度随精度变化而变化,最少为5字节,最多为17字节。 l 精度为1~9时,存储字节长度为5; l 精度为10~19时,存储字节长度为9; l 精度为20~28时,存储字节长度为13; l 精度为29~38时,存储字节长度为17。 例如若有声明numeric(8,3),则存储该类型数据需5字节,而若有声明numeric(22,5),则存储该类型数据需13字节。 注意:声明精确整数型数据时,其小数位数必须小于精度;在给精确整数型数据赋值时,必须使所赋数据的整数部分位数不大于列的整数部分的长度。 (3) 浮点型 浮点型也称近似数值型。顾名思义,这种类型不能提供精确表示数据的精度,使用这种类型来存储某些数值时,有可能会损失一些精度,所以它可用于处理取值范围非常大且对精确度要求不是十分高的数值量,如一些统计量。

API 中数据类型与PB数据类型对照表

API 中数据类型与PB数据类型对照表 MICROSOFT PB(16Bi t) PB(32Bit) Bool Boolean Boolean Byte, Char Char Char Char* Ref string Ref String Colorref Uint Ulong Double Double Double Dword Uint Ulong Float N/A N/A Handle Uint Ulong Hdc Uint Ulong Hfile Uint Ulong Hinstance Uint Ulong Hwnd Uint Ulong Int Int Int Long Long Long Lparam Uint Ulong Lpbyte Ref Int Ref Long Lpcwstr Ref Blob Ref Blob (Unicode use ToUnicode()) Lpcvoid Ref String Ref String Lpdword Ref Uint R ef Ulong Lpfiletime Ref Time Ref Time Lpint R ef Int Ref Long Lpstr,Lpcstr Ref String Ref String Lpvoid Ref Structstruct_inst Ref Struct struct_inst Lpword Ref Int R ef Ulong Mcierror Long Long Pbyte Ref Int[#] Ref Long[#] Short Int Int Structure Ref Struct struct_inst R ef Struct Struct_inst Uint Uint Uint Void** SUBROUTINE SUBROUTINE Word Uint Uint Wparam Uint Ulong

Excel中常用的数据类型

Excel中常用的数据类型 在Excel的单元格中可以输入多种类型的数据,如文本、数值、日期、时间等等。下面简单介绍这几种类型的数据。 1.字符型数据。在Excel中,字符型数据包括汉字、英文字母、空格等,每个单元格最多可容纳32000个字符。默认情况下,字符数据自动沿单元格左边对齐。当输入的字符串超出了当前单元格的宽度时,如果右边相邻单元格里没有数据,那么字符串会往右延伸;如果右边单元格有数据,超出的那部分数据就会隐藏起来,只有把单元格的宽度变大后才能显示出来。 如果要输入的字符串全部由数字组成,如邮政编码、电话号码、存折帐号等,为了避免Excel把它按数值型数据处理,在输入时可以先输一个单引号“'”(英文符号),再接着输入具体的数字。例如,要在单元格中输入电话号码“64016633”,先连续输入“'64016633”,然后敲回车键,出现在单元格里的就是“64016633”,并自动左对齐。 2.数值型数据。在Excel中,数值型数据包括0~9中的数字以及含有正号、负号、货币符号、百分号等任一种符号的数据。默认情况下,数值自动沿单元格右边对齐。在输入过程中,有以下两种比较特殊的情况要注意。 (1)负数:在数值前加一个“”号或把数值放在括号里,都可以输入负数,例如要在单元格中输入“66”,可以连续输入“66”“(66)”,然后敲回车键都可以在单元格中出现“66”。 (2)分数:要在单元格中输入分数形式的数据,应先在编辑框中输入“0”和一个空格,然后再输入分数,否则Excel会把分数当作日期处理。例如,要在单元格中输入分数“2/3”,在编辑框中输入“0”和一个空格,然后接着输入“2/3”,敲一下回车键,单元格中就会出现分数“2/3”。 3.日期型数据和时间型数据。在人事管理中,经常需要录入一些日期型的数据,在录入过程中要注意以下几点: (1)输入日期时,年、月、日之间要用“/”号或“-”号隔开,如“2002-8-16”“2002/8/16”。 (2)输入时间时,时、分、秒之间要用冒号隔开,如“10:29:36”。 (3)若要在单元格中同时输入日期和时间,日期和时间之间应该用空格隔开。 (信息技术教育室供稿)

C语言的基本数据类型及其表示

3.2C语言的基本数据类型及其表示 C语言的基本数据类型包括整型数据、实型数据和字符型数据,这些不同数据类型如何表示?如何使用?它们的数据范围是什么?下面我们分别进行介绍。 3.2.1常量与变量 1.常量 常量是指程序在运行时其值不能改变的量,它是C语言中使用的基本数据对 象之一。C语言提供的常量有: 以上是常量所具有的类型属性,这些类型决定了各种常量所占存储空间的大小和数的表示范围。在C程序中,常量是直接以自身的存在形式体现其值和类型,例如:123是一个整型常量,占两个存储字节,数的表示范围是-32768~32767;123.0是实型常量,占四个存储字节,数的表示范围是-3.410-38~3.41038。 需要注意的是,常量并不占内存,在程序运行时它作为操作对象直接出现在运算器的各种寄存器中。 2.符号常量 在C程序中,常量除了以自身的存在形式直接表示之外,还可以用标识符来表示常量。因为经常碰到这样的问题:常量本身是一个较长的字符序列,且在程序中重复出现,例如:取常数的值为3.1415927,如果在程序中多处出现,直接使用3.1415927的表示形式,势必会使编程工作显得繁琐,而且,当需要把的值修改为3.1415926536时,就必须逐个查找并修改,这样,会降低程序的可修改性和灵活性。因此,C语言中提供了一种符号常量,即用指定的标识符来表示某个常量,在程序中需要使用该常量时就可直接引用标识符。 C语言中用宏定义命令对符号常量进行定义,其定义形式如下: #define标识符常量 其中#define是宏定义命令的专用定义符,标识符是对常量的命名,常量可以是前面介绍的几种类型常量中的任何一种。该使指定的标识符来代表指定的常量,这个被指定的标识符就称为符号常量。例如,在C程序中,要用PAI代表实型常量3.1415927,用W代表字符串常量"Windows98",可用下面两个宏定义命令: #define PAI3.1415927 #define W"Windows98" 宏定义的功能是:在编译预处理时,将程序中宏定义(关于编译预处理和宏定义的概念详见9.10节)命令之后出现的所有符号常量用宏定义命令中对应的常量一一替代。例如,对于以上两个宏定义命令,编译程序时,编译系统首先将程序中除这两个宏定义命令之外的所有PAI替换为3.1415927,所有W替换为Windows98。因此,符号常量通常也被称为宏替换名。 习惯上人们把符号常量名用大写字母表示,而把变量名用小写字母表示。例3-1是符号常量的一个简单的应用。其中,PI为定义的符号常量,程序编译时,用3.1416替换所有的PI。 例3-1:已知圆半径r,求圆周长c和圆面积s的值。

数据类型

杨琦 西安交通大学计算机教学实验中心

?数据类型就是对数据的分类。不同类型的数据存储格式不同。 ?在C++中,基本数据类型可分为整型、实型等。?1.整型,采用补码表示,它又细分为: ?整型,4字节,-231(-2147483648)~231-1 (2147483647)?短整型, 2字节,-32768~32767 ?无符号整型,4字节,0~232-1 ?无符号短整型,2字节,0~216-1(即65535) ?C++11标准,长长整型,8字节,-263~263-1

?2.表示实数,采用浮点表示法,有两个标准: ?单精度浮点,4字节,-3.4×10-38~3.4×1038 ?双精度浮点,8字节,-1.8×10-308~1.8×10308 ?长双精度浮点数,C++11标准,16字节 ?C++标准并没有规定每种数据类型的字节数和范围?不同的编译器采用的字节数会有所不同 ?但相对关系不变 ?字节数越多,表示的数的范围就越大

1.整数的书写,不带小数点 ?十进制整型数,直接写,可带正、负号 1, 12, +123, -1234 ?十六进制整数 0xFF,0x10,0x21 ?八进制整数 010,021 ?无符号整数,加后缀U或u, 如:1U, 12U, 123U,2014u

2.实数的书写,有两种方式?小数形式: 1.0, 1. , 0.1, .1 ?指数形式: 1.2E-2表示1.2×10-2, 1.2E+2表示1.2×102 1.2E2表示1.2×102 E可以小写 ?默认,双精度浮点 ?单精度浮点加后缀F或f,如 12.5F,1.25E-2F

数据类型

17.下面________是不合法的单精度常数。 A)100! B) 100.0 C )1E+2 D)100.0D+2 72.日期类型(Date)在程序中运用时,日期类型必须用________符号括起来。 A.# B.@ C.$ D.% 102.方法Print "10+6=";10+6输出的结果是_________。 A.10+6=10+6 B. 10+6=16 C. 16=10+6 D. "10+6="10+6 122.扩展名为.vbp的工程文件中包含有__________。 A.工程中所有模块的有关信息 B.每个窗体模块中的所有控件的有关信息 C.每个模块中所有变量的有关信息 D.每个模块中所有过程的有关信息 136.以下关于方法的叙述中,错误的是__________。 A.方法是构成对象实体的一个部分 B.方法是一种特殊的过程或函数 C.调用方法的一般格式是:对象名称.方法名称 [参数] D.在调用方法时,对象名称是不可缺少的 140.设变量D为Date型、A为Integer型、S为String型、L为Long型,下面赋值语句中不能执行的是___________。 A.D=#12:30:00 PM# B.A="3277e1" C.S=Now D.L="4276D3" 141.对象在响应某个事件时,计算机要执行一段程序,以完成相应的操作,这样的程序片段叫做_______过程。 A.方法 B.事件C.调用D.编译 153.在一个工程中,可以有多个________。 A.资源文件B.工程文件C.标准模块文件D.机器代码文件 163.将数2.567E-12写成普通的十进制数是。 A.0.000000000002567 B.0.0000000002567 C.0.0000000000002567 D.0.00000000000002567 172.一只白色的足球被踢进球门,则白色、足球、踢、进球门是________。 A.属性、对象、方法、事件B.属性、对象、事件、方法. C.对象、属性、方法、事件D.对象、属性、事件、方法 189.VB6.0规定,不同类型的数据占用存储空间的长度是不同的。下列各组数据类型中,满足占用存储空间从小到大顺序排列的是_________。 A. Byte, Integer, Long, Double B. Byte, Integer, Double, Boolean C. Boolean, Byte, Integer, Double D. Boolean, Byte, Integer, Long 201.VB变量名abc!的类型是________。 A.字符串类型B.单精度类型C.整型D.双精度类型

数据类型

第四课数据类型 先来简单说说C语言的标识符和关键字。标识符是用来标识源程序中某个对象的名字的,这些对象可以是语句、数据类型、函数、变量、数组等等。C语言是大小字敏感的一种高级语言,如果我们要定义一个定时器1,可以写做"Timer1",如果程序中有"TIMER1",那么这两个是完全不同定义的标识符。标识符由字符串,数字和下划线等组成,注意的是第一个字符必须是字母或下划线,如"1Timer"是错误的,编译时便会有错误提示。有些编译系统专用的标识符是以下划线开头,所以一般不要以下划线开头命名标识符。标识符在命名时应当简单,含义清晰,这样有助于阅读理解程序。在C51编译器中,只支持标识符的前32位为有效标识,一般情况下也足够用了,除非你要写天书:P。 关键字则是编程语言保留的特殊标识符,它们具有固定名称和含义,在程序编写中不允许标识符与关键字相同。在KEIL uVision2中的关键字除了有ANSI C标准的32个关键字外还根据51单片机的特点扩展了相关的关键字。其实在KEIL uVision2的文本编辑器中编写C程序,系统可以把保留字以不同颜色显示,缺省颜色为天蓝色。 先看表4-1,表中列出了KEIL uVision2 C51编译器所支持的数据类型。在标准C语言中基本的数据类型为char,int,short,long,float 和double,而在C51编译器中int和short相同,float和double相同,这里就不列出说明了。下面来看看它们的具体定义:

表4-1 KEIL uVision2 C51编译器所支持的数据类型 1.char字符类型 char类型的长度是一个字节,通常用于定义处理字符数据的变量或常量。分无符号字符类型unsigned char和有符号字符类型signed char,默认值为signed char类型。unsigned char类型用字节中所有的位来表

java的基本数据类型有八种

java的基本数据类型有八种 各位读友大家好!你有你的木棉,我有我的文章,为了你的木棉,应读我的文章!若为比翼双飞鸟,定是人间有情人!若读此篇优秀文,必成天上比翼鸟! java的基本数据类型有八种四类八种基本数据类型1. 整型byte(1字节)short (2个字节)int(4个字节)long (8个字节)2.浮点型float(4个字节)double(8个字节)3.逻辑性boolean(八分之一个字节)4.字符型char(2个字节,一个字符能存储下一个中文汉字)基本数据类型与包装类对应关系和默认值short Short (short)0int Integer 0long Long 0Lchar Char '\u0000'(什么都没有)float Floa t0.0fdouble Double 0.0dboolean Boolean false 若某个类的某个成员是基本数据类型,即使没有初始化,java也会确保它获得一个默认值,如上所示。(这种初始化方法只是用于成员变量,不适用于局部变量)。jdk1.5支持自动拆装箱。可以将基本数据类型转换成它的包装类装箱Integer a = new Integer ();a = 100;拆箱int b = new Intger(100);一个字节等于8位,一个字节等于256个数,-128到127一个英文字母或一个阿拉伯数字就是一个字符,占用一个字节一个汉字两个字符,占用两个字节基本数据类型自动转换byte->short , char->int->longfloat->doubleint ->floatlong->double小可转大,大转小会失去精度。字符串与基本类型或其他类型间的转换⑴其它

常用数据类型的使用

刚接触编程地朋友往往对许多数据类型地转换感到迷惑不解,本文将介绍一些常用数据类型地使用. 我们先定义一些常见类型变量借以说明 ; ; ; ; []"程佩君"; []; *; ; ; ; 一、其它数据类型转换为字符串 短整型() ()将转换为字符串放入中,最后一个数字表示十进制 (); 按二进制方式转换 长整型() (); 浮点数() 用可以完成转换,这是中地例子: , ; *; ; ( , , , ); 运行结果: : '' : : 资料个人收集整理,勿做商业用途 表示小数点地位置表示符号为正数,为负数 变量 "北京奥运"; ()(); 变量 ("程序员"); * (); 资料个人收集整理,勿做商业用途 (); (); (); 变量 (""); * (); 资料个人收集整理,勿做商业用途 (); (); 变量 类型是对地封装,因为已经重载了操作符,所以很容易使用 ("");

* 不要修改中地内容 (); 通用方法(针对非数据类型) 用完成转换 []; ''; ; ; ; ( , ""); ( , ""); ( , ""); ( , ""); 二、字符串转换为其它数据类型 (,""); 短整型() (); 长整型() (); 浮点() (); 变量 ; 变量 ("程序员"); 完成对地使用 (); 变量 类型变量可以直接赋值 (""); (); 变量 类型地变量可以直接赋值 (""); (); 三、其它数据类型转换到 使用地成员函数来转换,例如: 整数() (""); 浮点数() (""); 字符串指针( *)等已经被构造函数支持地数据类型可以直接赋值 ; 对于所不支持地数据类型,可以通过上面所说地关于其它数据类型转化到*地方法先转到*,

MySQL数据表类型 数据类型

表类型 MySQL的数据表类型很多,其中比较重要的是MyISAM,InnoDB这两种。 这两种类型各有优缺点,需要根据实际情况选择适合的,MySQL支持对不同的表设置不同的类型。下面做个对比: 一般情况下我觉得选择MyISAM就行,如果需要事务,或者需要很多用户同时修改某个数据表里的数据时,可以考虑InnoDB数据表。 数据类型 1.整型(xxxint) 右侧的取值范围是在未加unsigned关键字的情况下,如果加了unsigned,则最大值翻倍,如tinyint unsigned的取值范围为(0~256)。 书上说int(m)括弧里的m是表示SELECT查询结果集中的显示宽度,并不影响实际的取值范围,我测了一下,定义一个字段number 类型为int(4),插入一条记录"123456",用mysql query broswer执行SELECT查询,返回的结果集中123456正确显示,没有影响到显示的宽度,不知道这个m有什么用。 2.浮点型(float和double)

参数m只影响显示效果,不影响精度,d却不同,会影响到精度。 比如设一个字段定义为float(5,3),如果插入一个数123.45678,实际数据库里存的是123.457,小数点后面的数别四舍五入截成457了,但总个数不受到限制(6位,超过了定义的5位)。 3.定点数(decimal) decimal(m,d) 定点类型 浮点型在数据库中存放的是近似值,而定点类型在数据库中存放的是精确值。参数m是定点类型数字的最大个数(精度),范围为0~65,d小数点右侧数字的个数,范围为0~30,但不得超过m。 对定点数的计算能精确到65位数字。 4.字符串(char,varchar,xxxtext) 1.都可以通过指定n,来限制存储的最大字符数长度,char(20)和varchar(20)将最多只能存储20个字符,超过的字符将会被截掉。n必须小于该类型允许的最大字符数。 2.char类型指定了n之后,如果存入的字符数小于n,后面将会以空格补齐,查询的时候再将末尾的空格去掉,所以char类型存储的字符串末尾不能有空格,varchar不受此限制。 3.内部存储的机制不同。char是固定长度,char(4)不管是存一个字符,2个字符或者4个字符(英文的),都将占用4个字节,varchar是存入的实际字符数+1个字节(n<=255)或2个字节(n>255),所以varchar(4),存入一个字符将占用2个字节,2个字符占用3个字节,4个字符占用5个字节。 4.char类型的字符串检索速度要比varchar类型的快。 varchar和text: 1.都是可变长度的,最多能存储65535个字符。 2.varchar可指定n,text不能指定,内部存储varchar是存入的实际字符数+1个字节 (n<=255)或2个字节(n>255),text是实际字符数+2个字节。 3.text类型不能有默认值。

数据类型

数据类型,也称为数据元素,是一种使用一组属性描述其定义,标识,表示形式和允许值的数据单元。在特定的上下文中,它通常用于构造特定概念语义的语义正确,独立且明确的信息单元。数据元素可以理解为数据的基本单位,并且数据模型以一定顺序由几个相关的数据元素组成。 基本属性 (1)身份类属性:适用于数据元素标识的属性。它包括中文名称,英文名称,中文拼写,内部标识符,版本,注册机构,同义词名称和上下文。 (2)定义类属性:描述数据元素的语义属性。它包括定义,对象类词,特征词和应用程序约束。 (3)关系属性:描述数据元素与(或)数据元素与模式,数据元素概念,对象和实体之间的关系的属性。它包括分类方案,分类方案值和关系。 (4)表示类属性:描述数据元素表示方面的属性。它包括表达式字,数据类型,数据格式,值字段和度量单位。 (5)数据管理的属性管理。包括状态,提交组织,批准日期和备注。 形成 数据元素通常由对象类,属性和表示形式组成 (1)对象类。它是现实世界中事物的集合或抽象概念,具有明确的边界和含义,并且其特征和行为遵循相同的规则并且可以识别。

(2)财产。它是对象类的所有个人共享的属性,是对象与其他成员不同的基础。 (3)代表性。它是值字段,数据类型和表示形式的组合,并且在必要时还包括诸如度量单位和字符集之类的信息。 对象类是我们要研究,收集和存储相关数据(例如人员,设施,设备,组织,环境,材料等)的实体。特征是人们用来区分和识别事物(例如人员姓名)的一种手段,性别,身高,体重,位置,水箱型号,口径,身高,长度,有效范围等。表示形式是对数据元素表示方式的描述。在表达式的各个组成部分中,任何部分的更改都会产生不同的表示形式。例如,如果人员的身高是用“cm”或“ m”测量的,则它是人员的身高特征的两种不同表示。数据元素的表达式可以用一些带有含义的术语来标记,例如名称,代码,数量,数量,日期,百分比等。 在数据元素的基本模型中,对象类对应于数据模型中的实体,属性和表示,而对应于数据模型中的属性。

数据类型

数据类型 数据元( Data Element),也称为数据元素,是用一组属性描述其定义、标识、表示和允许值的数据单元,在一定语境下,通常用于构建一个语义正确、独立且无歧义的特定概念语义的信息单元。数据元可以理解为数据的基本单元,将若干具有相关性的数据元按一定的次序组成一个整体结构即为数据模型。 中文名 数据元 外文名 Data element 又称 数据类型 被认为 是不可再分的最小数据单元 目录 .1基本属性 .2组成 .3分类 .4命名规则 .5数据元与元数据 .6数据元提取 .?自上而下提取法 .?自下而上提取法 基本属性

(1)标识类属性:适用于数据元标识的属性。包括中文名称、英文名称、中文全拼、内部标 识符、版本、注册机构、同义名称、语境。 (2)定义类属性:描述数据元语义方面的属性。包括定义、对象类词、特性词、应用约束。 (3)关系类属性:描述各数据元之间相互关联和(或)数据元与模式、数据元概念、对象、 实体之间关联的属性。包括分类方案、分类方案值、关系。 (4)表示类属性:描述数据元表示方面的属性。包括表示词、数据类型、数据格式、值域、 计量单位。 (5)管理类属性:描述数据元管理与控制方面的属性。包括状态、提交机构、批准日期、备 注。 组成 数据元一般由对象类、特性和表示3部分组成: (1)对象类(Object Class)。是现实世界或抽象概念中事物的集合,有清楚的边界和含义,并 且特性和其行为遵循同样的规则而能够加以标识。 (2)特性(Property)。是对象类的所有个体所共有的某种性质,是对象有别于其他成员的依据。 (3)表示(Representation)。是值域、数据类型、表示方式的组合,必要时也包括计量单位、 字符集等信息。 对象类是我们所要研究、收集和存储相关数据的实体,例如人员、设施、装备、组织、环境、物资等。特性是人们用来区分、识别事物的一种手段,例如人员的姓名、性别、身高、体重、职务,坦克的型号、口径、高度、长度、有效射程等。表示是数据元被表达的方式的一种描述。 表示的各种组成成分中,任何一个部分发生变化都将产生不同的表示,例如人员的身高用“厘米” 或用“米”作为计量单位,就是人员身高特性的两种不同的表示。数据元的表示可以用一些具有表示含义的术语作标记,例如名称、代码、金额、数量、日期、百分比等。 数据元基本模型中,对象类对应于数据模型中的实体、特性和表示对应于数据模型中的属性。 分类 数据元的类型按不同的分类方式可以作如下分类。 1)按数据元的应用范围

关于数据库建表时字段数据类型

char、varchar、text、ntext、bigint、int、smallint、tinyint 和bit的区别及数据库的数据类型 基础: char、varchar、text和nchar、nvarchar、ntext的区别 1、CHAR。CHAR存储定长数据很方便,CHAR字段上的索引效率级高,比如定义char(10),那么不论你存储的数据是否达到了10个字节,都要占去10个字节的空间,不足的自动用空格填充。 2、VARCHAR。存储变长数据,但存储效率没有CHAR高。如果一个字段可能的值是不固定长度的,我们只知道它不可能超过10个字符,把它定义为 VARCHAR(10)是最合算的。VARCHAR类型的实际长度是它的值的实际长度+1。为什么“+1”呢?这一个字节用于保存实际使用了多大的长度。从空间上考虑,用varchar合适;从效率上考虑,用char合适,关键是根据实际情况找到权衡点。 3、TEXT。text存储可变长度的非Unicode数据,最大长度为2^31-1(2,147,483,647)个字符。 4、NCHAR、NVARCHAR、NTEXT。这三种从名字上看比前面三种多了个“N”。它表示存储的是Unicode数据类型的字符。我们知道字符中,英文字符只需要一个字节存储就足够了,但汉字众多,需要两个字节

存储,英文与汉字同时存在时容易造成混乱,Unicode字符集就是为了解决字符集这种不兼容的问题而产生的,它所有的字符都用两个字节表示,即英文字符也是用两个字节表示。nchar、nvarchar的长度是在1到4000之间。和char、varchar比较起来,nchar、nvarchar 则最多存储4000个字符,不论是英文还是汉字;而char、varchar 最多能存储8000个英文,4000个汉字。可以看出使用nchar、nvarchar 数据类型时不用担心输入的字符是英文还是汉字,较为方便,但在存储英文时数量上有些损失。 进一步学习: char、varchar、text、ntext、bigint、int、smallint、tinyint 和bit的区别及数据库的数据类型 Varchar 对每个英文(ASCII)字符都占用2个字节,对一个汉字也只占用两个字节 char 对英文(ASCII)字符占用1个字节,对一个汉字占用2个字节Varchar 的类型不以空格填满,比如varchar(100),但它的值只是"qian",则它的值就是"qian"而char 不一样,比如char(100),它的值是"qian",而实际上它在数据库中是"qian "(qian后共有96个空格,就是把它填满为100个字节)。由于char是以固定长度的,所以它的速度会比varchar快得多!但程序处理起来要麻烦一点,要用trim之类的函数把两边的空格去掉!

数据类型

数据元: 数据元(DataElement),也称为数据元素,是用一组属性描述其定义、标识、表示和允许值的数据单元,在一定语境下,通常用于构建一个语义正确、独立且无歧义的特定概念语义的信息单元。数据元可以理解为数据的基本单元,将若干具有相关性的数据元按一定的次序组成一个整体结构即为数据模型。 分类: 1)按数据元的应用范围 分为通用数据元、应用数据元(或称“领域数据元”)和专用数据元。通用数据元是与具体的对象类无关的、可以在多种场合应用的数据元。应用数据元是在特定领域内使用的数据元。应用数据元与通用数据元是相对于一定的应用环境而言的,两者之间并没有本质的区别,应用数据元是被限定的通用数据元,通用数据元是被泛化的应用数据元,随环境的变化彼此可以相互转化。专用数据元是指与对象类完全绑定、只能用来描述该对象类的某个特性的数据元。专用数据元包含了数据元的所有组成部分,是“完整的”数据元。 2)按数据元值的数据类型 可分为文字型数据元与数值型数据元。例如人的姓名是用文字表示的,属于文字型数据元;人的身高是用数值表示的,属于数值型数据元。 3)按数据元中数据项的多少 可分为简单数据元和复合数据元。简单数据元由一个单独的数据

项组成;复合数据元是由2个及以上的数据项组成的数据元,即由2个以上的数据元组成。组成复合数据元的数据元称为成分数据元。虽然数据元一般被认为是不可再分的数据的基本单元,而复合数据元是由两个以上的数据元组成的,但是在实际应用中复合数据元一般被当作不可分割的整体来使用,所以复合数据元仍然可以看作是数据的基本单元,即数据元。例如数据元“日期时间”是一个复合数据元,表示某一天的某一时刻,它由“日期”和“时间”两个数据元组成。

基本数据类型

S7-300的数据类型分以下三种: 基本数据类型、复合数据类型和参数类型。 一、基本数据类型 1、位(bit) 常称为BOOL(布尔型),只有两个值:0或1。 如:I0.0,Q0.1,M0.0,V0.1等。 2、字节(Byte)一个字节(Byte)等于8位(Bit),其中0位为最低位,7位为最高位。如:IB0(包括I0.0~I0.7位),QB0(包括Q0.0~Q0.7位),MB0,VB0等。范围:00~FF(十进制的0~255)。 3、字(Word) 相邻的两字节(Byte)组成一个字(Word),来表示一个无符号数,因此,字为16位。 如:IW0是由IB0和IB1组成的,其中I是区域标识符,W表示字,0是字的起始字节。 需要注意的是,字的起始字节(如上例中的“0”)都必须是偶数。 字的范围为十六进制的0000~FFFF(即十进制的0~65536)。 在编程时要注意,如果已经用了IW0,如再用IB0或IB1要特别加以小心。 4、双字(Double Word) 相邻的两个字(Word)组成一个双字,来表示一个无符号数。因此,双字为32位。 如:MD100是由MW100和MW102组成的,其中M是区域标识符,D表示双字,100是双字的起始字节。 需要注意的是,双字的起始字节(如上例中的“100”)和字一样,必须是偶数。 双字的范围为十六进制的0000~FFFFFFFF(即十进制的0~4294967295)。 在编程时要注意,如果已经用了MD100,如再用MW100或MW102要特别加以小心。 以上的字节、字和双字数据类型均为无符号数,即只有正数,没有负数。 5、16位整数(INT,Integer) 整数为有符号数,最高位为符号位,1表示负数,0表示正数。范围为-32768~32767。 6、32位整数(DINT,Double Integer) 32位整数和16位整数一样,为有符号数,最高位为符号位,1表示负数,0表示正数。 范围为-2147483648~2147483647。 7、浮点数(R,Real) 浮点数为32位,可以用来表示小数。浮点数可以为:1.m×2e ,其存储结构如图所示:

MySQL 常用数据类型

MySQL 三种常用的数据类型 MySQL中定义数据字段的类型对你数据库的优化是非常重要的。 MySQL支持多种类型,大致可以分为三类:数值、日期/时间和字符串(字符)类型。 1.数值类型 MySQL支持所有标准SQL数值数据类型。 这些类型包括严格数值数据类型(INTEGER、SMALLINT、DECIMAL和NUMERIC),以及近似数值数据类型(FLOAT、REAL和DOUBLE PRECISION)。 关键字INT是INTEGER的同义词,关键字DEC是DECIMAL的同义词。 BIT数据类型保存位字段值,并且支持MyISAM、MEMORY、InnoDB和BDB表。 作为SQL标准的扩展,MySQL也支持整数类型TINYINT、MEDIUMINT和BIGINT。下面的表显示了需要的每个整数类型的存储和范围。

2.日期和时间类型 表示时间值的日期和时间类型为DATETIME、DATE、TIMESTAMP、TIME和YEAR。 每个时间类型有一个有效值范围和一个"零"值,当指定不合法的MySQL不能表示的值时使用"零"值。 TIMESTAMP类型有专有的自动更新特性,将在后面描述。

3.字符串类型 字符串类型指CHAR、VARCHAR、BINARY、VARBINARY、BLOB、TEXT、ENUM和SET。该节描述了这些类型如何工作以及如何在查询中使用这些类型。 注意:

char(n) 和 varchar(n) 中括号中 n 代表字符的个数,并不代表字节个数,比如 CHAR(30) 就可以存储 30 个字符。 CHAR 和 VARCHAR 类型类似,但它们保存和检索的方式不同。它们的最大长度和是否尾部空格被保留等方面也不同。在存储或检索过程中不进行大小写转换。 BINARY 和 VARBINARY 类似于 CHAR 和 VARCHAR,不同的是它们包含二进制字符串而不要非二进制字符串。也就是说,它们包含字节字符串而不是字符字符串。这说明它们没有字符集,并且排序和比较基于列值字节的数值值。 BLOB 是一个二进制大对象,可以容纳可变数量的数据。有 4 种 BLOB 类型:TINYBLOB、BLOB、MEDIUMBLOB 和 LONGBLOB。它们区别在于可容纳存储范围不同。 有 4 种 TEXT 类型:TINYTEXT、TEXT、MEDIUMTEXT 和 LONGTEXT。对应的这 4 种 BLOB 类型,可存储的最大长度不同,可根据实际情况选择。 以上就是三种常用的MySQL 数据类型的详细内容。

数据类型

在STEP 7-Micro/WIN中编程时,在下列两种情况下您必须识别并使用数据类型: ?如果您以IEC 1131-3模式编程,则必须为全局符号表中的所有数值选择数据类型。 ?如果您在局部变量表中赋值,则必须为每个局部变量定义数据类型。 当您明确地为数值指定数据类型时,您为STEP 7-Micro/WIN提供清晰的指令,指明需要为数值分配多少内存空间(例如,数值100可被存储为字节、字或双字)以及如何表示数值(将0视作布尔值还是数字值?)。 每个SIMATIC和IEC 1131-3指令或参数化子程序均由精确定义识别。该定义可被称为签名。对于所有的标准指令,每个指令操作数允许使用的数据类型集均从签名获得。对于参数化子程序,用户通过局部变量表建立子程序签名。 STEP 7-Micro/WIN V3.0编程软件为SIMA TIC模式执行简单的数据类型检查,为IEC 1131-3模式执行细致的数据类型检查。这意味着为局部或全局变量指定一种数据类型时,软件在下表所列的每个等级中确保操作数数据类型与指令签名相匹配。 基本数据类型数据类型大小说明范围 布尔1位布尔0至1 字节8位不带符号的字节0至255 字节8位带符号的字节(SIMATIC模式仅限用于 SHRB指令) -128至+127 字16位不带符号的整数0至65,535 整数16位带符号的整数-32768至+32767 双字32位不带符号的双整数0至4294967295 双整数32位带符号的双整数-2147483648至+2147483647 实数32位IEEE 32 位浮点+1.175495E-38至+3.402823E+38-1.175495E-38至3.402823E+38 字符串2至255字节 ASCII字符串照原样存储在PLC内存中,形式 为1字符串长度接ASCII数据字节ASCII字符代码128至255 复杂数据类型说明范围 TON 打开接通延时定时器 1 ms10 ms100 ms T32, T96T33 - T36, T97 - T100T37 - T63, T101 -T255 TOF 关闭接通延时定时器 1 ms10 ms100 ms T32, T96T33 - T36, T97 - T100T37 - T63, T101 - 255 TP 脉冲定时器(参阅注释1) 1 ms10 ms100 ms T32, T96T33 - T36, T97 - T100T37 - T63, T101 - 255 CTU 向上计数器0至255 CTD 向下计数器0至255 CTUD 向上/向下计数器0至255 SR 设置主要双稳态触发器无关 RS 复原主要双稳态触发器无关 STEP 7-Micro/WIN 提供三级数据类型检查

c语言的基本数据类型及其表示

3.2 C语言的基本数据类型及其表示 C语言的基本数据类型包括整型数据、实型数据和字符型数据,这些不同数据类型如何表示?如何使用?它们的数据范围是什么?下面我们分别进行介绍。 3.2.1 常量与变量 1. 常量 常量是指程序在运行时其值不能改变的量,它是C语言中使用的基本数据对 象之一。C语言提供的常量有: 以上是常量所具有的类型属性,这些类型决定了各种常量所占存储空间的大小和数的表示范围。在C程序中,常量是直接以自身的存在形式体现其值和类型,例如:123是一个整型常量,占两个存储字节,数的表示范围是-32768~32767;123.0是实型常量,占四个存储字节,数的表示范围是-3.4 10-38~3.4 1038。 需要注意的是,常量并不占内存,在程序运行时它作为操作对象直接出现在运算器的各种寄存器中。 2.符号常量 在C程序中,常量除了以自身的存在形式直接表示之外,还可以用标识符来表示常量。因为经常碰到这样的问题:常量本身是一个较长的字符序列,且在程序中重复出现,例如:取常数的值为3.1415927,如果在程序中多处出现,直接使用3.1415927的表示形式,势必会使编程工作显得繁琐,而且,当需要把的值修改为3.1415926536时,就必须逐个查找并修改,这样,会降低程序的可修改性和灵活性。因此,C语言中提供了一种符号常量,即用指定的标识符来表示某个常量,在程序中需要使用该常量时就可直接引用标识符。 C语言中用宏定义命令对符号常量进行定义,其定义形式如下: #define 标识符常量 其中#define是宏定义命令的专用定义符,标识符是对常量的命名,常量可以是前面介绍的几种类型常量中的任何一种。该使指定的标识符来代表指定的常量,这个被指定的标识符就称为符号常量。例如,在C程序中,要用PAI代表实型常量3.1415927,用W代表字符串常量"Windows 98",可用下面两个宏定义命令: #define PAI 3.1415927

相关文档