c语言定义字符类型?

如题所述

c语言字符类型可以表?单个字符,字符类型是char,char是1个字节(可以存字母或者数字),多个字符称为字符串,在C语?中使?char数组表?字符串,数组不是基本数据类型,?是构造类型char数组可能包含一个字符串.char*可以指向一个字符串.它们都不是字符串.如果您愿意,可以定义typedefchar*string;/*notrecommended*/


C语言中的字符类型

C语言中的字符型数据分为字符和字符串数据两类。**字符数据是指由单引号括起来的单个字符,**如‘a’、‘2’、‘&’等;字符串数据是指由双引号括起来的一串字符序列,如“good”、“0132”、“a”等。

1、基本类型定义

类型说明符:char

2、字符型数据的存储与取值范围

字符型数据的取值范围为ASCII码字符集中的可打印字符。一个字符型数据的存储占1个字节,存储时实际上存储的是对应字符的ASCII码值(即一个整数值)。


ASCII编码(AmericanStandardcodeforinformationinterchage)美国信息交换标准代码:


ASCII码使用指定的7位或8位二进制数组合来表示128或256种可能的字符。标准ASCII码也叫基础ASCII码,使用7位二进制数来表示所有的大写和小写字母,数字0到9、标点符号,以及在美式英语中使用的特殊控制字符。

其中:

0~31及127(共33个)是控制字符或通信专用字符(其余为可显示字符),如控制符:LF(换行)、CR(回车)、FF(换页)、DEL(删除)、BS(退格)、BEL(响铃)等;通信专用字符:SOH(文头)、EOT(文尾)、ACK(确认)等;ASCII值为8、9、10和13分别转换为退格、制表、换行和回车字符。它们并没有特定的图形显示,但会依不同的应用程序,而对文本显示有不同的影响。


32~126(共95个)是字符(32是空格),其中48-57为0到9十个阿拉伯数字。


65-90为26个大写英文字母,97-122号为26个小写英文字母,其余为一些标点符号、运算符号等。


同时还要注意,在标准ASCII中,其最高位(b7)用作奇偶校验位。所谓奇偶校验,是指在代码传送过程中用来检验是否出现错误的一种方法,一般分奇校验和偶校验两种。奇校验规定:正确的代码一个字节中1的个数必须是奇数,若非奇数,则在最高位b7添1;偶校验规定:正确的代码一个字节中1的个数必须是偶数,若非偶数,则在最高位b7添1。


后128个称为扩展ASCII码。许多基于x86的系统都支持使用扩展(或"高")ASCII。扩展ASCII码允许将每个字符的第8位用于确定附加的128个特殊符号字符、外来语字母和图形符号。


3、字符型数据的表示方法

字符型数据在计算机中存储的是字符的ASCII码值的二进制形式,一个字符数据的存储占用1个字节。**因为ASCII码在形式上就是0~255之间的整数,因此C语言中字符型数和整型数可以通用。**例如,字符’a’的ASCII码值用二进制表示是1100001,用十进制表示是97,字符‘a’的存储形式实际上就是一个整型数97,所以它可以直接与整型数进行运算,可以与整型变量相互赋值,也可以将字符型数据以字符或整数两种形式输出。以字符形式输出时,先将ASCII码值转换为相应的字符,然后再输出;以整数形式输出时,直接将ASCII码值作为输出。


C语言在语法上共提供了三种字符类型,分别是char、signedchar、unsignedchar,二进制长度均为8位,值域分别是

-128-127、-128-127、0~255。若不指定字符变量的类型,则默认为signedchar类型。因为字符型数据主要是用来处理字符的,故对它不能用long或short类型修饰符修饰。


字符数据:

用单引号括起来的单个字符数。如‘A’,‘%’,‘:’,‘9’等,而‘12’或‘abc’是不合法的字符。

字符串数据:

用双引号括起来的单个或一串字符数,如“good”、“0132”、“w1”、“a”等。注意,“a”是字符串而不是字符数。

为了便于C程序判断字符串是否结束,系统对每个字符串数存储时都在末尾添加一个结束标志——ASCII码值为0的空操作符‘’,

它既不引起任何动作也不会显示输出,所以存出一个字符串的字节数应该是字符串的长度加1。


你不能在C中创建string类型的变量,因为“string”不是一个类型.

根据定义,“字符串”是“由第一个空字符终止并包括第一个空字符的连续字符序列”.它不是数据类型,而是数据格式.

char数组可能包含一个字符串.char*可以指向一个字符串.它们都不是字符串.

如果您愿意,可以定义


1、字符类型名称是char

2、字符类型里一共包含256个整数,每个整数可以代表一个字符(例如’d’,’&’等),这些整数和字符是完全可以互相替代的

3、ASCII码表里列出所有整数和字符的对应关系

‘a’97

‘A’65

‘0’48

4、所有小写英文字母在ASCII码表里是连续排列的,’a’对应的整数最小,’z’对应的整数最大

5、所有大写英文字母和阿拉伯数字字符也都符合这个规律

‘d’-‘a’等于‘D’-‘A’

‘d’-‘a’等于‘3’-‘0’等于3-0

6、所有字符数据被分成两组,每组128个,其中一组字符和整数之间的对应关系在所有计算机上都一样,这些字符对应的整数范围从0到127

7、另外一组字符和整数之间的对应关系在不同的计算机上可能不同,这些字符对应的整数范围可能从-128到-1也可能从128到255

‘’换行字符

‘’回车字符

‘’字符

‘”‘字符

‘”’“字符

8、短整数类型名称是short这个类型里包含了65536个不同的整数,其中一半是负数另外一半是非负数。这些数字以数字0为中心向两边扩展。

9、长整数类型名称是long这个类型里包含了2的32次方个不同的整数,其中一半是负数另外一半是非负数。这些数字以0为中心向两边扩展。

10、整数类型名称是int在我们的计算机上整数类型和长整数类型完全一样

11、以上类型都叫做有符号类型

12、每个有符号类型都有一个对应的无符号类型,无符号类型的名称是在有符号类型的名称前加unsigned(例如unsignedchar,unsignedint等)

13、每个无符号类型包含的数字个数和对应的有符号类型一样,只是不包含负数

14、所有整数相关数据类型所包含的数字范围是互相重叠并逐渐扩大的

15、程序中不带小数点的数字后加u表示这个数字的类型是无符号整数类型

16、C语言里使用浮点类型表示带小数点的数字

17、浮点类型分为单精度浮点类型和双精度浮点类型

18、双精度浮点类型可以记录更多小数点后面的数位

19、单精度浮点类型的名称是float

20、双精度浮点类型的名称是double

21、程序中带小数点的数字默认是双精度浮点类型的

22、如果在带小数点的数字后加f就表示数字的类型是单精度浮点类型

23、C语言里可以创建新的数据类型,这些创建的数据类型叫复合数据类型,复合数据类型需要先创建然后才能使用

24、C99规范里引入布尔类型这个类型里包含两个整数,其中0叫做假,1叫做真真和假都叫做布尔值

25、C语言里任何整数都可以当作布尔值使用,0当布尔值使用的时候是假,所有其他整数当布尔值使用的时候都是真

26、程序中不需要使用布尔类型,直接把整数当布尔值使用就可以了

27、数据类型和占位符的对应关系

1、char和unsignedchar%c

2、short%hd

3、unsignedshort%hu

4、int%d

5、unsignedint%u

6、long%ld

7、unsignedlong%lu

8、float%f或%g

9、double%lf或%lg


%f和%lf会保留小数点后面无效的0,%g和%lg不会保留

28、不同类型存储区的一个主要区别就是它们所包含的字节个数不同

29、sizeof关键字可以用来计算一个存储区里包含的字节个数

char和unsignedchar1个字节

short和unsignedshort2个字节

int和unsignedint4个字节

long和unsignedlong4个字节

float4个字节

double8个字节

30、可以当数字使用的内容都可以写在sizeof关键字后面的小括号里

31、sizeof关键字小括号里对任何存储区内容的修改不会真正发生

/*

*sizeof关键字演示

**/

#include<stdio.h>

intmain(){

intnum=0;

printf("sizeof(int)是%d",sizeof(int));

printf("sizeof(num)是%d",sizeof(num));

printf("sizeof(6+7)是%d",sizeof(6+7));

sizeof(num=10);

printf("num是%d",num);

return0;

}


温馨提示:答案为网友推荐,仅供参考

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网