Long 和 long 的区别

在Java中,Longlong 是两个不同的概念,它们分别代表不同的数据类型:

  1. long

    • 这是一个 基本数据类型 (primitive type)。
    • 它用于存储 64位带符号的整数
    • 它的取值范围是 -9,223,372,036,854,775,8089,223,372,036,854,775,807
    • 在使用 long 类型变量时,你可以直接赋值,例如 long number = 123456789012345678L;,这里的 L 是可选的,用来表明这是一个 long 类型的字面量。
    • long 类型的变量不能为 null
  2. Long

    • 这是一个 包装类 (wrapper class),属于 java.lang 包。
    • 它是 long 类型的基本数据类型的对象形式。
    • Long 类提供了许多静态方法来操作 long 类型的数据,如 parseLong(String s)valueOf(long l)
    • Long 类的对象可以为 null
    • Long 类还实现了 SerializableComparable<Long> 接口,因此可以进行序列化和比较。
    • 使用 Long 类型时,需要进行装箱(boxing)和拆箱(unboxing)。例如,Long value = new Long(123456789012345678L); 或者使用自动装箱 Long value = 123456789012345678L;

使用场景

  • 基本类型 long 通常用于性能敏感的应用场合,因为它们不需要额外的对象开销。
  • 包装类 Long 通常用于需要对象的地方,比如集合框架(如 List, Set, Map 等),或者需要进行空值处理的地方。

示例

// 使用基本类型 long
long primitiveLong = 123456789012345678L;
System.out.println(primitiveLong); // 输出:123456789012345678 // 使用包装类 Long
Long objectLong = new Long(123456789012345678L);
System.out.println(objectLong); // 输出:123456789012345678 // 自动装箱
Long autoBoxedLong = 123456789012345678L;
System.out.println(autoBoxedLong); // 输出:123456789012345678 // 自动拆箱
long autoUnboxedLong = autoBoxedLong;
System.out.println(autoUnboxedLong); // 输出:123456789012345678

总结来说,long 是一个基本类型,主要用于数值计算;而 Longlong 的包装类,主要用于对象操作和需要空值支持的场合。

为什么在Springboot中一般使用Long 而不是long

在 Spring Boot 中,通常使用 Long 而不是 long,主要是出于以下几个方面的考虑:

1. 处理空值的能力

  • Long:作为一个对象类型,Long 可以持有 null 值。这意味着它可以表示数据库中可为空(nullable)的字段。
  • long:作为基本数据类型,long 无法表示 null 值。如果一个字段在数据库中是可以为 NULL 的,使用 long 类型会引发编译错误或运行时异常(如 NullPointerException)。

2. 对象模型的一致性

在面向对象编程中,通常希望所有的属性都是对象类型。使用对象类型 Long 能够保持对象模型的一致性。例如,如果你的实体类中有多个属性,有些可能是字符串、日期等对象类型,使用 Long 能够保持一致性。

3. 框架支持

  • ORM 框架(如 Hibernate 或 JPA):这些框架通常期望实体类中的属性是对象类型,以便于进行对象关系映射(ORM)。使用 Long 可以更方便地与这些框架集成。
  • Spring Data JPA:通常也会建议使用对象类型来表示数据库中的字段,尤其是在涉及到查询和关系映射时。

4. 集合框架的兼容性

Java 的集合框架(如 List, Set, Map)只接受对象类型,不接受基本类型。使用 Long 可以让你更方便地将数据放入集合中。

5. 自动装箱和拆箱

Java 提供了自动装箱和拆箱功能,使得在大多数情况下,使用 Longlong 没有明显的区别。这意味着你可以像使用基本类型一样使用 Long,而不需要显式地进行类型转换。

示例

假设你有一个实体类 User,其中包含一个可能为 NULLid 字段:

package com.guaiguailang.harmony.domain.entity;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id; @Entity
public class User {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id; private String name; // 构造函数、getter 和 setter 省略
}

在这个例子中,id 字段使用 Long 类型,即使它是自动生成的主键。这样做可以方便地处理 null 值,例如在新建用户时,还没有分配主键的情况下。

使用场景

1. 数据库字段为 NULLABLE

如果数据库中的某个字段允许为 NULL,那么使用 Long 类型可以更好地映射这种情形。

2. ORM 框架的要求

在使用 ORM 框架时,如 JPA 或 Hibernate,通常要求实体类中的字段为对象类型。这是因为 ORM 框架需要处理对象的关系映射,而基本类型不支持 null 值,这会导致一些问题。

总结

虽然 long 类型在某些性能敏感的情况下可能会更合适,但在 Spring Boot 应用程序中,为了更好地处理 null 值、支持集合框架以及方便地与 ORM 框架集成,通常会选择使用 Long 类型来对应数据库中的 BIGINT 类型。

总的来说,使用 Long 能够提供更多的灵活性,并且更符合面向对象编程的原则。

MySQL的bigint类型,在java中,用什么数据类型接收最合适

如果你的BIGINT列不允许NULL值,那么使用基本类型long就足够了。

如果你的BIGINT列允许NULL值,那么使用Long包装类更合适,因为它可以持有null值。

总结来说,如果你确定你的业务逻辑不需要处理null值,并且BIGINT列也定义为NOT NULL,则使用long是最简单直接的选择。否则,为了更好地处理潜在的null值,使用Long会更加合适。

在实际开发中,很多框架(如Hibernate、MyBatis等)都支持自动将数据库中的NULL值映射到Java中的null,在这种情况下,使用Long可以简化代码实现。

[AI回答]Java中Long和long的区别,为什么在Springboot项目中一般使用Long的更多相关文章

  1. SpringBoot12 QueryDSL01之QueryDSL介绍、springBoot项目中集成QueryDSL

    1 QueryDSL介绍 1.1 背景 QueryDSL的诞生解决了HQL查询类型安全方面的缺陷:HQL查询的扩展需要用字符串拼接的方式进行,这往往会导致代码的阅读困难:通过字符串对域类型和属性的不安 ...

  2. 自身使用的springboot项目中比较全的pom.xml

    在学习的时候常建新的项目,mark下商用的jar <dependency> <groupId>org.mybatis</groupId> <artifactI ...

  3. SpringBoot项目中遇到的BUG

    1.启动项目的时候报错 1.Error starting ApplicationContext. To display the auto-configuration report re-run you ...

  4. SpringBoot项目中,表单的验证操作

    在创建Springboot项目中,我们使用了表单验证操作,这一操作将极大地简化我们编程的开发 1.接收数据,以及验证 @PostMapping("/save") public Mo ...

  5. springboot项目中使用maven resources

    maven resource 组件可以把pom的变量替换到相关的resouces目录中的资源文件变量 示例项目:内容中心 (文章管理)  生成jar包,生成docker ,生成k8s文件 1.项目结构 ...

  6. 后端分页神器,mybatis pagehelper 在SSM与springboot项目中的使用

    mybatis pagehelper想必大家都耳熟能详了,是java后端用于做分页查询时一款非常好用的分页插件,同时也被人们称为mybatis三剑客之一,下面 就给大家讲讲如何在SSM项目和sprin ...

  7. springboot项目中接口入参的简单校验

    .katex { display: block; text-align: center; white-space: nowrap; } .katex-display > .katex > ...

  8. 国际化的实现i18n--错误码国际化以及在springboot项目中使用

    国际化 ,英文叫 internationalization 单词太长 ,又被简称为 i18n(取头取尾中间有18个字母); 主要涉及3个类: Locale用来设置定制的语言和国家代码 Resource ...

  9. 在SpringBoot项目中添加logback的MDC

    在SpringBoot项目中添加logback的MDC     先看下MDC是什么 Mapped Diagnostic Context,用于打LOG时跟踪一个“会话“.一个”事务“.举例,有一个web ...

  10. springboot 项目中获取默认注入的序列化对象 ObjectMapper

    在 springboot 项目中使用 @SpringBootApplication 会自动标记 @EnableAutoConfiguration 在接口中经常需要使用时间类型,Date ,如果想要格式 ...

随机推荐

  1. 《Vue.js 设计与实现》读书笔记 - 第5章、非原始值的响应式方案

    第5章.非原始值的响应式方案 5.1 理解 Proxy 和 Reflect Proxy Proxy 只能代理对象,不能代理非对象原始值,比如字符串. Proxy 会拦截对对象的基本语义,并重新定义对象 ...

  2. .NET 8.0 酒店管理系统设计与实现

    前言 给大家推荐一个基于.NET 8.0 的中小型酒店设计的管理系统. 随着酒店的日常工作增加,很难用人工去进行处理一些繁琐的数据,也可能会因为人工的失误而造成酒店的损失,因此需要一款可以协助酒店进行 ...

  3. USB总线-Linux内核USB3.0设备控制器中断处理程序分析(九)

    1.概述 USB设备枚举.请求处理.数据交互都涉及USB设备控制器中断.当有事件发生时,USB设备控制器首先将事件信息通过DMA写入到事件缓冲区中,然后向CPU发出中断,随后CPU调用中断处理函数开始 ...

  4. USB gadget驱动框架(三)

    gadget驱动框架(三) usb_udc与usb_gadget_driver的绑定 usb_udc与usb_gadget_driver,在注册的时候分别被添加到udc_list和gadget_dri ...

  5. Linux内核虚拟内存管理之匿名映射缺页异常分析

    今天我们就来讨论下这种缺页异常,让大家彻底理解它.注:本文使用linux-5.0内核源代码.文章分为以下几节内容: 匿名映射缺页异常的触发情况 0页是什么?为什么使用0页? 源代码分析 3.1 触发条 ...

  6. 1. 王道OS-操作系统的概念、功能

    1. 操作系统是指控制和管理整个计算机的硬件和软件资源,并合理地组织调度计算机的工作和资源的分配:以提供给用户和其他软件方便的接口和环境:他是计算机系统最基本的系统软件: 操作系统需要向其他软件提供服 ...

  7. ServiceMesh 3:路由控制(图文总结)

    ★ ServiceMesh系列 1 Istio部署 1.1 连接测试机 进入测试机服务器... 1.2 安装Istio 1.2.1 通过官方网站下载Istio # 下载最新版本的Istio $ cur ...

  8. kotlin函数和Lambda表达式——>内联函数

    1.内联函数 使用高阶函数会带来一些运行时的效率损失:每一个函数都是一个对象,并且会捕获一个闭包.即那些 在函数体内会访问到的变量.内存分配(对于函数对象和类)和虚拟调用会引入运行时间开销. 但是在许 ...

  9. 神经网络之卷积篇:详解经典网络(Classic networks)

    详解经典网络 首先看看LeNet-5的网络结构,假设有一张32×32×1的图片,LeNet-5可以识别图中的手写数字,比如像这样手写数字7.LeNet-5是针对灰度图片训练的,所以图片的大小只有32× ...

  10. Module Warning (from ./node_modules/postcss-loader/dist/cjs.js): Warning

    .markdown-body { line-height: 1.75; font-weight: 400; font-size: 16px; overflow-x: hidden; color: rg ...