java中boolean类型的长度

    在最近地总结中,发现boolean 类型的大小挺纠结,后来在网上看了下,发现网上的观点也是众说纷纭。

带着疑问我从oracle 公司的官网下载了最新的"The Java Virtual Machine Specification" 此版本是第七版本的,最终修订日期是2012-7-27

在JVM 是这样解释的:

Although the java virtual machine defines a boolean type,it only provides very limited support for it.There are no java virtual machine instructions solely dedicated to operations on boolean values.  Instead, expressions in the java programming language that operate on boolean values are compiled to use values of the java virtual machine int data type.

The java virtual machine does directly support boolean arrays. Its newarray instruction enables creation of boolean arrays. Arrays of type boolean are accessed and modified using the byte array instruction baload and bastore .

In Oracle java virtual machine implementation, boolean arrays in the java programming language are encoded as java virtual machine byte arrays, using 8 bits per boolean element .

The java virtual machine encodes boolean array components using 1 to represent true and 0 to represent false . Where java programming language boolean values are mapped by compilers to values of java virtual machine type int , the compilers must use the same encoding .  

从上述的解释中可以得出一个结论就是:单个的boolean 类型变量在编译的时候是使用的int 类型。而对于boolean 类型的数组时,在编译的时候是作为byte array来编译的所以boolean 数组里面的每一个元件占一个字节,这是确定的!

个人认为:单个的boolean 类型变量,即boolean b; 在这里说b 是和int 一样占有四个字节,我觉得不合适。在上述的描述中对boolean 类型进行编译的时候是把boolean类型的值以int 的形式映射到编译器上的,并且在JVM 中都没有专门处理boolean 类型的指令。应该是在程序读到boolean 时,会在内存的 “data” 区开辟一块空间用来存放true, 或者false。

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: 可以使用 Hibernate 的 @Type 注解来指定 boolean 类型在数据库的映射类型,例如: @Column(name = "is_active") @Type(type = "yes_no") private boolean isActive; 这里使用了 "yes_no" 映射类型,将 boolean 类型映射为 char(1) 类型的 'Y' 或 'N'。 ### 回答2: Hibernate是一个流行的Java持久化框架,它提供了对象关系映射(ORM)的功能,使得开发人员可以使用面向对象的思维来操作数据库。在Hibernateboolean类型Java属性可以映射到数据库字段的char类型。 在Hibernate,有一个`@Column`注解,可以用来指定属性与数据库字段的映射关系。对于boolean类型的属性,可以使用`columnDefinition`属性来指定数据库字段的类型。我们可以将`columnDefinition`属性设置为"char(1)",这样Hibernate就会将boolean类型的属性映射到char类型的数据库字段。 例如,我们可以定义一个Person实体类,其包含一个名为isEmployed的boolean属性: ```java @Entity @Table(name = "person") public class Person { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @Column(name = "is_employed", columnDefinition = "char(1)") private boolean isEmployed; // 其他属性和方法 } ``` 在上面的例子,`@Column`注解的`columnDefinition`属性指定了数据库字段的类型为char(1),即使用一个字符来表示boolean属性。 当我们使用Hibernate进行数据库操作时,Hibernate会自动将boolean属性映射到char类型的数据库字段,其true会被映射为字符"1",false会被映射为字符"0"。 总之,Hibernateboolean类型可以使用char类型的数据库字段进行映射。我们可以通过`columnDefinition`属性来指定数据库字段的类型,将true映射为字符"1",将false映射为字符"0"。这样,在使用Hibernate进行数据库操作时,可以自动实现Java boolean类型与数据库字段char类型的转换。 ### 回答3: 在HibernateJavaBoolean类型可以映射为数据库的Char类型,这是通过使用Hibernate的注解或XML映射文件来实现的。 如果我们想将JavaBoolean类型属性映射为数据库的Char类型字段,我们可以在实体类使用Hibernate的注解@Type来指定映射类型。例如,我们可以使用@Type注解,并设置type属性为"yes_no",这将会将Boolean类型属性映射为数据库的Char(1)类型,并使用"Y"表示true,"N"表示false。 另外,我们还可以使用Hibernate的注解@Column来指定数据库字段的相关属性。例如,我们可以使用@Column注解,并设置columnDefinition属性为"char(1)",这将会在数据库创建一个Char类型长度为1的字段。 以下是一个示例代码: ```java @Entity @Table(name = "example") public class ExampleEntity { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @Column(columnDefinition = "char(1)") @Type(type = "yes_no") private Boolean flag; // 其他属性和方法... } ``` 通过这种方式,我们可以将JavaBoolean类型属性映射为数据库的Char类型字段,实现在Hibernate对这两种类型之间的映射。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值