Java与C++内存分配
Java Vs C++ Memory Allocation
c++中的示例
Employee emp=new Employee();
现在在这里创建x字节来存储Employee。存储引用需要y字节。因此需要x+y字节。
现在在c++中,由于没有垃圾回收,它的程序员有责任销毁对象。
员工emp2=emp;
问题1:现在它是否为emp2再创建一个(x+y)的地址空间?
在Java 中
它只是指向堆中的对象。
问题2:那么,这是否意味着,如果同一个对象被添加到java中的ArrayList中,比如说100次,那么所使用的内存只用于将对象的引用存储在堆中即只使用100*y+x的内存量
那么,这是否意味着,如果在java中将同一个对象添加到ArrayList中,比如说100次,那么所使用的内存只用于在堆中存储对象的引用?即只使用100*y+x数量的内存-是的。在集合中,只添加对实际对象的引用(这些对象几乎总是在堆上)。
附带说明一下,java具有4字节引用,而与体系结构无关(32位/64位)。
函数调用的局部变量有堆栈内存;作为函数调用的堆栈是嵌套的。
这是变量的内存。在Java中,对对象的引用。对象本身存储在堆中,垃圾回收。数组也是Java中的对象。Java在堆栈上没有C结构作为"复杂"C++的继承者,这是一个保持一切简单的历史设计决策
现在在C++中,堆栈上有一个立即结构或数组(没有new/malloc)。然后,您需要一个复制构造函数,它将数据从一个空间铲送到另一个空间(堆栈或堆)。
有效的区别在于,在C中,可以有一个链表,其中每个节点都是胖的,里面有数据。在Java中,比如说LinkedList<T>
,每个节点(堆对象)都将包含一个额外的间接性,即对T数据对象的引用。数据可能在Java中共享,也可能在C.中复制
从这个角度来看,你可以自己计算内存使用情况。我觉得有必要提到,Java良好的垃圾收集总体上比malloc/free of C要好。所以Java当然没有那么糟糕。
- 在c++中为我自己的基于指针的数组分配内存的正确方法
- 给定一个指向堆分配内存的指针,智能指针实现如何为其找到合适的释放函数?
- 如果 const 不分配内存,为什么我可以获取 const 的地址?
- 在函数中分配内存时出现问题
- 如何为 std::vector 分配内存,然后稍后为某些元素调用构造函数?
- constexpr new 如何分配内存?
- 在构造函数中分配内存失败是如何冒泡的
- LLVM 传递以在特定地址分配内存
- CudaMalloc 在分配内存时失败
- 为什么它在不分配内存的情况下工作正常
- 为什么在正确解除分配内存时出现内存泄漏?
- 如何通过 malloc 为队列数组分配内存?
- vector是否为std::移动的对象连续分配内存
- 删除类成员的动态分配内存的最佳方法是什么
- 唯一指针是否在堆或堆栈上分配内存?
- 如果不分配内存,我如何能够为变量创建和分配值?
- std::initializer_list 堆是否分配内存?
- 如何按顺序或在指定的地址分配内存?
- 是否可以使用 malloc 为类对象分配内存?
- 迭代器是否分配内存(如指针)?