关于int和integer

大家可以看一下下面这个java程序的运行结果

		int k = 1;
		int l = 1;
		System.out.println(k == l);
		
		int a = 128;
		int b = 128;
		System.out.println(a == b);
		
		Integer i = 1;
		Integer j = 1;
		System.out.println(i == j);
		
		Integer m = 128;
		Integer n = 128;
		System.out.println(m == n);

运行结果为

true
true
true
false

为什么或造成这种情况呢,这就要从integer i =1的原理说起了,它相当于执行了integer i = Integer.valueOf(1);而在java的文档中我们可以看到如下解释
在这里插入图片描述“此方法将始终缓存”-128到127(含)范围的值”,这句话的意思是在第一次integer i = 1时,1这个数字就被存到了缓存中,再次执行integer j = 1时,就会直接从缓存中取。所以i == j 是true。而m是128,将不再进行缓存,m == n就是false。

我是一个正在偷偷努力学习java的大胖子,有任何问题大家都可以发在我的个人公众号上边,我也会尽量帮大家解决,当然,我也只是一个正在学习java的人,并不能保证“每个”问题都能回答上来,但是我们可以一起交流。
还有我的个人公众号会不定时更新我的java学习之路,大家如果也在学习java可以在公众号上边与我交流哦。

在这里插入图片描述

### MySQL 中 `INT` `INTEGER` 的区别及用法 在 MySQL 数据库中,`INT` `INTEGER` 是同义词,在定义表结构时可以互换使用。两者都表示整数型的字段,具有相同的存储需求范围。 #### 存储大小与取值范围 - **单字节 (TINYINT)**: 范围是从 -128 到 127 或者无符号情况下从 0 到 255。 - **双字节 (SMALLINT)**: 取值区间为 -32,768 至 32,767;如果是无符号,则是 0 至 65,535。 - **四字节 (MEDIUMINT)**: 支持的数值介于 -8,388,608 8,388,607 之间,对于无符号型则是 0 到 16,777,215。 - **四字节 (INT/INTEGER)**: 值域覆盖了 -2,147,483,648 到 2,147,483,647,而无符号版本则支持更大的正数范围,即 0 到 4,294,967,295[^1]。 #### 定义列时的选择 当创建数据库表格并指定某一列为整型时,可以选择 `INT` 或 `INTEGER` 关键字来声明这一属性。例如: ```sql CREATE TABLE example ( id INT NOT NULL AUTO_INCREMENT, value INTEGER DEFAULT 0, PRIMARY KEY(id) ); ``` 上述 SQL 语句展示了如何在同一张表里分别采用 `INT` `INTEGER` 来定义两个不同的整数列。值得注意的是,尽管语法上允许这样做,但在实际应用中通常只需要选用其中一种形式即可,因为它们的功能完全相同。 #### 使用场景考量 虽然 `INT` `INTEGER` 在功能层面没有差异,但在某些特定上下文中可能会更倾向于某一方。比如,在涉及到与其他编程语言交互的情况下,可能基于目标语言的习惯会选择其中一个作为标准写法。然而,这并不影响其内在特性或性能表现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值