java堆,栈,常量池的一些资料整理汇集

看到下面这个例子时,也是一脸懵逼。就发现了自己对堆,栈,这些概念不清楚,于是上网看了一些前辈的资料,自己也参考着整理了一下
public class TestString3 {
	public static void main(String[]args){
		
		//维护在常量池里面
		String a ="hello";
		String b ="hello";
		 
		//new出来的所有对象都是在堆内存
		//只要是new出来的,都是新对象
		String c =new String("hello");
		String d =new String("hello");

		System.out.println(a==b);//true 
		System.out.println(a==c);//false
		System.out.println(c==d);//false
	}
}


堆:存放所有new出来的对象;
栈:存放基本类型的变量数据和对象的应用,对象(new出来的对象)本身并不存在栈中,而是存放在堆中或者常量池中.
常量池:存放基本类型常量和字符串常量。

静态域:存放静态成员(static定义的) 
常量池:存放字符串常量和基本类型常量(public static final)。 
非RAM存储:硬盘等永久存储空间

补充:
基本数据类型:Java固有的数据类型,可分为数字型,布尔型,字符型。
数字型:6类:byte(8位),short(16位),int(32位) long(64位),float(32位),double(64位) 
布尔型:true,false
字符型:char
变量:是一个由标识符命名的项,它具有类型和作用域,它的值可以改变。
常量:在变量声明格式前加上一个final修饰符,就声明了一个常量,常量一但被初始化就不能被改变

对于栈和常量池中的对象可以共享,对于堆中的对象不可以共享。
栈中的数据大小和生命周期是可以确定的,当没有引用指向数据时,这个数据就会自动消失。
堆中的对象的由垃圾回收器负责回收,因此大小和生命周期不需要确定,具有很大的灵活性。
而对于字符串来说,其对象的引用都是存储在栈中的,
如果是编译期已经创建好(即指用双引号定义的)的就存储在常量池中,
如果是运行期(new出来的对象)则存储在堆中。
对于equals相等的字符串,在常量池中是只有一份的,在堆中则有多份。

对于成员变量和局部变量:
成员变量就是方法外部、类的内部定义的变量;
局部变量就是方法或语句块内部定义的变量。局部变量必须初始化。 
形式参数是局部变量,局部变量的数据存在于栈内存中。
栈内存中的局部变量随着方法的消失而消失。 
成员变量存储在堆中的对象里面,由垃圾回收器负责回收。 

如以下代码: 

class BirthDate 
{
  private int day;
  private int month;
  private int year;
  public BirthDate(int d, int m, int y) 
{
  day = d;
  month = m;
  year = y;
  
}
  
  }
  public class Test
{
  public static void main(String args[])
{
  int date = 9;
  Test test = new Test();
  test.change(date);
  BirthDate d1= new BirthDate(7,7,1970);
  
}
  public void change1(int i)
{
  i = 1234;
  
}
对于以上这段代码,
date为局部变量,
i,d,m,y都是形参为局部变量,
day,month,year为成员变量。
下面分析一下代码执行时候的变化: 
 1. main方法开始执行:int date = 9; 
date局部变量,基础类型,引用和值都存在栈中。 
 2. Test test = new Test(); 
  test为对象引用,存在栈中,对象(new Test())存在堆中。 
 3. test.change(date); 
   i为局部变量,引用和值存在栈中。当方法change执行完成后,i就会从栈中消失。 
 4. BirthDate d1= new BirthDate(7,7,1970); 
   d1为对象引用,存在栈中,对象(new BirthDate())存在堆中,
其中d,m,y为局部变量存储在栈中,且它们的类型为基础类型,因此它们的数据也存储在栈中。
day,month,year为成员变量,它们存储在堆中(new BirthDate()里面)。
当BirthDate构造方法执行完之后,d,m,y将从栈中消失。 

  5.main方法执行完之后,date变量,test,d1引用将从栈中消失,new Test(),new BirthDate()将等待垃圾回收。

总结:

局部变量、形参、对象的引用、基本类型的变量数据存在栈中

new出来的对象存在堆中,只是它的引用在栈中。

(疑惑:new出来的基本类型数据是在哪儿?

//new出来的所有对象都是在堆内存
//只要是new出来的,都是新对象

所以new出的对象还是在堆中,其引用在栈中


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
目标检测(Object Detection)是计算机视觉领域的一个核心问题,其主要任务是找出图像中所有感兴趣的目标(物体),并确定它们的类别和位置。以下是对目标检测的详细阐述: 一、基本概念 目标检测的任务是解决“在哪里?是什么?”的问题,即定位出图像中目标的位置并识别出目标的类别。由于各类物体具有不同的外观、形状和姿态,加上成像时光照、遮挡等因素的干扰,目标检测一直是计算机视觉领域最具挑战性的任务之一。 二、核心问题 目标检测涉及以下几个核心问题: 分类问题:判断图像中的目标属于哪个类别。 定位问题:确定目标在图像中的具体位置。 大小问题:目标可能具有不同的大小。 形状问题:目标可能具有不同的形状。 三、算法分类 基于深度学习的目标检测算法主要分为两大类: Two-stage算法:先进行区域生成(Region Proposal),生成有可能包含待检物体的预选框(Region Proposal),再通过卷积神经网络进行样本分类。常见的Two-stage算法包括R-CNN、Fast R-CNN、Faster R-CNN等。 One-stage算法:不用生成区域提议,直接在网络中提取特征来预测物体分类和位置。常见的One-stage算法包括YOLO系列(YOLOv1、YOLOv2、YOLOv3、YOLOv4、YOLOv5等)、SSD和RetinaNet等。 四、算法原理 以YOLO系列为例,YOLO将目标检测视为回归问题,将输入图像一次性划分为多个区域,直接在输出层预测边界框和类别概率。YOLO采用卷积网络来提取特征,使用全连接层来得到预测值。其网络结构通常包含多个卷积层和全连接层,通过卷积层提取图像特征,通过全连接层输出预测结果。 五、应用领域 目标检测技术已经广泛应用于各个领域,为人们的生活带来了极大的便利。以下是一些主要的应用领域: 安全监控:在商场、银行
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值