爆款云主机2核4G限时秒杀,88元/年起!
查看详情

活动

天翼云最新优惠活动,涵盖免费试用,产品折扣等,助您降本增效!
热门活动
  • 618智算钜惠季 爆款云主机2核4G限时秒杀,88元/年起!
  • 免费体验DeepSeek,上天翼云息壤 NEW 新老用户均可免费体验2500万Tokens,限时两周
  • 云上钜惠 HOT 爆款云主机全场特惠,更有万元锦鲤券等你来领!
  • 算力套餐 HOT 让算力触手可及
  • 天翼云脑AOne NEW 连接、保护、办公,All-in-One!
  • 中小企业应用上云专场 产品组合下单即享折上9折起,助力企业快速上云
  • 息壤高校钜惠活动 NEW 天翼云息壤杯高校AI大赛,数款产品享受线上订购超值特惠
  • 天翼云电脑专场 HOT 移动办公新选择,爆款4核8G畅享1年3.5折起,快来抢购!
  • 天翼云奖励推广计划 加入成为云推官,推荐新用户注册下单得现金奖励
免费活动
  • 免费试用中心 HOT 多款云产品免费试用,快来开启云上之旅
  • 天翼云用户体验官 NEW 您的洞察,重塑科技边界

智算服务

打造统一的产品能力,实现算网调度、训练推理、技术架构、资源管理一体化智算服务
智算云(DeepSeek专区)
科研助手
  • 算力商城
  • 应用商城
  • 开发机
  • 并行计算
算力互联调度平台
  • 应用市场
  • 算力市场
  • 算力调度推荐
一站式智算服务平台
  • 模型广场
  • 体验中心
  • 服务接入
智算一体机
  • 智算一体机
大模型
  • DeepSeek-R1-昇腾版(671B)
  • DeepSeek-R1-英伟达版(671B)
  • DeepSeek-V3-昇腾版(671B)
  • DeepSeek-R1-Distill-Llama-70B
  • DeepSeek-R1-Distill-Qwen-32B
  • Qwen2-72B-Instruct
  • StableDiffusion-V2.1
  • TeleChat-12B

应用商城

天翼云精选行业优秀合作伙伴及千余款商品,提供一站式云上应用服务
进入甄选商城进入云市场创新解决方案
办公协同
  • WPS云文档
  • 安全邮箱
  • EMM手机管家
  • 智能商业平台
财务管理
  • 工资条
  • 税务风控云
企业应用
  • 翼信息化运维服务
  • 翼视频云归档解决方案
工业能源
  • 智慧工厂_生产流程管理解决方案
  • 智慧工地
建站工具
  • SSL证书
  • 新域名服务
网络工具
  • 翼云加速
灾备迁移
  • 云管家2.0
  • 翼备份
资源管理
  • 全栈混合云敏捷版(软件)
  • 全栈混合云敏捷版(一体机)
行业应用
  • 翼电子教室
  • 翼智慧显示一体化解决方案

合作伙伴

天翼云携手合作伙伴,共创云上生态,合作共赢
天翼云生态合作中心
  • 天翼云生态合作中心
天翼云渠道合作伙伴
  • 天翼云代理渠道合作伙伴
天翼云服务合作伙伴
  • 天翼云集成商交付能力认证
天翼云应用合作伙伴
  • 天翼云云市场合作伙伴
  • 天翼云甄选商城合作伙伴
天翼云技术合作伙伴
  • 天翼云OpenAPI中心
  • 天翼云EasyCoding平台
天翼云培训认证
  • 天翼云学堂
  • 天翼云市场商学院
天翼云合作计划
  • 云汇计划
天翼云东升计划
  • 适配中心
  • 东升计划
  • 适配互认证

开发者

开发者相关功能入口汇聚
技术社区
  • 专栏文章
  • 互动问答
  • 技术视频
资源与工具
  • OpenAPI中心
开放能力
  • EasyCoding敏捷开发平台
培训与认证
  • 天翼云学堂
  • 天翼云认证
魔乐社区
  • 魔乐社区

支持与服务

为您提供全方位支持与服务,全流程技术保障,助您轻松上云,安全无忧
文档与工具
  • 文档中心
  • 新手上云
  • 自助服务
  • OpenAPI中心
定价
  • 价格计算器
  • 定价策略
基础服务
  • 售前咨询
  • 在线支持
  • 在线支持
  • 工单服务
  • 建议与反馈
  • 用户体验官
  • 服务保障
  • 客户公告
  • 会员中心
增值服务
  • 红心服务
  • 首保服务
  • 客户支持计划
  • 专家技术服务
  • 备案管家

了解天翼云

天翼云秉承央企使命,致力于成为数字经济主力军,投身科技强国伟大事业,为用户提供安全、普惠云服务
品牌介绍
  • 关于天翼云
  • 智算云
  • 天翼云4.0
  • 新闻资讯
  • 天翼云APP
基础设施
  • 全球基础设施
  • 信任中心
最佳实践
  • 精选案例
  • 超级探访
  • 云杂志
  • 分析师和白皮书
  • 天翼云·创新直播间
市场活动
  • 2025智能云生态大会
  • 2024智算云生态大会
  • 2023云生态大会
  • 2022云生态大会
  • 天翼云中国行
天翼云
  • 活动
  • 智算服务
  • 产品
  • 解决方案
  • 应用商城
  • 合作伙伴
  • 开发者
  • 支持与服务
  • 了解天翼云
      • 文档
      • 控制中心
      • 备案
      • 管理中心

      Java引用类型

      首页 知识中心 软件开发 文章详情页

      Java引用类型

      2023-05-06 09:00:06 阅读次数:114

      java

               最近在跟人聊java的容器,在聊到WeakHashMap时,被问Weak是什么意思,当时没能回答出来,后面同事继续问java有哪几种引用,当时便有一种智商严重不足的感觉。于是便整理出这篇文章,希望各位多提意见。

               java中提供了4个级别的引用:强引用、软引用、弱引用和虚引用。这4个引用在java.lang.ref包下:

      Java引用类型

      一、强引用(FinalReference)

               强引用在程序代码这是普遍存在的,类似Object o = new Object()这类的引用,只要强引用还存在,垃圾回收集器永远不会回收被引用的对象。

               强引用具备以下三个特点:

      1、强引用可以直接访问目标对象。

      2、强引用锁指向的对象任何时候都不会被系统回收。JVM宁愿抛出OOM(OutOfMemory)异常也不回收强引用所指向的对象。

      3、强引用可能导致内存泄漏。

       

      强引用的源码如下:

       

      package java.lang.ref;
      
      /**
       * Final references, used to implement finalization
       */
      class FinalReference<T> extends Reference<T> {
      
          public FinalReference(T referent, ReferenceQueue<? super T> q) {
              super(referent, q);
          }
      }
      只有一个构造函数,根据所给的对象的引用和引用队列构造一个强引用。

       

      二、软引用(SoftReference)

      用来描述一类还有用但并非必须的对象。对于软引用关联着的对象,在系统将要发生内存溢出异常之前,将会把这些对象列进回收范围之中进行第二次回收。如果这次回收还没有足够的内存,才会抛出内存溢出异常。

        对于软引用关联着的对象,如果内存充足,则垃圾回收器不会回收这些对象的内存,如果内存不足,则这些对象的内存被回收。在JDK1.2之后,提供了SoftReference类来实现软引用。软引用可以用来实现内存敏感的高速缓存。软引用可以和一个引用队列(ReferenceQueue)联合使用,如果软引用所引用的对象被垃圾回收器回收,java虚拟机就会把这个软引用加入到与之关联的引用队列中。

       

      package collections.ref;
      
      import java.lang.ref.Reference;
      import java.lang.ref.ReferenceQueue;
      import java.lang.ref.SoftReference;
      
      public class SoftRefTest
      {
          private static ReferenceQueue<MyObject> softQueue = new ReferenceQueue<>();
      
          public static class MyObject{
      
              @Override
              protected void finalize() throws Throwable
              {
                  super.finalize();
                  System.out.println("MyObject's finalize called");
              }
      
              @Override
              public String toString()
              {
                  return "I am MyObject";
              }
          }
      
          public static class CheckRefQueue implements Runnable
          {
              Reference<MyObject> obj = null;
              @Override
              public void run()
              {
                  try
                  {
                      obj = (Reference<MyObject>)softQueue.remove();
                  }
                  catch (InterruptedException e)
                  {
                      e.printStackTrace();
                  }
                  if(obj != null)
                  {
                      System.out.println("Object for SoftReference is "+obj.get());
                  }
              }
          }
      
          public static void main(String[] args)
          {
              MyObject object = new MyObject();
              SoftReference<MyObject> softRef = new SoftReference<>(object,softQueue);
              new Thread(new CheckRefQueue()).start();
      
              object = null;    //删除强引用
              System.gc();
              System.out.println("After GC: Soft Get= "+softRef.get());
              System.out.println("分配大块内存");
              byte[] b = new byte[5*1024*928];
              System.out.println("After new byte[]:Soft Get= "+softRef.get());
              System.gc();
          }
      }

      运行参数1:

       

       

      -Xmx5M
      运行结果:

       

       

      After GC: Soft Get= I am MyObject
      分配大块内存
      MyObject's finalize called
      Object for SoftReference is null
      After new byte[]:Soft Get= null
      运行参数2:

       

       

      -Xmx5M -XX:PrintGCDetails
      运行结果2:

       

       

      [GC [PSYoungGen: 680K->504K(2560K)] 680K->512K(6144K), 0.0040658 secs] [Times: user=0.00 sys=0.00, real=0.00 secs] 
      [Full GC [PSYoungGen: 504K->0K(2560K)] [ParOldGen: 8K->482K(3584K)] 512K->482K(6144K) [PSPermGen: 2491K->2490K(21504K)], 0.0188479 secs] [Times: user=0.01 sys=0.00, real=0.02 secs] 
      After GC: Soft Get= I am MyObject
      分配大块内存
      [GC [PSYoungGen: 123K->64K(2560K)] 605K->546K(7680K), 0.0004285 secs] [Times: user=0.00 sys=0.00, real=0.00 secs] 
      [GC [PSYoungGen: 64K->64K(2560K)] 546K->546K(7680K), 0.0003019 secs] [Times: user=0.00 sys=0.00, real=0.00 secs] 
      [Full GC [PSYoungGen: 64K->0K(2560K)] [ParOldGen: 482K->482K(4608K)] 546K->482K(7168K) [PSPermGen: 2493K->2493K(21504K)], 0.0094748 secs] [Times: user=0.02 sys=0.00, real=0.01 secs] 
      [GC [PSYoungGen: 0K->0K(2560K)] 482K->482K(7680K), 0.0003759 secs] [Times: user=0.00 sys=0.00, real=0.00 secs] 
      [Full GC [PSYoungGen: 0K->0K(2560K)] [ParOldGen: 482K->472K(5120K)] 482K->472K(7680K) [PSPermGen: 2493K->2493K(21504K)], 0.0101017 secs] [Times: user=0.06 sys=0.00, real=0.01 secs] 
      MyObject's finalize called
      Object for SoftReference is null
      After new byte[]:Soft Get= null
      [GC [PSYoungGen: 122K->32K(2560K)] 5235K->5144K(7680K), 0.0004806 secs] [Times: user=0.00 sys=0.00, real=0.00 secs] 
      [Full GC [PSYoungGen: 32K->0K(2560K)] [ParOldGen: 5112K->5112K(5120K)] 5144K->5112K(7680K) [PSPermGen: 2493K->2493K(21504K)], 0.0136270 secs] [Times: user=0.06 sys=0.00, real=0.01 secs] 
      Heap
       PSYoungGen      total 2560K, used 20K [0x00000000ffd00000, 0x0000000100000000, 0x0000000100000000)
        eden space 2048K, 1% used [0x00000000ffd00000,0x00000000ffd05250,0x00000000fff00000)
        from space 512K, 0% used [0x00000000fff00000,0x00000000fff00000,0x00000000fff80000)
        to   space 512K, 0% used [0x00000000fff80000,0x00000000fff80000,0x0000000100000000)
       ParOldGen       total 5120K, used 5112K [0x00000000ff800000, 0x00000000ffd00000, 0x00000000ffd00000)
        object space 5120K, 99% used [0x00000000ff800000,0x00000000ffcfe188,0x00000000ffd00000)
       PSPermGen       total 21504K, used 2500K [0x00000000fa600000, 0x00000000fbb00000, 0x00000000ff800000)
        object space 21504K, 11% used [0x00000000fa600000,0x00000000fa871190,0x00000000fbb00000)

             加入 -XX:PrintGCDetails参数运行可以更形象的看到GC回收的细节。 
        这个案例1中,首先构造MyObject对象,并将其赋值给object变量,构成强引用。然后使用SoftReference构造这个MyObject对象的软引用softRef,并注册到softQueue引用队列。当softRef被回收时,会被加入softQueue队列。设置obj=null,删除这个强引用,因此,系统内对MyObject对象的引用只剩下软引用。此时,显示调用GC,通过软引用的get()方法,取得MyObject对象的引用,发现对象并未被回收,这说明GC在内存充足的情况下,不会回收软引用对象。 
        接着,请求一块大的堆空间5*1024*928,这个操作会使系统堆内存使用紧张,从而产生新一轮的GC。在这次GC后,softRef.get()不再返回MyObject对象,而是返回null,说明在系统内存紧张的情况下,软引用被回收。软引用被回收时,会被加入注册的引用队列。 
        如果将上面案例中的数组再改大点,比如5*1024*1024,就会抛出OOM异常:

       

       

      After GC: Soft Get= I am MyObject
      分配大块内存
      MyObject's finalize called
      Object for SoftReference is null
      Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
          at collections.ref.SoftRefTest.main(SoftRefTest.java:58)

      软引用主要应用于内存敏感的高速缓存,在 Android 系统中经常使用到。一般情况下,Android应用会用到大量的默认图片,这些图片很多地方会用到。如果每次都去读取图片,由于读取文件需要硬件操作,速度较慢,会导致性能较低。所以我们考虑将图片缓存起来,需要的时候直接从内存中读取。但是,由于图片占用内存空间比较大,缓存很多图片需要很多的内存,就可能比较容易发生OutOfMemory异常。这时,我们可以考虑使用软引用技术来避免这个问题发生。SoftReference可以解决oom的问题,每一个对象通过软引用进行实例化,这个对象就以cache的形式保存起来,当再次调用这个对象时,那么直接通过软引用中的get()方法,就可以得到对象中中的资源数据,这样就没必要再次进行读取了,直接从cache中就可以读取得到,当内存将要发生OOM的时候,GC会迅速把所有的软引用清除,防止oom发生。

       

       案例2:

       

      public class BitMapManager {
          private Map<String, SoftReference<Bitmap>> imageCache = new HashMap<String, SoftReference<Bitmap>>();
      
          //保存Bitmap的软引用到HashMap
          public void saveBitmapToCache(String path) {
              // 强引用的Bitmap对象
              Bitmap bitmap = BitmapFactory.decodeFile(path);
              // 软引用的Bitmap对象
              SoftReference<Bitmap> softBitmap = new SoftReference<Bitmap>(bitmap);
              // 添加该对象到Map中使其缓存
              imageCache.put(path, softBitmap);
              // 使用完后手动将位图对象置null
              bitmap = null;
          }
      
          public Bitmap getBitmapByPath(String path) {
      
              // 从缓存中取软引用的Bitmap对象
              SoftReference<Bitmap> softBitmap = imageCache.get(path);
              // 判断是否存在软引用
              if (softBitmap == null) {
                  return null;
              }
              // 取出Bitmap对象,如果由于内存不足Bitmap被回收,将取得空
              Bitmap bitmap = softBitmap.get();
              return bitmap;
          }
      }

       

      三、弱引用(WeakReference)

      用来描述非必须的对象,但是它的强度比软引用更弱一些,被弱引用关联的对象只能生存到下一次垃圾收集发送之前。当垃圾收集器工作时,无论当前内存是否足够,都会回收掉只被弱引用关联的对象。一旦一个弱引用对象被垃圾回收器回收,便会加入到一个注册引用队列中。 
        我们略微修改一下案例1的代码,如下:

       

      package collections.ref;
      
      import java.lang.ref.Reference;
      import java.lang.ref.ReferenceQueue;
      import java.lang.ref.WeakReference;
      
      public class WeakRefTest
      {
          private static ReferenceQueue<MyObject> weakQueue = new ReferenceQueue<>();
      
          public static class MyObject{
      
              @Override
              protected void finalize() throws Throwable
              {
                  super.finalize();
                  System.out.println("MyObject's finalize called");
              }
      
              @Override
              public String toString()
              {
                  return "I am MyObject";
              }
          }
      
          public static class CheckRefQueue implements Runnable
          {
              Reference<MyObject> obj = null;
              @Override
              public void run()
              {
                  try
                  {
                      obj = (Reference<MyObject>)weakQueue.remove();
                  }
                  catch (InterruptedException e)
                  {
                      e.printStackTrace();
                  }
                  if(obj != null)
                  {
                      System.out.println("删除的弱引用为:"+obj+"  but获取弱引用的对象obj.get()="+obj.get());
                  }
              }
          }
      
          public static void main(String[] args)
          {
              MyObject object = new MyObject();
              Reference<MyObject> weakRef = new WeakReference<>(object,weakQueue);
              System.out.println("创建的弱引用为:"+weakRef);
              new Thread(new CheckRefQueue()).start();
      
              object = null;
              System.out.println("Before GC: Weak Get= "+weakRef.get());
              System.gc();
              System.out.println("After GC: Weak Get= "+weakRef.get());
          }
      }

      不加参数运行结果:

       

       

      创建的弱引用为:java.lang.ref.WeakReference@29e07d3e
      Before GC: Weak Get= I am MyObject
      After GC: Weak Get= null
      MyObject's finalize called
      删除的弱引用为:java.lang.ref.WeakReference@29e07d3e  but获取弱引用的对象obj.get()=null

      可以看到,在GC之前,弱引用对象并未被垃圾回收器发现,因此通过 weakRef.get()可以获取对应的对象引用。但是只要进行垃圾回收, 弱引用一旦被发现,便会立即被回收 ,并加入注册引用队列中。此时再试图通过weakRef.get()获取对象的引用就会失败。 
        弱引用的相关实际案例可以参考WeakHashMap。

       

      软引用、弱引用都非常适合来保存那些可有可无的缓存数据。如果这么做,当系统内存不足时,这些缓存数据会被回收,不会导致内存溢出。而当内存资源充足时,这些缓存数据又可以存在相当长的时间,从而起来加速系统的作用。

       

      四、虚引用(PhantomReference)

      虚引用也称为幽灵引用或者幻影引用,它是最弱的一种引用关系。一个持有虚引用的对象,和没有引用几乎是一样的,随时都有可能被垃圾回收器回收。当试图通过虚引用的get()方法取得强引用时,总是会失败。并且,虚引用必须和引用队列一起使用,它的作用在于跟踪垃圾回收过程。 
        虚引用中get方法的实现如下:

       

      public T get() {
              return null;
          }
      可以看到永远返回null. 
        我们再来修改一下案例1的代码:
      package collections.ref;
      
      import java.lang.ref.PhantomReference;
      import java.lang.ref.Reference;
      import java.lang.ref.ReferenceQueue;
      import java.util.concurrent.TimeUnit;
      
      public class PhantomRefTest
      {
          private static ReferenceQueue<MyObject> phanQueue = new ReferenceQueue<>();
      
          public static class MyObject{
      
              @Override
              protected void finalize() throws Throwable
              {
                  super.finalize();
                  System.out.println("MyObject's finalize called");
              }
      
              @Override
              public String toString()
              {
                  return "I am MyObject";
              }
          }
      
          public static class CheckRefQueue implements Runnable
          {
              Reference<MyObject> obj = null;
              @Override
              public void run()
              {
                  try
                  {
                      obj = (Reference<MyObject>)phanQueue.remove();
                      System.out.println("删除的虚引用为:"+obj+"  but获取虚引用的对象obj.get()="+obj.get());
                      System.exit(0);
                  }
                  catch (InterruptedException e)
                  {
                      e.printStackTrace();
                  }
              }
          }
      
          public static void main(String[] args) throws InterruptedException
          {
              MyObject object = new MyObject();
              Reference<MyObject> phanRef = new PhantomReference<>(object,phanQueue);
              System.out.println("创建的虚引用为:"+phanRef);
              new Thread(new CheckRefQueue()).start();
      
              object = null;
              TimeUnit.SECONDS.sleep(1);
              int i =1;
              while(true)
              {
                  System.out.println("第"+i+++"次gc");
                  System.gc();
                  TimeUnit.SECONDS.sleep(1);
              }
          }
      }

      运行结果:

       

       

      创建的虚引用为:java.lang.ref.PhantomReference@3a6646fc
      第1次gc
      MyObject's finalize called
      第2次gc
      删除的虚引用为:java.lang.ref.PhantomReference@3a6646fc  but获取虚引用的对象obj.get()=null

      可以看到,再经过一次GC之后,系统找到了垃圾对象,并调用finalize()方法回收内存,但没有立即加入回收队列。第二次GC时,该对象真正被GC清楚,此时,加入虚引用队列。 
         虚引用的最大作用在于跟踪对象回收,清理被销毁对象的相关资源。 
         通常当对象不被使用时,重载该对象的类的finalize方法可以回收对象的资源。但是如果使用不慎,会使得对象复活,譬如这么编写finalize方法:

       

       

      public class Test{
          public static Test obj;
      
          @Override protected void finalize() throws Throwable{
              super.finalize();
              obj = this;
          }
      }
      对上面这个类Test中obj = new Test();然后obj=null;之后调用System.gc()企图销毁对象,但是很抱歉,不管你调用多少次System.gc()都没有什么用,除非你在下面的代码中再就obj=null;这样才能回收对象,这是因为JVM对某一个对象至多只执行一次被重写的finalize方法。 
        上面的小片段说明重写finalize的方法并不是很靠谱,可以使用虚引用来清理对象所占用的资源。 
        如下代码所示:
      public class PhantomRefTest2
      {
          private static ReferenceQueue<MyObject> phanQueue = new ReferenceQueue<>();
          private static Map<Reference<MyObject>,String> map = new HashMap<>();
      
          public static class MyObject{
      
              @Override
              protected void finalize() throws Throwable
              {
                  super.finalize();
                  System.out.println("MyObject's finalize called");
              }
      
              @Override
              public String toString()
              {
                  return "I am MyObject";
              }
          }
      
          public static class CheckRefQueue implements Runnable
          {
              Reference<MyObject> obj = null;
              @Override
              public void run()
              {
                  try
                  {
                      obj = (Reference<MyObject>)phanQueue.remove();
                      Object value = map.get(obj);
                      System.out.println("clean resource:"+value);
                      map.remove(obj);
      
                      System.out.println("删除的虚引用为:"+obj+"  but获取虚引用的对象obj.get()="+obj.get());
                      System.exit(0);
                  }
                  catch (InterruptedException e)
                  {
                      e.printStackTrace();
                  }
              }
          }
      
          public static void main(String[] args) throws InterruptedException
          {
              MyObject object = new MyObject();
              Reference<MyObject> phanRef = new PhantomReference<>(object,phanQueue);
              System.out.println("创建的虚引用为:"+phanRef);
              new Thread(new CheckRefQueue()).start();
              map.put(phanRef, "Some Resources");
      
              object = null;
              TimeUnit.SECONDS.sleep(1);
              int i =1;
              while(true)
              {
                  System.out.println("第"+i+++"次gc");
                  System.gc();
                  TimeUnit.SECONDS.sleep(1);
              }
          }
      }
      运行结果:
      创建的虚引用为:java.lang.ref.PhantomReference@6a07348e
      第1次gc
      MyObject's finalize called
      第2次gc
      clean resource:Some Resources
      删除的虚引用为:java.lang.ref.PhantomReference@6a07348e  but获取虚引用的对象obj.get()=null
      版权声明:本文内容来自第三方投稿或授权转载,原文地址:https://blog.csdn.net/youzhouliu/article/details/51492062,作者:youzhouliu,版权归原作者所有。本网站转在其作品的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如因作品内容、版权等问题需要同本网站联系,请发邮件至ctyunbbs@chinatelecom.cn沟通。

      上一篇:C语言找画笔(全网最详)

      下一篇:python代码-FTP备份交换机配置脚本

      相关文章

      2025-05-14 10:02:58

      java休眠到指定时间怎么写

      java休眠到指定时间怎么写

      2025-05-14 10:02:58
      java , sleep , Thread , util , 方法
      2025-05-14 10:02:58

      java项目多端数据同步解决方案

      多端数据同步是指在多个设备(例如桌面应用、移动应用、Web应用)之间保持数据的一致性。

      2025-05-14 10:02:58
      java , Spring , WebSocket , 同步 , 数据 , 版本号
      2025-05-13 09:49:12

      Java学习(动态代理的思想详细分析与案例准备)(1)

      Java学习(动态代理的思想详细分析与案例准备)(1)

      2025-05-13 09:49:12
      java , 代理 , 代码 , 对象 , 接口 , 方法 , 需要
      2025-05-09 08:20:32

      基于IDEA的Maven简单工程创建及结构分析

      通过一个 mvn 命令直接让我们创建一个 Maven 的脚手架。

      2025-05-09 08:20:32
      java , Maven , xml , 创建 , 文件 , 文件夹 , 项目
      2025-05-08 09:03:57

      前K个高频元素java

      给定一个非空的整数数组,返回其中出现频率前 前K个高频元素java 高的元素。

      2025-05-08 09:03:57
      java , 元素 , 样例 , 给定
      2025-05-08 09:03:21

      基于java Swing开发的学生成绩管理系统【项目源码+数据库脚本】

      基于java Swing开发的学生成绩管理系统【项目源码+数据库脚本】

      2025-05-08 09:03:21
      java , Swing , 学生 , 源码
      2025-05-08 09:03:21

      java Swing学生成绩管理系统【项目源码+数据库脚本】

      本项目是一套基于java Swing开发的学生成绩管理系统,主要针对计算机相关专业的正在做bishe的学生和需要项目实战练习的Java学习者。

      2025-05-08 09:03:21
      java , 学生 , 成绩 , 数据库 , 源码
      2025-05-07 09:08:08

      java Swing学生选课管理系统【源码+数据库+报告】

      本项目是一套基于java Swing学生选课管理系统,主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的Java学习者。

      2025-05-07 09:08:08
      java , 学生 , 截图 , 源码
      2025-05-07 09:08:08

      java swing人机对战五子棋(含背景音乐)

      本项目是一套基于java swing的人机对战五子棋系统,主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的Java学习者。

      2025-05-07 09:08:08
      java , 源码
      2025-04-22 09:40:08

      【ETL工具】kettle 程序报错 Javascript error: TypeError: Cannot call method “trim“ of null

      【ETL工具】kettle 程序报错 Javascript error: TypeError: Cannot call method “trim“ of null

      2025-04-22 09:40:08
      java , javascript , org
      查看更多
      推荐标签

      作者介绍

      天翼云小翼
      天翼云用户

      文章

      33561

      阅读量

      5264824

      查看更多

      最新文章

      java项目多端数据同步解决方案

      2025-05-14 10:02:58

      Java学习(动态代理的思想详细分析与案例准备)(1)

      2025-05-13 09:49:12

      前K个高频元素java

      2025-05-08 09:03:57

      基于java Swing开发的学生成绩管理系统【项目源码+数据库脚本】

      2025-05-08 09:03:21

      java Swing学生成绩管理系统【项目源码+数据库脚本】

      2025-05-08 09:03:21

      java Swing学生选课管理系统【源码+数据库+报告】

      2025-05-07 09:08:08

      查看更多

      热门文章

      JAVA__接口的作用

      2023-04-18 14:14:13

      Java学习之算术运算符两只老虎

      2023-04-19 09:23:13

      排序算法Java版-归并排序算法

      2023-04-24 11:25:19

      JAVA多线程学习笔记

      2023-05-11 06:05:48

      try...catch...finally java

      2023-03-29 09:40:26

      Java:apache.poi读写Excel文件

      2023-02-22 06:40:54

      查看更多

      热门标签

      java Java python 编程开发 代码 开发语言 算法 线程 Python html 数组 C++ 元素 javascript c++
      查看更多

      相关产品

      弹性云主机

      随时自助获取、弹性伸缩的云服务器资源

      天翼云电脑(公众版)

      便捷、安全、高效的云电脑服务

      对象存储

      高品质、低成本的云上存储服务

      云硬盘

      为云上计算资源提供持久性块存储

      查看更多

      随机文章

      Java正则匹配提取年月日字符串

      Java、SpringBoot中配置接口文档,knife4j、swagger

      一个json格式转xml格式的java实现

      新的日期和时间API

      java字节码编程技术(5/10)-应用

      Mac:Eclipse配置启动Java路径

      • 7*24小时售后
      • 无忧退款
      • 免费备案
      • 专家服务
      售前咨询热线
      400-810-9889转1
      关注天翼云
      • 旗舰店
      • 天翼云APP
      • 天翼云微信公众号
      服务与支持
      • 备案中心
      • 售前咨询
      • 智能客服
      • 自助服务
      • 工单管理
      • 客户公告
      • 涉诈举报
      账户管理
      • 管理中心
      • 订单管理
      • 余额管理
      • 发票管理
      • 充值汇款
      • 续费管理
      快速入口
      • 天翼云旗舰店
      • 文档中心
      • 最新活动
      • 免费试用
      • 信任中心
      • 天翼云学堂
      云网生态
      • 甄选商城
      • 渠道合作
      • 云市场合作
      了解天翼云
      • 关于天翼云
      • 天翼云APP
      • 服务案例
      • 新闻资讯
      • 联系我们
      热门产品
      • 云电脑
      • 弹性云主机
      • 云电脑政企版
      • 天翼云手机
      • 云数据库
      • 对象存储
      • 云硬盘
      • Web应用防火墙
      • 服务器安全卫士
      • CDN加速
      热门推荐
      • 云服务备份
      • 边缘安全加速平台
      • 全站加速
      • 安全加速
      • 云服务器
      • 云主机
      • 智能边缘云
      • 应用编排服务
      • 微服务引擎
      • 共享流量包
      更多推荐
      • web应用防火墙
      • 密钥管理
      • 等保咨询
      • 安全专区
      • 应用运维管理
      • 云日志服务
      • 文档数据库服务
      • 云搜索服务
      • 数据湖探索
      • 数据仓库服务
      友情链接
      • 中国电信集团
      • 189邮箱
      • 天翼企业云盘
      • 天翼云盘
      ©2025 天翼云科技有限公司版权所有 增值电信业务经营许可证A2.B1.B2-20090001
      公司地址:北京市东城区青龙胡同甲1号、3号2幢2层205-32室
      • 用户协议
      • 隐私政策
      • 个人信息保护
      • 法律声明
      备案 京公网安备11010802043424号 京ICP备 2021034386号