首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

CC++:long int与long long的区别

在实际的使用中,long与int几乎没有区别,比如—— #include int main(){ long l = 10000000; int i = 10000000...在ANSI C的标准中,对长整型的定义也是long int应该至少和int一样长,而不是long int 一定要比int占用存储字节长。...long long   long long则不同,long long是C++的64位整型的基本类型,“现任”长整型,从C99开始引入这个概念,在后续的标准中完善概念和定义,C++11官方正式标准如下——...与之相反,出身MS的__int64就有点不受待见了,在不同的编译器上可能水土不服。 __int64   在早期的代码中,可能会遇到__int64这种类型,这应该算是“历史遗留”问题。...早期的C/C++标准中并没有规定64位长整型的规范,因此不同的编译器对这一模糊概念有不同的定义,我们熟知的VC6.0采用了__int64这种类型来表示64位长整型—— #include<iostream

2.6K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    C语言中int、long int、long long的区别

    (4)在标准中,并没有规定long一定要比int长,也没有规定short要比int短。 标准时这么说的:长整型至少和整型一样长,整型至少和短整型一样长。...至于如何实现要看编译器厂商 (5)shortlong VC里面还有个 long long 是占8个字节的 2、关于long long (1)long long在win32中是确实存在...为什么会出现long int呢,在win32现在系统中,长度为4;在历史上,或者其他某些系统中,int长度为2,是short int。 即便是long long,在TI的有款平台中,长度为5。...(2)visual c++ 6.0中不支持,long long int,是在vc99中添加此功能的,所以我们在vc6.0中编译有long long 的数据时,会出错,但是在VS更高的版本中,是能通过的。...ACM题目中“求矩形的个数”那道题,就需要用到long long。

    3K20

    MySQL 数据库中的锁

    全局锁 顾名思义,全局锁就是对整个数据库实例加锁。 1. FTWRL MySQL 提供了一个加全局读锁的方法,命令是 Flush tables with read lock (FTWRL)。...如果执行 FTWRL 命令之后由于客户端发生异常断开,那么 MySQL 会自动释放这个全局锁,整个库回到可以正常更新的状态。...MDL 锁 另一类表级的锁是 MDL(metadata lock),这个是 MySQL 5.5 版本中引入了 MDL,当对一个表做增删改查操作的时候,加 MDL 读锁;当要对表做结构变更操作的时候,加...这大大降低了数据库的执行性能。 怎么减少行锁对性能的影响? 关闭死锁检测 控制并发度,业务层面和数据库层面。...另一种就是修改数据库 server 层的源码,在服务端控制并发数量。 拆分更新记录,将一条记录分成多条记录的合计。如果这种方式需考虑数值变更的临界值判断,比如金额为 0 的情况。

    5K20

    Java中new Long(String s)和Long.valueOf(String s)的区别

    想要知道new Long(String s)和Long.valueOf(String s)的区别,还是得从源码直接看比较直观 new Long(String s) Long.valueOf(String...s) 从源码可以看出,使用new Long(s)和Long.valueOf(s)都会去调用parseLong(s, 10)方法, parseLong(String s, int radix)...result : -result; } parseLong(String s, int radix)返回long值,这事区别就出来了,对于new Long(String s)是直接将该long值返回...,而Long.valueOf(String s)会将返回的long值继续处理Long.valueOf(long l) 那么从valueOf(long l)方法可以看到再返回结果之前会进行一个判断...,判断当值在[-128,127]之间返回的是缓存的值,不在这个值区间了才会通过构造函数返回,从这一点上看会比new Long(String s)更节省空间,提高性能。

    13610

    Java 中 long 和 double 的原子性?

    来源:http://t.cn/EGb8BxE JVM中对long的操作是不是原子操作? 为什么对long的操作不是原子的? 在硬件,操作系统,JVM都是64位的情况下呢?...---- java中基本类型中,long和double的长度都是8个字节,32位(4字节)处理器对其读写操作无法一次完成,那么,JVM,long和double是原子性的吗?...JVM中对long的操作是不是原子操作? 首先,通过一段程序对long的原子性进行判断。...可以推测,jvm中对long的操作并非原子操作。 为什么对long的操作不是原子的?...操作从工作内存中得到的变量的值写到主内存中的变量 其中,与赋值,取值相关的包括 read,load,use,assign,store,write 按照这个规定,long的读写都是原子操作,与我们的实践结果相反

    2.3K20

    MySQL 经典案例分析:Specified key was too long

    一、 问题是这样来的 BG内部要进行数据库的容灾演习,需要模拟线上实际的环境进行测试,这就需要copy一份线上的数据库到测试库中,其实也就是重建一个线上数据库。...这时候,我很天真的以为可能是因为建表的时候没有指定字符集,所以在导入测试库的时候默认使用utf-8字符集,导致Specified key was too long。...所以就更改了测试库中默认的字符集,但是导入数据的时候依然还是报同样的错误。...先分别查了下两个数据库的默认存储引擎,果然发现在线上库中default_storage_engine和storage_engine都是MYISAM,而测试库却均是INNODB。...=barracuda,innodb_file_per_table=true,并且建表的时候指定表的row_format为dynamic或者compressed(mysql 5.6中row_format默认值为

    122.9K5532

    Mysql自带数据库中的信息

    当你新建一个mysql服务,并且使用root用户登录mysql(或者你拥有相应的权限),会发现mysql预先安装了四个数据库. information_schema mysql perfomance_schema...SCHEMATA:提供了当前mysql实例中所有数据库的信息,我们经常使用的show databases就是从这里读取数据的. TABLES:提供了关于数据库中的表的信息(包括视图)。...COLUMNS:提供了表中的列信息。详细的描述了某个字段属于某张表,某个库,以及其他的字段名,字段类型,权限,备注等信息. STATISTICS:提供了关于表索引的信息。...TABLE_CONSTRAINTS:描述了存在约束的表。以及表的约束类型等。 KEY_COLUMN_USAGE:描述了具有约束的键列。 VIEWS:给出了关于数据库中的视图的信息。...mysql 这是mysql的核心库,我们的用户,密码及权限等相关信息都存储在这里,所以在修改用户或者添加用户等操作的时候,使用grant命令和直接对这个库中的user表进行增删改查的作用是相等的.

    4.1K20

    java integer long 转换_long(Long)与int(Integer)之间的转换

    1.将long型转化为int型,这里的long型是基础类型: long a = 10; int b = (int)a; 2.将Long型转换为int 型的,这里的Long型是包装类型: Long a =...10; int b=a.intValue(); 3.将Long型转换为 Integer 型的,这里的Long型是包装类型: Long a = 10;; Integer b=a.intValue();...4.将int型转化为long型,这里的int型是基础类型: int a = 10;long b = (int)a; 5.将Integer型转化为long型,这里的Integer型是包装类型: int a...= 10;Long b = a.longValue(); 6.将Long型转化为Integer型,这里的Integer型是包装类型: Long a = 10; Integer b=a.longValue...(); 总结:这里的转化就是要注意Java的八种基础数据类型以及八种包装数据类型的区别 基本类型和封装类的转换 Int转Integer: Integer integer = new Integer(int

    5.5K20

    【MSQL数据库】MySQL中的NULL

    mysql中的NUll是什么 ? 维基百科是这样说的:空值(Null或NULL)是结构化查询语言中使用的特殊标记,是中对数属性未知或缺失的一种标识,用于指示数据库中不具值。...由关系数据库模型的创作者 E.F.科德所引入。SQL空值是用来满足真实关系数据库管理系统(RDBMS)中,支持“缺失信息与不适用的信息”的需求。...另外,数据库中的统计计算,一般将有空值的数据忽略不计。 MYSQL 的null值和’ '值有什么区别呢?...占用空间区别 null值在mysql中的占用空间大小也为null,而’ '值在mysql 中为0。...总结: 在创建MySQL表示尽量要限制not NULL 且给初始值为 ’ ’ 或 0; NULL值在mysql数据库中是占有存储的, ’ ’ 是不占用的。 如果某一列有NULL值,且以此列创建索引。

    3.8K10

    mysql存储long型数据_int数据类型

    许多不同的子类型对这些类别中的每一个都是可用的,每个子类型支持不同大小的数据,并且 MySQL 允许我们指定数值字段中的值是否有正负之分或者用零填补。...例如,指定一个字段的类型为 INT(6),就可以保证所包含数字少于 6 个的值从数据库中检索出来时能够自动地用空格填充。需要注意的是,使用一个宽度指示器不会影响字段的大小和它可以存储的值的范围。...使用这个修饰符可以阻止 MySQL 数据库存储负值。 FLOAT、DOUBLE 和 DECIMAL 类型 MySQL 支持的三个浮点类型是 FLOAT、DOUBLE 和 DECIMAL 类型。...忽略 DECIMAL 数据类型的精度和计数方法修饰符将会使 MySQL 数据库把所有标识为这个数据类型的字段精度设置为 10,计算方法设置为 0。...SET 类型可以从预定义的集合中取得任意数量的值。并且与 ENUM 类型相同的是任何试图在 SET 类型字段中插入非预定义的值都会使 MySQL 插入一个空字符串。

    3.9K30

    7.MySQL数据库中的约束

    create table student( id int not null, name varchar(20), score decimal(3,1) ); 图片 如果在这一列中插入null...,就会报错 2. unique 创建表的时候在对应变量类型后面加上“unique”字样,表示该列的所有行是不能重复的,当插入重复数据的时候就会报错。...如果表中没有记录,自增就从1开始,如果有记录了,自增从上一条记录往下增。 插入数据时: 如果把中间的某个数据删了,再插入元素时,刚才删除的那个自增主键的值不会重复利用。...,那么就会报错 使用外键,会对插入操作的效率产生一定的影响,同时外键约束也会影响表的删除。...以上两个表中,class表被其他表依赖着,就无法被删除。

    1.8K20
    领券