C语言支持两种不同的数值类型,整数类型,浮点类型。

C语言的整数类型有不同的尺寸。int类型通常为32位,但在老的CPU上可能是16位。有些可能是64位。

因此,int型如果在16位CPU上最大值就是:0111111111111111   对应值是32768(2^15-1)。

在32位CPU上当然就是:01111111111111111111111111111111   对应值是2147 483 647(2^31-1).

同理64位上…………

32位上int型与long类型的最大值相等

但是16位与64位均不同,long比int大2^n次方

C99提供了两个额外的标准整数类型:long long int 和 unsigned long long int 。

这两个long long 类型要求至少64位宽,所以long long int 类型值的范围通常为

-2^63(-9 223 372 036 854 775 808)到2^63-1(-9 223 372 036 854 775 807)

整数溢出怎么办?

整数溢出是的行为要根据操作数是有符号型还是无符号型来确定。有符号整数运算中发生溢出时,程序的行为时未定义的。

无符号整数类型运算过程中发生溢出时,结果是有定义的:正确的答案对2^n取模,其中n是用于存储结果的位数。

例如,如果对无符号的16位数65535加1,其结果可以保证是0.

浮点常量

浮点常量可以有许多种书写方式。例如下面这些常量是表示数57.0的有效方式

57.0    57.    57.0e0    57E0    5.7e1    5.7e+1    .57e2    570.e-1

默认情况下,浮点常量都以双精度数的形式存储。当C语言编译器在程序中发现常量57.0时,他会安排数据以double类型变量的格式存储在内存中。

在某些极个别情况下,可能会需要强制编译器以float或long double 格式存储浮点常量。为了表明只需要单精度,可以在常量的末尾加上字母F或f(如 57.0F);

而为了说明常量必须以long double格式存储,可以在常量的末尾加上字母L或l(如57.0L)。

执行程序时,使用getchar()函数和putchar()函数(胜于scanf和printf)可以节约时间。

注意算术转换中不同类型之间的变化

为了统一操作数的类型,通常可以将相对较狭小类型的操作数转换成另一个操作数的类型来实现

即为所谓的提升,最常用的提升是整值提升,它把字符或段整数转换成int类型(或者在某些情况下是unsigned int类型)

任意操作数是浮点型的情况

long double

^

|

double

^

|

float

如此提升

两个操作数的类型都不是浮点类型的情况。

int ——>unsigned int ——>long int ——>unsigned long int

当把有符号操作数和无符号操作数组合时,把有符号操作数“转换”成无符号的值。转换过程需要加上或者减去n+1的倍数,其中n是无符号类型能表示的最大值

。这条规则可能会导致某些隐蔽的编程错误。

假设int类型的变量 i 的值是-10 而unsigned int 类型的变量u的值是10.如果用“<”运算符比较 i 和 u 那么期望的结果应该是1(真)

但是,在比较前,变量 i 转换成unsigned int类型。因为负数不能被表示成无符号,所以转换后不再是-10,而是加上 4 294 967 296 的结果

即4 294 967 286 因而 i < u   结果是0

因此,最好避免使用无符号整数,特别是不要把它和有符号的整数混合使用

如果数是负数,如何以八进制或十六进制形式书写它???

没有直接的方法可以书写负数的八进制或十六进制。幸运的是需要这样做的情况非常少。当然,

我们可以判定这个数是否是负数,然后自己显示一个负号:

if(i < 0)

printf("-%x",-i);

else

printf("%x",i);

C语言程序设计现代方法_基本类型(第七章)的更多相关文章

  1. C语言程序设计现代方法_数组(第八章)

    C语言不要求检查下标的范围.当下标超出范围时,程序可能会执行不可预知的行为. 看下这个程序: #include <stdio.h> #define N 10 // int main() { ...

  2. C语言程序设计现代方法1,2,3章

    1:浮点型(float)运算比int慢,并且可能存在舍入误差 如float存储0.1,以后使用可能会变成0.099999999987 2:宏定义只用大写,这是大多数C程序猿遵循的规范! C语言区分大小 ...

  3. Lambda语言篇 —— lambda, 方法引用, 目标类型和默认方法

    本文介绍了Java SE 8中新引入的lambda语言特性以及这些特性背后的设计思想.这些特性包括: lambda表达式(又被成为"闭包"或"匿名方法") 方法 ...

  4. C语言学习书籍推荐《C语言程序设计 现代方法(第2版)》下载

    下载地址:点我 C语言仍然是计算机领域的通用语言之一,但现在的C语言已经和当初的时候大不相同了.本书主要的一个目的就是通过一种“现代方法”来介绍C语言,书中强调标准C,强调软件工程,不再强调“手工优化 ...

  5. C语言程序设计-现代方法(笔记3)

    第十三章 字符串 1.字符串字面量(13.1) 字符串字面量:用一对双引号括起来的字符序列.字符串字面量可以像字符常量一样包含转义字序列. 在字符串字面量中小心使用八进制和十六进制的转义序列. 字符串 ...

  6. C语言程序设计-现代方法(笔记1)

    第一章 C语言概述 1.C语言的历史(1.1) 起源:贝尔实验室开发的UNIX操作系统的副产品.标准化:C89和C99.基于C的语言:C++,Java,C#,Perl. 2.C语言的优缺点(1.2) ...

  7. 《C语言程序设计现代方法》第4章 表达式

    C语言的一个特点就是它更多地强调表达式而不是语句,表达式是表示如何计算值的公式. 当表达式包含两个或更多个相同优先级的运算符时,运算符的结合性(associativity)开始发挥作用.如果运算符是从 ...

  8. 《C语言程序设计现代方法》第2章 C语言基本概念

    C语言的基本概念 第一个C程序例子. /* pun.c */ #include <stdio.h> int main(void) { printf("To C, or not t ...

  9. 《C语言程序设计现代方法》第4章 编程题

    1 编写一个程序,要求用户输入一个两位数,然后按数位的逆序打印出这个数. 方法一:没技术含量的 #include <stdio.h> int main() { int high, low; ...

随机推荐

  1. linux设备驱动归纳总结(五):3.操作硬件——IO静态映射【转】

    本文转载自:http://blog.chinaunix.net/uid-25014876-id-83299.html linux设备驱动归纳总结(五):3.操作硬件——IO静态映射 xxxxxxxxx ...

  2. 【python cookbook】【数据结构与算法】2 从任意长度的可迭代对象中分解元素

    从某个可迭代对象中分解出N个元素,但是可迭代对象的长度可能超过N,会出现“分解值过多”的异常: 使用“*表达式”来解决该问题: Python 3.4.3 (v3.4.3:9b73f1c3e601, F ...

  3. Java的多线程+Socket 后台 Ver 2.0

    package com.wulala; import java.io.IOException;import java.net.ServerSocket;import java.net.Socket; ...

  4. iOS的通知Notification

    这里是不同的对象之间的通知, 不是本地通知. 一开始玩, 很挠头, 后来发现原来只是对象init的过程出了问题. 首先, 新建一个简单的单controller的工程. 然后打开它的ViewContro ...

  5. Java 基本数据类型 sizeof 功能【转】

    转自:http://blog.csdn.net/sunboy_2050/article/details/7310008 版权声明:本文为博主原创文章,未经博主允许不得转载. Java基本数据类型int ...

  6. PHP stat() 函数 返回关于文件的信息。

    定义和用法 stat() 函数返回关于文件的信息. 语法 fstat(file) 参数 描述 file 必需.规定要检查的文件. 说明 获取由 file 指定的文件的统计信息.如果 file 是符号连 ...

  7. 9、Http回顾/Servlet

    1 Http回顾 Http协议: 1)http协议: 对浏览器客户端和服务器端之间数据传输的格式规范. 2)http请求:浏览器->服务器端 格式: 请求行(请求方式(GET/POST) 请求资 ...

  8. Struts输出流向jsp页面写入图片乱码

    通过Struts2输出字节流将图片写到jsp页面上,之前用jquery的div对象的html()方法接收一直显示乱码,查了很多网页都找不到解决办法,不是说contentype="multip ...

  9. 修改tomcat的logo

    每页的<head> 里添加   <link rel="icon" href="favicon.gif" />   图片名称必须是favi ...

  10. c#游戏 剪刀石头

    电脑using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace sh ...