/**
* 整数的溢出
*/
#include <stdio.h> int main(int argc, char *argv[]) {
short i = -24;
// 将-24以无符号int类型输出,实际输出的是
// 其补码转换成的十进制数
printf("将 %d 以无符号整型输出为 %u\n", i, i); // 将 -24 以无符号整型输出为 4294967272
printf("将 %d 以十六进制(小写x)输出为 %x\n", i, i); // 将 -24 以十六进制(小写x)输出为 ffffffe8
printf("将 %d 以十六进制(大写X)输出为 %X\n", i, i); // 将 -24 以十六进制(大写X)输出为 FFFFFFE8
printf("将 %d 以八进制输出为 %o\n", i, i); // 将 -24 以八进制输出为 37777777750 printf("short类型占 %d 个字节\n", sizeof(short)); // short类型占 2 个字节
// long
// 在32位系统下unix系统占4个字节
// 在64位系统下unix系统占8个字节
// 不是很固定,在程序中尽量少用long
printf("long类型占 %d 个字节\n", sizeof(long)); // long类型占 8 个字节
// long long
// 占8个字节,64位,是固定的,对于32位系统,cpu的寄存器
// 是32位,所以计算long long的类型的数据,效率会很低
printf("long long类型占 %d 个字节\n", sizeof(long long)); // long long类型占 8 个字节
printf("unsigned int类型占 %d 个字节\n", sizeof(unsigned int)); // unsigned int类型占 4 个字节
printf("unsigned short类型占 %d 个字节\n", sizeof(unsigned short)); // unsigned short类型占 2 个字节
printf("unsigned long类型占 %d 个字节\n", sizeof(unsigned long)); // unsigned long类型占 8 个字节
printf("unsigned long long类型占 %d 个字节\n", sizeof(unsigned long long)); // unsigned long long类型占 8 个字节 // 整数溢出
// 计算一个整数的时候超过整数能够容纳的最大单位后
// 整数会溢出,溢出的结果是高位被舍弃
unsigned short abc = 0xffff;
abc = abc + 1;
printf("abc = %d\n", abc); // abc = 0
unsigned short n1 = 0xffff;
// n1 += 100 <=> n1 + 1 + 99
n1 += 100;
printf("n1 = %d\n", n1); // n1 = 99
unsigned short n2 = 2;
n2 -= 5;
// 输出的是-3对应的补码的整数值
printf("n2 = %d\n", n2); // n2 = 65533
int n3 = 0x12345678;
// n3为int型占4个字节32位,n2为unsigned short型占2个字节16位
// 将n3赋给n2,将大整型赋给小整型,多出的部分会被截取丢弃掉
n2 = n3;
printf("n2 = %x\n", n2); //n2 = 5678
short n4 = -2;
// 当一个小的整数赋值给一个大的整数时,符号位不会丢失
// 若为正则补0,为负补1
// n3不足的位会自动补1,因为n4为负值,符号位为1
n3 = n4;
printf("n3 = %x\n", n3); // n3 = fffffffe
unsigned short n5 = 0;
// n5为无符号整型,最小值为0,再减一,值为-1
// 最后会输出-1补码 1111 1111 1111 1111
n5 -= 1;
printf("n5 = %x\n", n5); // n5 = ffff return 0;
}

C中整数的溢出的更多相关文章

  1. java int整数相乘溢出

    int整数相乘溢出 我们计算一天中的微秒数: * * * * ;// 正确结果应为:86400000000 System.out.println(microsPerDay);// 实际上为:50065 ...

  2. linux中tomcat内存溢出解决办法

    用命令 tail -f /root/apache-tomcat-6.0.20/logs/catalina.out(需要找到tomcat路径) 查看日志,查看是否有错误 linux中tomcat内存溢出 ...

  3. linux中tomcat内存溢出

    刚开始测试服务器与线上后台都不能上传10分钟以上的视频,后来只要是视频就不能上传,进入服务器查日志得到如下错误: Caused by: java.lang.OutOfMemoryError: Java ...

  4. Shell中整数自增的几种方式

    Shell中整数自增的几种方式 2016年08月27日 19:07:40 杰瑞26 阅读数:2816    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.n ...

  5. Java架构师中的内存溢出和内存泄露是什么?实际操作案例!

    JAVA中的内存溢出和内存泄露分别是什么,有什么联系和区别,让我们来看一看. 01 内存泄漏 & 内存溢出 1.内存泄漏(memory leak ) 申请了内存用完了不释放,比如一共有 102 ...

  6. C/C++中整数与浮点数在内存中的表示方式

    在C/C++中数字类型主要有整数与浮点数两种类型,在32位机器中整型占4字节,浮点数分为float,double两种类型,其中float占4字节,而double占8字节.下面来说明它们在内存中的具体表 ...

  7. 谈谈Java中整数类型(short int long)的存储方式

    在java中的整数类型有四种,分别是byte short in long,本文重点给大家介绍java中的整数类型(short int long),由于byte只是一个字节0或1,在此就不多说了,对ja ...

  8. java中整数的默认为int类型的一些问题

    thingking in java 读书感悟 作者 :淮左白衣 写于2018年4月8日17:51:44 关于整数的默认类型,以及会产生的一些小问题 涉及基本数据类型的重载 关于整数的默认类型,以及会产 ...

  9. Tomcat中JVM内存溢出及合理配置及maxThreads如何配置(转)

    来源:http://www.tot.name/html/20150530/20150530102930.htm Tomcat本身不能直接在计算机上运行,需要依赖于硬件基础之上的操作系统和一个Java虚 ...

随机推荐

  1. Thymeleaf入门——入门与基本概述

    https://www.cnblogs.com/jiangbei/p/8462294.html 一.概述 1.是什么 简单说, Thymeleaf 是一个跟 Velocity.FreeMarker 类 ...

  2. BJSV-P-003高清智能卡口系统

    高清智能卡口系统 捕获率99%,车牌识别率98%   ■ 道路安装示意图 ■ 系统结构 ■      抓拍实例 北京太速科技有限公司在线客服:QQ:448468544 淘宝网站:orihard.tao ...

  3. 一、UC中文调试

    一.只支持UC浏览器,版本号6.2.3831.3,复制resources.pak到UC安装目录下,覆盖同名文件即可

  4. 初学Java 数值运算符

    import java.util.Scanner; public class DisplayTime { public static void main(String[] args) { Scanne ...

  5. mybatis基本查询

    <?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE mapper PUBLIC "-/ ...

  6. ARC102E - Stop. Otherwise... 组合计数

    枚举 \(i\),然后可以把 \(j\) 和 \(i - j\) 绑定成一对.把一对看成一个整的元素,与别的没有被绑定的数一起来参与选择就可以了. 但是由于实际上一对中的数是可以二选一的,所以不妨令 ...

  7. Java类加载顺序练习题

    一.题目 public class Test { public static Test t1 = new Test();// 标记1 // 普通代码块 { System.out.println(&qu ...

  8. 用Redis进行实时数据排名

    1先生成一个Redis对象 2实例化一个对象.zscore有序集合中进行排序 3 Redis Zscore命令返回有序集合中,成员的分数值.如果成员元素不是有序集合 key的成员,则key不存在,返回 ...

  9. 【HDU6662】Acesrc and Travel【树形DP】

    题目大意:给你一棵树,每个节点有一个权值,Alice和Bob进行博弈,起点由Alice确定,确定后交替选择下一个点,Alice目标是最终值尽可能大,Bob目标是尽可能小 题解:很明显是树形DP,那么考 ...

  10. 2019.6.1 模拟赛——[ 费用流 ][ 数位DP ][ 计算几何 ]

    第一题:http://codeforces.com/contest/1061/problem/E 把点集分成不相交的,然后跑费用流即可.然而错了一个点. #include<cstdio> ...