BS系统界面设计与开发详解.docx
- 文档编号:28957777
- 上传时间:2023-07-20
- 格式:DOCX
- 页数:21
- 大小:459.15KB
BS系统界面设计与开发详解.docx
《BS系统界面设计与开发详解.docx》由会员分享,可在线阅读,更多相关《BS系统界面设计与开发详解.docx(21页珍藏版)》请在冰豆网上搜索。
BS系统界面设计与开发详解
基本数据类型
(备注:
Java属于C语系,和C语言的数据类型是一致的)
1、1C的数据类型
程序、算法处理的对象是数据。
数据以某种特定的形式存在(如整数、实数、字符),而
且不同的数据还存在某些联系(如由若干整数构成的数组)。
数据结构就是指数据的组织形式
(逻辑结构、物理结构)。
处理同样的问题如果数据结构不同,算法也不同,应当综合考虑算法和数据结构、选择最佳的数据结构和算法。
C语言的数据结构是以数据类型的形式体现。
也就是说C语言中数据是有类型的,数据的
类型简称数据类型。
例如,整型数据、实型数据、整型数组类型、字符数组类型(字符串)分别代表我们常说的整数、实数、数列、字符串。
、I.
注意:
-32768〜32767,浮点数
1、不同的数据类型有不同的取值范围。
如有符号整数取值范围-3.4e-38〜3.4e38。
2、不同的数据类型有不同的操作。
如整型数可以取余操作,实型数据却不行;整型、实型数据可以有加法,字符数组不行。
3、不同的数据类型即使有相同的操作有时含义也不同,如指针数据自增1与整数自增1含义是不同的。
4、不同的数据类型对计算机可能出现的错误不同。
如整型数的溢出错误,浮点数的精度的丢失(有效数字位数不够)。
5、C语言的数据类型可以构造复杂的数据结构。
如使用结构体数组可以构造线性表。
使用指针类型、结构体类型可以构造线性链表(栈、队列)、树、图。
(在《数据结构》课程介绍)
6、C语言中的数据有变量与常量,它们分别属于上述这些类型。
1、2常量与变量
1、2、1常量:
在程序的运行过程中,其值不能改变的量称为常量。
1、常量有不同的类型,女口12、0、-3为整型常量,4.6、-1.23为实型常
量,’a'、’d'字符常量。
常量可以从字面形式即可判断-字面常量或直接常量。
2、符号常量
#definePI3.1416
使用符号常量的好处:
(1)含义清楚、见名知意。
(2)修改方便、一改全改。
例2-1:
符号常量应用
#definePI3.14
main()
{
floatarea;
area=10*10*PI;
printf("area=%f\n",area);
}
结果:
area=314.000000
1、2、2变量:
在程序的运行过程中,其值可以改变的量称为变量。
1、变量名(用标识符表示)、变量在内存中占据的存储单元、变量值三者关系。
变量名在程序运行过程中不会改变,变量的值可以改变。
变量名遵守标识符准则。
却不是这样。
有时你会用了两个相近似变量而你根本没有发现,却当作同一个变量在使
用。
2)申明的变量属于确定的类型,编译系统可方便地检查变量所进行运算的合法性。
3)在编译时根据变量类型可以为变量确定存储空间,“先定义后使用”使程序效率高。
1、3整型数据
1、3、1整型常数的表示方法
三种形式:
(+/-)
1)十进制。
例如123,-456,0。
2)八进制。
以0开头,后面跟几位的数字(0-7)。
例如:
0123=(123)8=(83)10;-011=(-11)8=(-9)10。
3)十六进制。
以0x开头,后面跟几位的数字(0-9,A-F)。
例如:
0x123=291,-0x12=-18。
4)整型常量的类型(整型常数的后缀)-在整型变量部分介绍,这里只要知道怎么表示。
整型常量后可以用:
u或U明确说明为无符号整型数
I或L明确说明为长整型数.
1、3、2整型变量
2、整型数据在内存中的存放形式数据在内存中以二进制形式存放,事实上以补码形式存放。
例如:
定义一个整型变量i=10,
(a)
丑-数据存放示意图
b-数据在内存中实际存放的情眾(补码表示)
补充知识(参考《微机原理》等课程):
1)带符号数的表示,原码、反码、补码。
2)原码-补码相互转化。
正数的补码与其原码相同,负数的补码是其对应的原码数值位按位取
反+1。
例题:
10,-10的计算机机内表示。
思路:
先将数值表示为二进制形式(十进制=>二进制,除2取余),即获得数值的原码。
将原码转化为补码,就是机内表示。
10=(1010)2=(0000,0000,0000,1010)原=(0000,0000,0000,1010)补。
-10=(-1010)2=(1000,0000,0000,1010)原=(1111,1111,1111,0110)补。
从10,-10的计算机机内表示可以看出正数、负数机内表示(补码表示)看上去明显不同。
3、整型变量的分类
整型变量的基本类型为int。
通过加上修饰符,可定义更多的整数数据类型。
1)根据表达范围可以分为:
基本整型(int)、短整型(shortint)、长整型(long
int)。
用long型可以获得大范围的整数,但同时会降低运算速度。
根据是否有符号可以分为:
有符号(signed,默认),无符号(unsigned)-目的:
扩大表示范围,有些情况只需要用正整数。
有符号整型数的存储单元的最高位是符号位(0:
正、1:
负),其余为数值位。
无符号整型
数的存储单元的全部二进制位用于存放数值本身而不包含符号。
归纳起来可以用6种整型变量:
有符号基本整型
:
[signed]int
有符号短整型
:
[signed]short[int]
有符号长整型
:
[signed]long[int]
无符号基本整型
:
unsigned[int]
无符号短整型:
unsignedshort[int]
无符号长整型:
unsignedlong[int]
例子:
保存整数13的各种整型数据类型。
/
符号St—>
0:
0
00
00
00
00
00
11
0L
int盘
short型
o|o
00
00
00
00
co
11
01
00
00
00
00
00
00loo0000000011吋long型
'oo
00
00
00
unsignedint挺
00
00
00
00
00
00
11
01
Lin$ignbdshort型
00
00
00
00
00
0000
co
00|0000&0&0001101叩血鷲矶
保存整软J3的各种整型变量
C标准没有具体规定上面数据类型所占用的字节数,只要求
short型不长于int型。
具体如何实现,由各计算机系统自行决定。
如微机上short,int
16位,而long是32位;VAX750机,int,long都是32位,而short是16位。
IT据恳存
E
IBMPCPDP-11
1
VAX-11
1
Honeywell
1
IBM370
int
isie
32
32
■haft
1016
16
35
16
long
32黠
32
se
32
utudgxMdInt
161G
32
36
处
umi^rMdibon
ieie
IS
36
16
uflilgiwdIon*
32龍
32
se
32
以IBMPC为例.数的范围如表£2所示.
所占位数
戟的柜蜃
16
-32768—32767
即-吵〜⑴“一门
ihort[in叮
16
-32768-32767
”却・一1)
long[in叮
32
-21174836<8—2147J83647
卿_叫&7
unsigned[tut]
ie
£〜弱碎5
・po〜4皿士1)
unaigDodshort
16
0—65535
即0~(2'*-1)
uMd*n«iIqt>b
32
0—^29^967235
即(护一1>
4、整型变量的定义
格式:
数据类型名变量名表;
例如:
main()
{
inta,b,c,d;
unsignedu;
a=12;b=-24;u=10;
c=a+u;d=b+u;
printf(“%d,%nd”,c,d);
}
说明:
(1)变量定义时,可以说明多个相同类型的变量。
各个变量用“,”分隔。
类型说明与变量名之间至少有一个空格间隔。
(2)最后一个变量名之后必须用“;”结尾。
(3)变量说明必须在变量使用之前。
(4)可以在定义变量的同时,对变量进行初始化。
例2-2:
变量初始化
main()
{
inta=3,b=5;
printf("a+b=%d\n",a+b);
}
5、整型数据的溢出
整型数最大允许值+1,最小允许值-1,会出现什么情况?
32767+1=-32768;-32768-1=32767。
例2-2a:
整型数据的溢出
main()
{
inta,b;
a=32767;
b=a+1;
printf("\na=%d,a+1=%d\n",a,b);
a=-32768;
b=a-1;
printf("\na=%d,a-1=%d\n",a,b);
getch();
}
a=32767,a+1=-32768
a=-32768,a-1=32767
超出范围就发生“溢出”,运行时不报错。
1、4实型数据
1、4、1实型常量的表示方法
实数(浮点数)有两种表示形式:
1、十进制小数形式。
由数字,小数点组成(必须有小数点)。
例如:
.123、123.、123.0、0.0
2、指数形式。
格式:
aEn。
例如:
123e3、123E3都是实数的合法表示。
1)字母e或E之前必须有数字,e后面的指数必须为整数。
例如:
e3、2.1e3.5、.e3、e都不是合法的指数形式。
2)规范化的指数形式。
在字母e或E之前的小数部分,小数点左边应当有且只能有一位
非0数字。
用指数形式输出时,是按规范化的指数形式输出的。
例如:
2.3478e2、3.0999E5、6.46832e12都属于规范化的指数形式。
3)实型常量都是双精度,如果要指定它为单精度,可以加后缀f(实型数据类型参看实型
变量部分说明)。
1、4、2实型变量
1、实型数据在内存中的存放形式
一个实型数据一般在内存中占4个字节(32位)。
与整数存储方式不同,实型数据是按照指
数形式存储的。
系统将实型数据分为小数部分和指数部分,分别存放。
实型数据存放的示意
+
*314159
1
数符小數部分扌鐵
III
1,314159x1013.14150
图。
标准C没有规定用多少位表示小数,多少位表示指数部分,由C编译系统自定。
例如,很多
编译系统以24位表示小数部分,8位表示指数部分。
小数部分占的位数多,实型数据的有效数字多,精度高;指数部分占的位数多,则表示的数值范围大。
2、实型变量的分类
实型变量分为:
单精度(float)、双精度(double)、长双精度(Iongdouble)。
ANSIC没有规定每种数据类型的长度、精度和数值范围。
表3.2列出微机上常用的C编译系
统的情况,不同的系统会有差异。
表3.2
类型
比特数
有效数字
数值范围
float
32
6-7
-3.4x10+38-
-3.4x10+38
double
64
15-16
-1.7x10+308
〜1.7x10+308
longdouble
128
18-19
-1.2x10+4932
〜1.2x10+4932
对于每一个实型变量也都应该先定义后使用。
如:
floatx,y;doublez;longdoublet;
3、实型数据的舍入误差(对比:
整型数据的溢出)实型变量是用有限的存储单元存储的,因此提供的有效数字是有限的,在有效位以外的数字将被舍去,由此可能会产生一些误差。
例2-3a:
实型数据的舍入误差(实型变量只能保证7位有效数字,后面的数字无意义)main()
{
floata,b;
a=123456.789e5;
b=a+20;
printf("a=%f,b=%f\n",a,b);
printf("a=%e,b=%e\n",a,b);
}
a=12345678848.000000,b=12345678848.000000a=1.23457e+10,b=1.23457e+10
结论:
由于实数存在舍入误差,使用时要注意:
(a)不要试图用一个实数精确表示一个大整数,记住:
浮点数是不精确的。
(b)实数一般不判断“相等”,而是判断接近或近似。
(c)避免直接将一个很大的实数与一个很小的实数相加、相减,否则会“丢失”小的数。
(d)根据要求选择单精度、双精度。
例2-4:
根据精度要求,选择实数类型
main()
{
floata;doubleb;
a=33333.33333;
b=33333.3333333333;
printf("a=%f,b=%f\n",a,b);
}
1、4、3实型常量的类型
1、许多C编译系统将实型常量作为双精度实数来处理,这样可以保证较高的精度,缺点
是运算速度降低。
在实数的后面加字符f或F,如1.65f、654.87F,使编译系统按单精度处理实数。
2、实型常量可以赋值给一个float、double、longdouble型变量。
根据变量的类型截取实型常量中相应的有效数字。
1、5字符型数据
1、5、1字符常量
字符常量是用单引号(‘')括起来的一个字符。
字符常量主要用下面几种形式表示:
$'
1、可显示的字符常量直接用单引号括起来,如,'a'、'x'、'D'、
等都是字符常量。
2、所有字符常量(包括可以显示的、不可显示的)均可以使用字符的转义表示法表示
(ASCII码表示)。
转义表示格式:
‘\ddd'或‘\xhh'(其中ddd,hh是字符的ASCII码,ddd八进制、hh十六进制)。
注意:
不可写成‘\0xhh'或‘\0ddd'(整数)。
3、
预先定义的一部分常用的转义字符。
如‘\n'-换行,‘\t'-水平制表。
宇符形式
功能
换行(将也曲柱王仍到T"行fl■块)
¥
橫向跳格(即臓到下一个输岀医}(水半*城」'
\v
竖向跳格
\b
退洛(将蚩倉垃霍移到灯一列)
V
回丰1常習前住多到艮荷升头k
\f
违纸换页|埒当4T位藍绞为下更开此丨
\\
反斛社字希
y
单引号dft号)字蒂
Vldd
1到3览8进制裁所代哀的字符
1到£也也进制散所代套的字符
例2-5:
(P.15.)分析数据的格式输出。
注意:
\b,\t对输出的控制作用。
例2-6:
(P.16.)分析数据的格式输出。
注意:
在打印机打印和在显示器上输出的不同效果。
打印机打印过的地方可以永久保留,显示器不能在同一个位置只能显示最后输出的字符。
1、5、2字符变量
字符型变量是用来存放字符数据,同时只能存放一个字符。
所有编译系统都规定以一个字节来存放一个字符,或者说,一个字符变量在内存中占一个字节。
1、5、3字符数据在内存中的存储形式及其使用
字符魏据在內存中朗存储形式
字符数据在内存中的存储形式:
以字符的ASCII码,以二进制形式存放,占用1个字节。
可以看出字符数据以ASCII码存储的形式与整数的存储形式类似,这使得字符型数据和整型数据之间可以通用(当作整型量)。
具体表现为:
1、可以将整型量赋值给字符变量,也可以将字符量赋值给整型变量。
2、可以对字符数据进行算术运算,相当于对它们的ASCII码进行算术运算。
3、一个字符数据既可以以字符形式输出(ASCII码对应的字符),也可以以整数形式输
出(直接输出ASCII码)。
注意:
尽管字符型数据和整型数据之间可以通用,但是字符型只占1个字节,即如果作为整数
使用范围0-255(无符号)-128-127(有符号)。
例2-7a:
给字符变量赋以整数(字符型、整型数据通用)
main()/*字符’a'的各种表达方法*/
{
charc1='a';
charc2='\x61';/*note:
'\x..','\...'*/
charc3='\141';
charc4=97;
charc5=0x61;/*note:
0x..,0...*/
charc6=0141;
printf("\nc1=%c,c2=%c,c3=%c,c4=%c,c5=%c,c6=%c\n",c1,c2,c3,c4,c5,c6);
printf("c1=%d,c2=%d,c3=%d,c4=%d,c5=%d,c6=%d\n",c1,c2,c3,c4,c5,c6);
getch();
c1=a,c2=a,c3=a,c4=a,c5=a,c6=a
c1=97,c2=97,c3=97,c4=97,c5=97,c6=97
过程:
整型数=>机内表示(两个字节)=>取低8位赋值给字符变量例2-8a:
大小写字母的转换(ASCII码表:
小写字母比对应的大写字母的ASCII码大32,本例还可以看出允许字符数据与整数直接进行算术运算,运算时字符数据用ASCII码值参与运算)main()
{
charc1,c2,c3;
c1='a';
c2='b';
c1=c1-32;
c2=c2-32;
c3=130;
printf("\n%c%c%c\n",c1,c2,c3);
printf("%d%d%d\n",c1,c2,c3);
getch();
}
AB?
6566-126
6566-126
1、5、4字符串常量
字符串变量:
是一对双引号(“”)括起来的字符序列。
例如:
“Howdowyoudo?
”,“CHINA”,“a”,“$123.45”.
1、区分字符常量与字符串常量。
如“a”和‘a'。
C语言规定:
在每个字符串的结尾加一个“字符串结束标志”,以便系统据此判断字符串是否
结束。
C规定以‘\0'(ASCII码为0的字符)作为字符串结束标志。
如:
“CHINA”在内存中的存储应当是:
(长度=6)
C
H
I
N
A
'\0
2、不能将字符串赋给字符变量。
3、C语言没有专门的字符串变量,如果想将一个字符串存放在变量中,可以使用字符数
组。
即用一个字符数组来存放一个字符串,数组中每一个元素存放一个字符。
1、6变量赋初值
例如:
可以只对定义的一部分变量赋初值。
inta,b=2,c=5;/*指定a,b,c为整型变量,只对b、c初始化,b的初值为2,c的初值为5*/
初始化不是在编译阶段完成的,而是在程序运行时执行本函数时赋予初值的,相当于有一个赋
值语句。
inta=3;
相当于:
inta;
a=3;
1、7各类数值型数据(整型、实型、字符型)的混合运算
整型(包括int,short,long)和实型(包括float,double)数据可以混合运算,另外字符型数据和整型数据可以通用,因此,整型、实型、字符型数据之间可以混合运算。
例如:
表达式10+'a'+1.5-8765.1234*'b'是合法的。
在进行运算时,不同类型的数据先转换成同一类型,然后进行计算,转换的方法有两种:
自动转换(隐式转换);强制转换。
1、自动动转换(隐式转换)
自动转换发生在不同类型数据进行混合运算时,由编译系统自动完成。
转换规则:
(参看
图2-1)
(1)类型不同,先转换为同一类型,然后进行运算。
(2)图中纵向的箭头表示当运算对象为不同类型时转换的方向。
可以看到箭头由低级别数据类型指向高级别数据类型,即数据总是由低级别向高级别转换。
即按数据长度增加的方向进行,保证精度不降低。
(3)图中横向向左的箭头表示必定的转换(不必考虑其它运算对象)。
如字符数据参与运
算必定转化为整数,float型数据在运算时一律先转换为双精度型,以提高运算精度
(即使是两个float型数据相加,也先都转换为double型,然后再相加)。
(4)赋值运算,如果赋值号“=”两边的数据类型不同,赋值号右边的类型转换为左边的
类型。
这种转换是截断型的转换,不会四舍五入。
(教材P19倒数18行“四舍五
入”有异议?
)
高I
doublr4floatflangt
unsigned
丰
低
int4char,short
2、强制转换
强制转换是通过类型转换运算来实现。
一般形式:
(类型说明符)表达式
功能:
把表达式的结果强制转换为类型说明符所表示的类型。
例如:
(int)a将a的结果强制转换为整型量。
(int)(x+y)将x+y的结果强制转换为整型量。
(float)a+b将a的内容强制转换为浮点数,再与b相加。
说明:
(1)类型说明和表达式都需要加括号(单个变量可以不加括号)
(2)无论隐式转换,强制转换都是临时转换,不改变数据本身的类型和值。
例2-9:
强制类型转换(P.20)
main()
{
floatf=5.75;
printf("(int)f=%d\n",(int)f);/*将f的结果强制转换为整型,输出*/
printf("f=%f\n",f);/*输出f的值*/
}
结果:
(int)f=5f=5.750000
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- BS 系统 界面设计 开发 详解
![提示](https://static.bdocx.com/images/bang_tan.gif)