C语言的无符号数据类型转换

时间:2023年01月13日

/

来源:酱饼酱香鸭脖子

/

编辑:本站小编

收藏本文

下载本文

下面是小编为大家整理的C语言的无符号数据类型转换,本文共6篇,供大家参考借鉴,希望可以帮助到有需要的朋友。本文原稿由网友“酱饼酱香鸭脖子”提供。

篇1:C语言的无符号数据类型转换

从网络中读取C的无符号int,short,byte字节数组,相应转换成java的long,char,short

short anUnsignedByte = 0;

char anUnsignedShort = 0;

long anUnsignedInt = 0;

int firstByte = 0;

int secondByte = 0;

int thirdByte = 0;

int fourthByte = 0;

byte buf[] = getNetData;//如:读网络字节数据

int index = 0;

firstByte = (0x000000FF & ((int)buf[index]))

index++;

anUnsignedByte = (short)firstByte;

firstByte = (0x000000FF & ((int)buf[index]))

secondByte = (0x000000FF & ((int)buf[index+1]))

index = index+2;

anUnsignedShort = (char) (firstByte << 8 | secondByte);

firstByte = (0x000000FF & ((int)buf[index]))

secondByte = (0x000000FF & ((int)buf[index+1]))

thirdByte = (0x000000FF & ((int)buf[index+2]))

fourthByte = (0x000000FF & ((int)buf[index+3]))

index = index+4;

anUnsignedInt = ((long) (firstByte << 24

| secondByte << 16

| thirdByte << 8

| fourthByte))

& 0xFFFFFFFFL;

篇2:c语言:算数转换举例

算数转换程序1:#includeint main(){char c1 = 128;char c2 = 1;char c3 = c1+c2;//0111 1111//0000 0001//1000 0000,表示-127printf(“%d\\n”,c3);return 0;}结果:-127请按任意键继续. . .程序2:#includeint main(){char c1 = 12;char c2 = 1;char c3 = c1+c2;//0000 1100//0000 0001//0000 1101printf(“%d\\n”,c3);return 0;}结果:13请按任意键继续. . .

篇3:C语言初学者入门讲座2数据类型(2)

字符型量

字符型量包括字符常量和字符变量,

字符常量

字符常量是用单引号括起来的一个字符。例如'a','b','=','+','?'都是合法字符常量。在C语言中,字符常量有以下特点:

1.字符常量只能用单引号括起来,不能用双引号或其它括号。

2.字符常量只能是单个字符,不能是字符串。

3.字符可以是字符集中任意字符。但数字被定义为字符型之后就不能参与数值运算。如'5'和5 是不同的。'5'是字符常量,不能参与运算。

转义字符

转义字符是一种特殊的字符常量。转义字符以反斜线“\\”开头,后跟一个或几个字符。转义字符具有特定的含义,不同于字符原有的意义,故称“转义”字符。例如,在前面各例题printf函数的格式串中用到的“\\n”就是一个转义字符,其意义是“回车换行”。转义字符主要用来表示那些用一般字符不便于表示的控制代码。

常用的转义字符及其含义

转义字符 转义字符的意义

\\n 回车换行

\\t 横向跳到下一制表位置

\\v 竖向跳格

\\b 退格

\\r 回车

\\f 走纸换页

\\\\ 反斜线符“\\”

\\' 单引号符

\\a 鸣铃

\\ddd 1~3位八进制数所代表的字符

\\xhh 1~2位十六进制数所代表的字符

广义地讲,C语言字符集中的任何一个字符均可用转义字符来表示。表2.2中的\\ddd和\\xhh正是为此而提出的。ddd和hh分别为八进制和十六进制的ASCII代码。如\\101表示字?quot;A“ ,\\102表示字母”B“,\\134表示反斜线,\\XOA表示换行等。转义字符的使用。

void main

{

int a,b,c;

a=5; b=6; c=7;

printf(”%d\\n\\t%d %d\\n %d %d\\t\\b%d\\n“,a,b,c,a,b,c);

}

此程序练习转义字符的使用:

a、b、c为整数 5->a,6->b,7->c

调用printf显示程序运行结果:

printf(”%d\\n\\t%d %d\\n %d %d\\t\\b%d\\n“,a,b,c,a,b,c);

程序在第一列输出a值5之后就是“\\n”,故回车换行;接着又是“\\t”,于是跳到下一制表位置(设制表位置间隔为8),再输出b值6;空二格再输出c 值7后又是”\\n“,因此再回车换行;再空二格之后又输出a值5;再空三格又输出b的值6;再次后”\\t“跳到下一制表位置(与上一行的6 对齐),但下一转义字符“\\b”又使退回一格,故紧挨着6再输出c值7。

字符变量

字符变量的取值是字符常量,即单个字符。字符变量的类型说明符是char。字符变量类型说明的格式和书写规则都与整型变量相同。

例如:

char a,b; 每个字符变量被分配一个字节的内存空间,因此只能存放一个字符。字符值是以ASCII码的形式存放在变量的内存单元之中的。如x的

十进制ASCII码是120,y的十进制ASCII码是121。对字符变量a,b赋予'x'和'y'值: a='x';b='y';实际上是在a,b两个单元内存放120和121的二进制代码:

a 0 1 1 1 1 0 0 0

b 0 1 1 1 1 0 0 1

所以也可以把它们看成是整型量。 C语言允许对整型变量赋以字符值,也允许对字符变量赋以整型值。在输出时, 允许把字符变量按整型量输出,也允许把整型量按字符量输出。 整型量为二字节量,字符量为单字节量,当整型量按字符型量处理时, 只有低八位字节参与处理。

main(){

char a,b;

a=120;

b=121;

printf(”%c,%c\\n%d,%d\\n“,a,b,a,b);

}

a ■ b ■

a <-- 120

b <--- 121

显示程序结果 char a,b;

a=120;

b=121;

本程序中说明a,b为字符型,但在赋值语句中赋以整型值。从结果看,a,b值的输出形式取决于printf函数格式串中的格式符,当格式符为”c“时,对应输出的变量值为字符,当格式符为”d“时,对应输出的变量值为整数。

void main(){

char a,b;

a='x';

b='y';

a=a-32;

b=b-32;

printf(”%c,%c\\n%d,%d\\n“,a,b,a,b);

}

a,b被说明为字符变量并赋予字符值

把小写字母换成大写字母

以整型和字符型输出

本例中,a,b被说明为字符变量并赋予字符值,C语言允许字符变量参与数值运算,即用字符的ASCII 码参与运算。由于大小写字母的ASCII 码相差32,因此运算后把小写字母换成大写字母。然后分别以整型和字符型输出。

[Practice] //charint a=49;

char b;

char d;

b=a+10;

d=a+b;'Vtable

a,2,49

b,1,随机

d,1,随机

of Vtable

'Vupdate

1,49

2,随机

3,随机

2,';'

3,'l'

of Vupdate

of Practice

[Practice] //char c1,c2;

c1='a';c2='b';

c1=c1-32;c2=c2-32;'Vtable

c1,1,随机

c2,1,随机

of Vtable

'Vupdate

1,随机;2,随机

1,'a';2,'b'

1,'A';2,'B'

of Vupdate

of Practice

字符型量

字符型量包括字符常量和字符变量,

字符常量

字符常量是用单引号括起来的一个字符。例如'a','b','=','+','?'都是合法字符常量。在C语言中,字符常量有以下特点:

1.字符常量只能用单引号括起来,不能用双引号或其它括号。

2.字符常量只能是单个字符,不能是字符串。

3.字符可以是字符集中任意字符。但数字被定义为字符型之后就不能参与数值运算。如'5'和5 是不同的。'5'是字符常量,不能参与运算。

转义字符

转义字符是一种特殊的字符常量。转义字符以反斜线”\\“开头,后跟一个或几个字符。转义字符具有特定的含义,不同于字符原有的意义,故称“转义”字符。例如,在前面各例题printf函数的格式串中用到的“\\n”就是一个转义字符,其意义是“回车换行”。转义字符主要用来表示那些用一般字符不便于表示的控制代码。

常用的转义字符及其含义

转义字符 转义字符的意义

\\n 回车换行

\\t 横向跳到下一制表位置

\\v 竖向跳格

\\b 退格

\\r 回车

\\f 走纸换页

\\\\ 反斜线符”\\“

\\' 单引号符

\\a 鸣铃

\\ddd 1~3位八进制数所代表的字符

\\xhh 1~2位十六进制数所代表的字符

广义地讲,C语言字符集中的任何一个字符均可用转义字符来表示。表2.2中的\\ddd和\\xhh正是为此而提出的。ddd和hh分别为八进制和十六进制的ASCII代码。如\\101表示字?quot;A” ,\\102表示字母“B”,\\134表示反斜线,\\XOA表示换行等。转义字符的使用。

void main()

{

int a,b,c;

a=5; b=6; c=7;

printf(“%d\\n\\t%d %d\\n %d %d\\t\\b%d\\n”,a,b,c,a,b,c);

}

此程序练习转义字符的使用:

a、b、c为整数 5->a,6->b,7->c

调用printf显示程序运行结果:

printf(“%d\\n\\t%d %d\\n %d %d\\t\\b%d\\n”,a,b,c,a,b,c);

程序在第一列输出a值5之后就是“\\n”,故回车换行;接着又是“\\t”,于是跳到下一制表位置(设制表位置间隔为8),再输出b值6;空二格再输出c 值7后又是“\\n”,因此再回车换行;再空二格之后又输出a值5;再空三格又输出b的值6;再次后“\\t”跳到下一制表位置(与上一行的6 对齐),但下一转义字符“\\b”又使退回一格,故紧挨着6再输出c值7。

字符变量

字符变量的取值是字符常量,即单个字符。字符变量的类型说明符是char。字符变量类型说明的格式和书写规则都与整型变量相同。

例如:

char a,b; 每个字符变量被分配一个字节的内存空间,因此只能存放一个字符。字符值是以ASCII码的形式存放在变量的内存单元之中的。如x的

十进制ASCII码是120,y的十进制ASCII码是121。对字符变量a,b赋予'x'和'y'值: a='x';b='y';实际上是在a,b两个单元内存放120和121的二进制代码:

a 0 1 1 1 1 0 0 0

b 0 1 1 1 1 0 0 1

所以也可以把它们看成是整型量。 C语言允许对整型变量赋以字符值,也允许对字符变量赋以整型值。在输出时, 允许把字符变量按整型量输出,也允许把整型量按字符量输出。 整型量为二字节量,字符量为单字节量,当整型量按字符型量处理时, 只有低八位字节参与处理。

main(){

char a,b;

a=120;

b=121;

printf(“%c,%c\\n%d,%d\\n”,a,b,a,b);

}

a ■ b ■

a <-- 120

b <--- 121

显示程序结果 char a,b;

a=120;

b=121;

本程序中说明a,b为字符型,但在赋值语句中赋以整型值。从结果看,a,b值的输出形式取决于printf函数格式串中的格式符,当格式符为“c”时,对应输出的变量值为字符,当格式符为“d”时,对应输出的变量值为整数。

void main(){

char a,b;

a='x';

b='y';

a=a-32;

b=b-32;

printf(“%c,%c\\n%d,%d\\n”,a,b,a,b);

}

a,b被说明为字符变量并赋予字符值

把小写字母换成大写字母

以整型和字符型输出

本例中,a,b被说明为字符变量并赋予字符值,C语言允许字符变量参与数值运算,即用字符的ASCII 码参与运算。由于大小写字母的ASCII 码相差32,因此运算后把小写字母换成大写字母。然后分别以整型和字符型输出。

[Practice] //charint a=49;

char b;

char d;

b=a+10;

d=a+b;'Vtable

a,2,49

b,1,随机

d,1,随机

of Vtable

'Vupdate

1,49

2,随机

3,随机

2,';'

3,'l'

of Vupdate

of Practice

[Practice] //char c1,c2;

c1='a';c2='b';

c1=c1-32;c2=c2-32;'Vtable

c1,1,随机

c2,1,随机

of Vtable

'Vupdate

1,随机;2,随机

1,'a';2,'b'

1,'A';2,'B'

of Vupdate

of Practice

收藏分享

篇4:C语言初学者入门讲座2数据类型(3)

基本运算符和表达式

运算符的种类、优先级和结合性

C语言中运算符和表达式数量之多, 在高级语言中是少见的,正是丰富的运算符和表达式使C语言功能十分完善。 这也是C语言的主要特点之一。

C语言的运算符不仅具有不同的优先级, 而且还有一个特点,就是它的结合性。在表达式中, 各运算量参与运算的先后顺序不仅要遵守运算符优先级别的规定,还要受运算符结合性的制约, 以便确定是自左向右进行运算还是自右向左进行运算。 这种结合性是其它高级语言的运算符所没有的,因此也增加了C语言的复杂性。

运算符的种类C语言的运算符可分为以下几类:

1.算术运算符

用于各类数值运算。包括加(+)、减(-)、乘(*)、除(/)、求余(或称模运算,%)、自增(++)、自减(--)共七种。

2.关系运算符

用于比较运算。包括大于(>)、小于(<)、等于(==)、大于等于(>=)、小于等于(<=)和不等于(!=)六种。

3.逻辑运算符

用于逻辑运算。包括与(&&)、或(||)、非(!)三种。

4.位操作运算符

参与运算的量,按二进制位进行运算。包括位与(&)、位或(|)、位非(~)、位异或(^)、左移(<<)、右移(>>)六种。

5.赋值运算符

用于赋值运算,分为简单赋值(=)、复合算术赋值(+=,-=,*=,/=,%=)和复合位运算赋值(&=,|=,^=,>>=,<<=)三类共十一种。

6.条件运算符

这是一个三目运算符,用于条件求值(?:)。

7.逗号运算符

用于把若干表达式组合成一个表达式(,)。

8.指针运算符

用于取内容(*)和取地址(&)二种运算。

9.求字节数运算符

用于计算数据类型所占的字节数(sizeof)。

10.特殊运算符

有括号(),下标[],成员(→,.)等几种。

优先级和结合性

C语言中,运算符的运算优先级共分为15级。1级最高,15级最低。在表达式中,优先级较高的先于优先级较低的进行运算。 而在一个运算量两侧的运算符优先级相同时, 则按运算符的结合性所规定的结合方向处理。C语言中各运算符的结合性分为两种,即左结合性(自左至右)和右结合性(自右至左)。例如算术运算符的结合性是自左至右,即先左后右。如有表达式x-y+z则y应先与“-”号结合, 执行x-y运算,然后再执行+z的运算。这种自左至右的结合方向就称为“左结合性”。而自右至左的结合方向称为“右结合性”。 最典型的右结合性运算符是赋值运算符。如x=y=z,由于“=”的右结合性,应先执行y=z再执行x=(y=z)运算。 C语言运算符中有不少为右结合性,应注意区别,以避免理解错误。

算术运算符和算术表达式基本的算术运算符

1.加法运算符“+”加法运算符为双目运算符,即应有两个量参与加法运算。如a+b,4+8等。具有右结合性。

2.减法运算符“-”减法运算符为双目运算符。但“-”也可作负值运算符,此时为单目运算,如-x,-5等具有左结合性。

3.乘法运算符“*”双目运算,具有左结合性。

4.除法运算符“/”双目运算具有左结合性。参与运算量均为整型时, 结果也为整型,舍去小数。如果运算量中有一个是实型,则结果为双精度实型。

void main(){

printf(“\\n\\n%d,%d\\n”,20/7,-20/7);

printf(“%f,%f\\n”,20.0/7,-20.0/7);

}

双目运算具有左结合性。参与运算量均为整型时, 结果也为整型,舍去小数。如果运算量中有一个是实型,则结果为双精度实型。

printf(“\\n\\n%d,%d\\n”,20/7,-20/7);

printf(“%f,%f\\n”,20.0/7,-20.0/7);

本例中,20/7,-20/7的结果均为整型,小数全部舍去。而20.0/7和-20.0/7由于有实数参与运算,因此结果也为实型。

5.求余运算符(模运算符)“%”双目运算,具有左结合性。要求参与运算的量均为整型。 求余运算的结果等于两数相除后的余数。

void main(){

printf(“%d\\n”,100%3);

}

双目运算,具有左结合性。求余运算符% 要求参与运算的量均为整型。本例输出100除以3所得的余数1。

自增1,自减1运算符

自增1运算符记为“++”,其功能是使变量的值自增1。自减1运算符记为“--”,其功能是使变量值自减1。自增1,自减1运算符均为单目运算,都具有右结合性。可有以下几种形式: ++i i自增1后再参与其它运算。--i i自减1后再参与其它运算。

i++ i参与运算后,i的值再自增1。

i-- i参与运算后,i的值再自减1。

在理解和使用上容易出错的是i++和i--。 特别是当它们出在较复杂的表达式或语句中时,常常难于弄清,因此应仔细分析。

void main(){

int i=8;

printf(“%d\\n”,++i);

printf(“%d\\n”,--i);

printf(“%d\\n”,i++);

printf(“%d\\n”,i--);

printf(“%d\\n”,-i++);

printf(“%d\\n”,-i--);

} i<--8

i<--i+1

i<--i-1

i<--i+1

i<--i-1

i<--i+1

i<--i-1 int i=8;

printf(“%d\\n”,++i);

printf(“%d\\n”,--i);

printf(“%d\\n”,i++);

printf(“%d\\n”,i--);

printf(“%d\\n”,-i++);

printf(“%d\\n”,-i--);

i的初值为8

第2行i加1后输出故为9;

第3行减1后输出故为8;

第4行输出i为8之后再加1(为9);

第5行输出i为9之后再减1(为8) ;

第6行输出-8之后再加1(为9);

第7行输出-9之后再减1(为8)

void main(){

int i=5,j=5,p,q;

p=(i++)+(i++)+(i++);

q=(++j)+(++j)+(++j);

printf(“%d,%d,%d,%d”,p,q,i,j);

}

i<--5,j<--5,p<--0,q<--0

i+i+i--->p,i+1-->i,i+1-->i,i+1-->i

j+1->j,j+1->j,j+1->j,j+j+j->q int i=5,j=5,p,q;

p=(i++)+(i++)+(i++);

q=(++j)+(++j)+(++j);

这个程序中,对P=(i++)+(i++)+(i++)应理解为三个i相加,故P值为15。然后i再自增1三次相当于加3故i的最后值为8。而对于q 的值则不然,q=(++j)+(++j)+(++j)应理解为q先自增1,再参与运算,由于q自增1三次后值为8,三个8相加的和为24,j的最后值仍为8。算术表达式表达式是由常量、变量、函数和运算符组合起来的式子。 一个表达式有一个值及其类型, 它们等于计算表达式所得结果的值和类型。表达式求值按运算符的优先级和结合性规定的顺序进行。 单个的常量、变量、函数可以看作是表达式的特例。

算术表达式

是由算术运算符和括号连接起来的式子, 以下是算术表达式的例子:

a+b (a*2)/c (x+r)*8-(a+b)/7 ++i sin(x)+sin(y) (++i)-(j++)+(k--)

赋值运算符和赋值表达式

简单赋值运算符和表达式,简单赋值运算符记为“=”。由“= ”连接的式子称为赋值表达式。其一般形式为: 变量=表达式 例如:

x=a+b

w=sin(a)+sin(b)

y=i+++--j 赋值表达式的功能是计算表达式的值再赋予左边的变量。

赋值运算符具有右结合性。因此:

a=b=c=5

可理解为

a=(b=(c=5))

在其它高级语言中,赋值构成了一个语句,称为赋值语句,

而在C中,把“=”定义为运算符,从而组成赋值表达式。凡是表达式可以出现的地方均可出现赋值表达式。例如,式子x=(a=5)+(b=8)是合法的。它的意义是把5赋予a,8赋予b,再把a,b相加,和赋予x ,故x应等于13。

在C语言中也可以组成赋值语句,按照C语言规定, 任何表达式在其未尾加上分号就构成为语句。因此如x=8;a=b=c=5;都是赋值语句,在前面各例中我们已大量使用过了。

如果赋值运算符两边的数据类型不相同, 系统将自动进行类型转换,即把赋值号右边的类型换成左边的类型。具体规定如下:

1.实型赋予整型,舍去小数部分。前面的例2.9已经说明了这种情况。

2.整型赋予实型,数值不变,但将以浮点形式存放, 即增加小数部分(小数部分的值为0)。

3.字符型赋予整型,由于字符型为一个字节, 而整型为二个字节,故将字符的ASCII码值放到整型量的低八位中,高八位为0。

4.整型赋予字符型,只把低八位赋予字符量。

void main(){

int a,b=322;

float x,y=8.88;

char c1='k',c2;

a=y;

x=b;

a=c1;

c2=b;

printf(“%d,%f,%d,%c”,a,x,a,c2);

}

int a,b=322;

float x,y=8.88;

char c1='k',c2;

printf(“%d,%f,%d,%c”,a=y,x=b,a=c1,c2=b);

本例表明了上述赋值运算中类型转换的规则。a为整型,赋予实型量y值888后只取整数8。x为实型,赋予整型量b值322, 后增加了小数部分。字符型量c1赋予a变为整型,整型量b赋予c2 后取其低八位成为字符型(b的低八位为01000010,即十进制66,按ASCII码对应于字符B)。

复合赋值符及表达式

在赋值符“=”之前加上其它二目运算符可构成复合赋值符。如

+=,-=,*=,/=,%=,<<=,>>=,&=,^=,|=。 构成复合赋值表达式的一般形式为: 变量 双目运算符=表达式 它等效于 变量=变量 运算符 表达式 例如:

a+=5 等价于a=a+5

x*=y+7 等价于x=x*(y+7)

r%=p 等价于r=r%p

复合赋值符这种写法,对初学者可能不习惯, 但十分有利于编译处理,能提高编译效率并产生质量较高的目标代码。逗号运算符和逗号表达式在

逗号运算符

C语言中逗号“,”也是一种运算符,称为逗号运算符。 其功能是把两个表达式连接起来组成一个表达式, 称为逗号表达式。

其一般形式为: 表达式1,表达式2 其求值过程是分别求两个表达式的值,并以表达式2的值作为整个逗号表达式的值。

void main(){

int a=2,b=4,c=6,x,y;

y=(x=a+b),(b+c);

printf(“y=%d,x=%d”,y,x);

}

a<--2,b<--4,c<--6,x<--0,y<--0

x<--a+b,y<---b+c

本例中,y等于整个逗号表达式的值,也就是表达式2的值,x是第一个表达式的值。对于逗号表达式还要说明两点:

1.逗号表达式一般形式中的表达式1和表达式2 也可以又是逗号表达式。例如: 表达式1,(表达式2,表达式3) 形成了嵌套情形。因此可以把逗号表达式扩展为以下形式: 表达式1,表达式2,…表达式n 整个逗号表达式的值等于表达式n的值。

2.程序中使用逗号表达式,通常是要分别求逗号表达式内各表达式的值,并不一定要求整个逗号表达式的值。

3.并不是在所有出现逗号的地方都组成逗号表达式,如在变量说明中,函数参数表中逗号只是用作各变量之间的间隔符。

[Practice] //arithmeticint a,b,c;

float d;

a=11;

b=235;

c=a+b-a*b;

d=(float)c/(float)a;

a=c/a;'Vtable

a,2,0

b,2,0

c,2,0

d,4,0.0

of Vtable

'Vupdate

1,0;2,0;3,0

4,0.0

1,11

2,235

3,-2339

4,-212.636368

1,-212

of Vupdate

of Practice

[Practice] //1int a,b,c1,c2;

a=25;

b=3243;

c1=b/a;

c2=b%a;'Vtable

a,2,0

b,2,0

c1,2,0

c2,2,0

of Vtable

'Vupdate

1,0;2,0;3,0;4,0

1,25

2,3243

3,129

4,18

of Vupdate

of Practice

[Practice] //1int a,b,c;

a=25;

b=40;

c=a+b,c+35;'Vtable

a,2,0

b,2,0

c,2,0

of Vtable

'Vupdate

1,0;2,0;3,0

1,25

2,40

3,65

of Vupdate

of Practice

小结

1.C的数据类型

基本类型,构造类型,指针类型,空类型

2.基本类型的分类及特点

类型说明符 字节 数值范围

字符型char 1 C字符集

基本整型int 2 -32768~32767

短整型short int 2 -32768~32767

长整型 long int 4 -214783648~214783647

无符号型 unsigned 2 0~65535

无符号长整型 unsigned long 4 0~4294967295

单精度实型 float 4 3/4E-38~3/4E+38

双精度实型 double 8 1/7E-308~1/7E+308

3.常量后缀

L或l 长整型

U或u 无符号数

F或f 浮点数

4.常量类型

整数,长整数,无符号数,浮点数,字符,字符串,符号常数,转义字符。

5.数据类型转换

·自动转换

在不同类型数据的混合运算中,由系统自动实现转换, 由少字节类型向多字节类型转换。 不同类型的量相互赋值时也由系统自动进行转换,把赋值号右边的类型转换为左边的类型。

·强制转换

由强制转换运算符完成转换。

6.运算符优先级和结合性

一般而言,单目运算符优先级较高,赋值运算符优先级低。 算术运算符优先级较高,关系和逻辑运算符优先级较低。 多数运算符具有左结合性,单目运算符、三目运算符、赋值

7.表达式

表达式是由运算符连接常量、变量、函数所组成的式子。 每个表达式都有一个值和类型。 表达式求值按运算符的优先级和结合性所规定的顺序进行。

篇5:C语言中将0到1000的浮点数用强制指针类型转换的方式生成一幅图像

搞过计算机图像的人都知道,图像中的每一个像素通常为一个整型数,它可以分成4个无符号的char类型,以表示其RGBA四个分量,一幅图像可以看做是一个二维整型数组。这里我会生成一个float数组,其数组大小为1000000,刚好1000*1000,数组内的浮点数的数值范围在0到1000.0之间,呈等差数组排列,相邻两数的差为0.001。然后将其每一个浮点数强制转化成一个整型数或三个unsigned char型,以决定像素的RGB三个通道分量,看看其生成的图像是什么样子。

前几天写了一篇文章是在C语言中使用异或运算交换两个任意类型变量,引来某人的质疑,说什么“指针的强制类型转换有一定限制,不是你想怎么转就怎么转的,结果可能会出错的”。用这种莫须有的话来否定我的代码。为嘲笑他的无知,我特意写出这种用强制指针类型转换生成图像的算法。

先上C代码:

复制代码

#include

#include

#include

#define DIM 1000

void pixel_write(int,int);

FILE *fp;

int main

{

fp = fopen(“image.ppm”,“wb”);

if (!fp)

{

return -1;

}

fprintf(fp, “P6\\n%d %d\\n255\\n”, DIM, DIM);

for(int j=0;j

{

for(int i=0;i

{

pixel_write(i,j);

}

}

fclose(fp);

return 0;

}

void pixel_write(int i, int j)

{

static unsigned char color[3];

float t = j + i*0.001f;

memcpy(color, &t, 3);

fwrite(color, 1, 3, fp);

// 其实更简单粗爆的方式是

//fwrite(&t, 1, 3, fp);

}

复制代码

代码运行后会生成一种PPM格式的图像,如下图所示:

图像多少有点分形的感觉,

PPM格式的图像不太常见,它是一种非常简单的图像格式。在我写的软件Why数学图像生成工具中可以查看,当然我也将该图像的生成算法写到这个软件中,相关代码如下:

复制代码

#ifndef _PixelFloatConvertInt_H_

#define _PixelFloatConvertInt_H_

// --------------------------------------------------------------------------------------

#include “IPixelEquation.h”

// --------------------------------------------------------------------------------------

class CPixelFloatConvertInt : public IPixelEquation

{

public:

CPixelFloatConvertInt()

{

m_width = 1000;

m_height = 1000;

}

const char*  GetName() const

{

return “Float Convert Int”;

}

unsigned int  CalculatePixel(unsigned int x, unsigned int y)

{

float t = y + x*0.001f;

unsigned int rst = *(unsigned int*)&t;

rst |= 0xff000000;

return rst;

}

};

// --------------------------------------------------------------------------------------

#endif

篇6:c语言:有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?打印出来?

有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?打印出来?

解:程序:

#includeint main(){int i, j, k;int count = 0;for (i = 1; i < 5; i++){for (j = 1; j < 5; j++){for (k = 1; k < 5; k++){if (i != j&&i != k&&j != k){printf(“%d%d%d ”,i,j,k);count++;}}}}printf(“count=%d\\n”,count);return 0;}

结果:

123 124 132 134 142 143 213 214 231 234 241 243 312 314 321 324 341 342 412 413 421 423 431 432 count=24

Sybase的数据类型

《有趣的人形符号》大班下学期语言教案

签名符号

故乡的符号散文

qq留言符号

下载C语言的无符号数据类型转换(共6篇)
C语言的无符号数据类型转换.doc
将本文的Word文档下载到电脑,方便收藏和打印
推荐度:
点击下载文档
点击下载本文文档