Java reference

Java数据类型与引用详解
本文详细介绍了Java中的数据类型,包括原始类型如byte、short、int等,以及复杂类型如类、接口、数组等,并深入探讨了不同引用类型的特点及其应用场景。

Reference思考

原写于 2010-12-18

 

一. Java数据类型

数据类型就是对内存位置的抽象表达(很多编程语言都依赖于特定的计算机类型和对数据类型属性的具体编译实现,比如word和integer数据类型的大小等;Java通过JVM保证数据所占存储空间的大小不会随硬件的改变发生变化)。

 

1.Primitive data type :A primitive type is predefined by the language and is named by a reserved keyword. Primitive values do not share state with other primitive values. The eight primitive data types supported by the Java programming language。

原生类型是语言自身预先定义的,原生值不会与其他原生值共享状态。有8中原生类型被Java语言支持,如下:byte(8位)、short(16位)、int(32位)、long(64位)、float(浮点数,32位)、double(浮点数,64位)、boolean(1位,只有true或false可取)、char(16-bit Unicode character)

 

2.复杂数据类型

运行期动态创建,一切皆为对象。

- 接口(定义行为)

- 类(String objects are immutable, which means that once created, their values cannot be changed.)

- 数组

- 引用(软、弱、虚引用)

 

二. Reference分类

1. strong Reference :正常情况下的引用都属于strong引用,如:String str = new String();str是strong reference。其它引用必须是显式的声明,如:SoftReference softRef = new SoftReferencne(str),softRef是弱引用。

2. SoftReference :软引用。在内存溢出前,垃圾收集器将回收其引用的对象。

3. WeakReference :弱引用。任何垃圾回收,扫描到弱引用时,其引用的对象都会被回收。

4. PhantomReference :不理解。

写道
补充:ReferenceQueue
Reference queues, to which registered reference objects are appended by the garbage collector after the appropriate reachability changes are detected.
当某个引用对象的可达性被垃圾搜集器改变或清除后,会被放入对应的 ReferenceQueue 中(如果注册引用队列)。
String str = new String("hello");
ReferenceQueue<String> refQuence = new ReferenceQueue<String>();
SoftReference<String> softRef = new SoftReference<String>(str, refQuence);
str = null; // 垃圾回收
如上例:当“hello”对象被收回后,则softRef会被加入到ReferenceQueue。

 

 

三.WeakHashMap简单分析

 

简化WeakHashMap结构:

class WeakHashMap<K, V> {
	private final ReferenceQueue<K> queue = new ReferenceQueue<K>();
	private Entry[] table;
	private static class Entry<K,V> extends WeakReference<K> implements Map.Entry<K,V> {}
}

分析:WeakHashMap的put方法(Map对数据的保存也是通过数组实现)

public V put(K key, V value) {
        K k = (K) maskNull(key);
        int h = HashMap.hash(k.hashCode());
        Entry[] tab = getTable(); //获取table(关键:调用expungeStaleEntries方法,清洗table数组中,value所指的实际对象已被GC)
        int i = indexFor(h, tab.length); //根据key.hash计算在数组的位置

		//从此位置开始,遍历单向链表,判断此位置是否已经存在相同元素
		//1.有,更新为value
//2.无,创建新的对象,置原头部元素为自己的next,让自身为单向链表头部
        for (Entry<K,V> e = tab[i]; e != null; e = e.next) {
			//如果hash相等,且equals相等
            if (h == e.hash && eq(k, e.get())) {
                V oldValue = e.value;
                if (value != oldValue)
                    e.value = value;
                return oldValue;
            }
        }
        modCount++;
	    Entry<K,V> e = tab[i];
		//queue是ReferenceQueue,h自身key计算得到的hash值,e指向单链表下一个节点next
        tab[i] = new Entry<K,V>(k, value, queue, h, e);
        if (++size >= threshold) //判断数组容量是否需要扩充,策略:2倍
            resize(tab.length * 2);
        return null;
    }

/*
* 清洗已被gc对象的引用,释放数组的容量
*/
private void expungeStaleEntries() {
		Entry<K,V> e;
        while ( (e = (Entry<K,V>) queue.poll()) != null) { //从队列获取第一个加入ReferenceQueue的引用,循环
            int h = e.hash;
            int i = indexFor(h, table.length);

            Entry<K,V> prev = table[i];
            Entry<K,V> p = prev;
            while (p != null) { //检查单链表的数据是否已陈旧,清洗
                Entry<K,V> next = p.next;
                if (p == e) { //若相等,说明引用的对象已被gc
                    if (prev == e)
                        table[i] = next;
                    else
                        prev.next = next;
				    //因为其引用对象被垃圾收集器改变可达性时,也会被放入queue,所以强制设置其next、value为null,帮助gc收集其引用对象(不这样的理解正确不?请大家指点)
                    e.next = null;  // Help GC
                    e.value = null; //  "   "
                    size--;
                    break;
                }
                prev = p;
                p = next;
            }
        }
    }

 

 

 四.总结

 引用也是属于Java的比较特殊的数据类型,对于软、弱引用的使用场景大多是“缓存”。

基于matlab建模FOC观测器采用龙贝格观测器+PLL进行无传感器控制(Simulink仿真实现)内容概要:本文档主要介绍基于Matlab/Simulink平台实现的多种科研仿真项目,涵盖电机控制、无人机路径规划、电力系统优化、信号处理、图像处理、故障诊断等多个领域。重点内容之一是“基于Matlab建模FOC观测器,采用龙贝格观测器+PLL进行无传感器控制”的Simulink仿真实现,该方法通过状态观测器估算电机转子位置与速度,结合锁相环(PLL)实现精确控制,适用于永磁同步电机等无位置传感器驱动场景。文档还列举了大量相关科研案例与算法实现,如卡尔曼滤波、粒子群优化、深度学习、多智能体协同等,展示了Matlab在工程仿真与算法验证中的广泛应用。; 适合人群:具备一定Matlab编程基础,从事自动化、电气工程、控制科学、机器人、电力电子等相关领域的研究生、科研人员及工程技术人员。; 使用场景及目标:①学习并掌握FOC矢量控制中无传感器控制的核心原理与实现方法;②理解龙贝格观测器与PLL在状态估计中的作用与仿真建模技巧;③借鉴文中丰富的Matlab/Simulink案例,开展科研复现、算法优化或课程设计;④应用于电机驱动系统、无人机控制、智能电网等实际工程仿真项目。; 阅读建议:建议结合Simulink模型与代码进行实践操作,重点关注观测器设计、参数整定与仿真验证流程。对于复杂算法部分,可先从基础案例入手,逐步深入原理分析与模型改进。
IEEE33节点电力系统中模拟接入光伏并网simulink仿真(分析电能质量)内容概要:本文档围绕IEEE33节点电力系统中模拟接入光伏并网的Simulink仿真展开,重点分析光伏并网对电能质量的影响。文中构建了完整的光伏发电系统模型,包括光伏阵列、逆变器(如T型三电平逆变器)、并网控制策略及电力系统接口,并通过Simulink仿真平台进行建模与分析。核心内容涵盖MPPT控制、逆变器DPWM调制技术、载波优化以降低开关损耗、并网后的电压波动、谐波畸变等电能质量问题的评估与改善措施。同时,文档提及多种相关仿真案例和技术手段,突出其在电力系统仿真与优化中的综合性与实用性。; 适合人群:具备电力系统、新能源发电或自动化控制基础知识的高校学生、科研人员及从事光伏并网系统设计的工程技术人员。; 使用场景及目标:①开展光伏并网系统对配电网电能质量影响的研究;②学习并掌握基于Simulink的电力电子系统建模与仿真方法;③进行逆变器控制策略(如DPWM、MPPT)的设计与优化;④支撑课程设计、毕业论文或科研项目中的仿真验证环节。; 阅读建议:建议结合Simulink软件实际操作,逐步搭建系统模型,重点关注逆变器控制与并网接口部分的实现细节,同时对比不同工况下的仿真结果以深入理解光伏接入对IEEE33节点系统电能质量的具体影响。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值