Java对象存储

读书做笔记这个习惯一直没怎么养好,现在重读《Java编程思想》,把改记的都记下来。

 

以前一直不明白,下面两句有什么区别, 直到在书中看到Java对象的存储位置

String s1 = "abc";
String s2 = new String("abc");

  1. 寄存器。最快的存储区,位于cpu内部,数量有限,对程序员是透明的(c/c++允许向编译器建议寄存器的分配方式)
  2. 堆栈 。  位于通用RAM中,通过堆栈指针的上下移动来分配或释放内存,快速有效的分配存储。在创建程序时,java系统必须知道存储在堆栈内所有项的确切生命周期,以便上下移动指针(限制程序的灵活性),堆栈用于存储对象的引用。
  3. 堆。 通用的内存池,用于存放所有的Java对象。堆不同于堆栈的好处是:编译器不需要知道存储的数据在堆中存活多长时间。当用new创建一个对象时,在堆中进行存储分配。(灵活性的代价进行存储分配及清理可能比堆栈更需要时间,c++好像在栈中创建对象的)
  4. 常量存储。常量值通常直接存储在程序代码内部,比较安全,因为常量永远不被改变。(有时在嵌入式系统中,常量本身和其他部分隔离,可将其放在ROM中,如字符串池)
  5. 非RAM存储。如流对象和持久化对象

特例,其实Java中并非所有对象都是继承Object,比如基本类型(据说是为了吸引C++社区的人而保留的),不用new 来创建,而是创建一个并非是引用的“自动”变量,直接存储“值”并至于堆栈中

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java 中,将对象存储到 Redis 中有以下几种方式: 1. 将对象序列化为二进制数据,然后存储到 Redis 中。Java 中有多种序列化方式,如 JDK 自带的 Serializable 接口、Google 的 Protobuf、Apache 的 Avro 等。存储时可以使用 Redis 的二进制数据类型,如 `byte[]`、`String` 等。这种方式需要注意序列化和反序列化的性能问题,同时需要考虑序列化的兼容性问题。 2. 将对象转为 JSON 字符串,然后存储到 Redis 中。Java 中有多种 JSON 库,如 Google 的 Gson、阿里的 Fastjson 等。存储时可以使用 Redis 的字符串类型,如 `String`、`byte[]` 等。这种方式需要注意 JSON 库的性能问题,同时需要考虑 JSON 库的兼容性问题。 3. 将对象转为 Redis 的 Hash 结构,然后存储到 Redis 中。这种方式需要将对象的属性转为 Hash 的字段,可以使用 Java 反射机制进行转换。存储时可以使用 Redis 的 Hash 类型,如 `Map<String, String>`、`byte[]` 等。这种方式需要注意 Hash 字段和对象属性的映射关系,同时需要考虑 Hash 字段的数据类型问题。 4. 将对象转为 Redis 的 List 结构,然后存储到 Redis 中。这种方式需要将对象的属性转为 List 的元素,可以使用 Java 反射机制进行转换。存储时可以使用 Redis 的 List 类型,如 `List<String>`、`byte[]` 等。这种方式需要注意 List 元素和对象属性的映射关系,同时需要考虑 List 元素的数据类型问题。 需要注意的是,不同的存储方式适用于不同的场景,需要根据实际情况选择合适的方式。另外,存储到 Redis 中的数据需要考虑数据的安全性和可靠性问题,可以使用 Redis 提供的数据备份、持久化等功能进行保护。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值