c语言符号小数点用法,C语言_第一讲_C语言入门

1.C语言是一个标准,而执行标准的时候产生的自动化程序则是编译器

2.了解:1983年美国国家标准化歇会(ANSI)制定了C语言标准.

C语言的特点:

3.代码的可移植性(理想状态是代码可以不加修改,就可以移植,前提是不包括任何平台相关库)

4.写代码的时候最好把业务逻辑层和UI层分开.这样便于代码的移植

5.结构化编程(可以把问题分解成一个一个的函数去执行)

6.丰富的数据类型(相对于汇编而言是丰富的)

7.简洁高效的代码(这得看人,不是编译器的或者语言的特性,如果算法写的不好,一样执行速度慢,和语言无关.反之则相反);

二、代码和调试之间的比例

1.调试和写代码的时间比例是2比8

2.写代码占2 调试的时间占8

3.UI和逻辑分离,UI占7,逻辑占2

三、&符号的双重用法

1.符号在C语言中的场景不一样,那么就会有不同的作用

2.列如:

3.++ + + 2个加号就和加号的意思不一样

4.+号可以看做是加好,也可以看做是数学上的±符号

5.所以不同场景用什么运算符会起到不一样的作用

6.&运算单独使用的时候可以看做是取地址符号,如果左边有操作数的时候可以看做是位与符号

四、程序的挂起状态的三种表现形式

1.Getchar()

2.Scanf(“%d”);

3.System(“pause);

4.其中system()这个函数是与平台相关的函数,所以加了这句话就不可跨平台了

五、Scanf的常见问题解析

1.scanf的用法:通过标准输入设备输入到程序中

2.第二个参数式地址变量,是放地址的.不放地址会把这个变量里面的值当做是一个地址

3.如果访问到不该访问的地址就会出错

4.分别有两个有用的信息是:

5.异常代码:c00005 意思就是访问了一个不该访问的地址

6.异常便宜:00026 可以定位到代码出错的位置

总结:如果没有填地址府,程序不崩溃那么以后可能会吃亏,程序会受影响

有隐患,如果遇到变量的值不再初始化那么会使用上次内存使用后残留的值

所以一定要给变量初始化.

六、批处理

Del *.exe 删除目录下所有的exe可执行的文件

Del *.obj删除目录下所有的.obj文件

Cl /c /W4 /WX 文件名.c编译文件名.c为obj文件

Link 文件名.obj连接文件名.obj文件名为文件名.exe可执行文件

文件名.exe运行可执行文件

Pause暂停窗口等待进一步的操作

七、浮点数

浮点数的查看

1.浮点数后边加上f列如 3.25f代表是一个浮点数

2.如果不加的话那么默认会认为是一个双精度的小数

ZERO零在不同场合的用法

Char ch = ‘ ’;

Int n = 0;

Int *p = NULL;

Float f = 0.0f;

Double db = 0.0;

切记软件的规范

小数转化为16进制的算法

1.第一步:将小数转化为二进制

假设有一个小数是4.25

那么先转化为二进制为:100.01

2.第二步:

把小数点定位为最前位1的后面,直到遇到第一位为1的值

那么现在是1.0001总共往左移动了2位那么可以看做是1.0001*2^2次方

3.第三步:定义符号位

符号位0,因为4.25的是正数

4.第四步:定义指数为(指数为在32位系统下占8位 double 是11位)

而指数位是2^2的幂+127 他的次方(也就是幂)是2

所以就是2+127 = 129

转化为二进制是1000 0001 最后加上符号位是

0 1000 0001

5.第五步:确定尾数为(尾数位占23位不足的补零在)

直接把1.0001 把前边的1去掉放在指数为后面即可

0 1000 0001 0001 0000 0000 0000 0000 000

最后按照从右向左4位一体的分割二进制转化为16进制

0100 0000 1000 1000 0000 0000 0000 0000

4 0 8 8 0 0 0 0

按照小端模式就是00 00 88 40

十六进制转化为小数的实现

第一步:把给定的十六进制转化为二进制

44 22 00 00

0100 0100 0 010 0010 0000 0000 0000 0000

第二步:去掉符号位,取指数位(32位下是8位)

0是符号位去掉之后的值是

1000 1000 128 +8 = 136

第三步:用指数得出的值减去127 然后尾数从指数后面的前面加1然后往右移动 >>(指数减去127得出的值的位数)

结果是136 - 127 = 7; 那么小数点就从刚才取出指数位

的后面往后移动7位

结果为:

注意:取出指数后,在后边指数后的位置加个1点(1.XXX为尾数)

(移动位置的时候也从1.后面开始算)

1.010 0010 0000 0000 0000 0000 (一.1.不算,从尾数开始移动

1 010 0010.0000 0000 0000 0000(二.移动后

第四步:把移动后的结果转化为10进制的数即可.

如果小数位有那么就是乘以2^1...(尾数有多少就乘以多少)

正确结果是:16进制的162.00

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值