weakreference(weakreference和softreference的区别)

http://www.itjxue.com  2023-02-12 05:20  来源:未知  点击次数: 

c++weakreference的原理

原理其实也很间单,其实就是在对象里添加了一个子对象masterReference,

对象在析构的时候主动调用masterReference.clear();,这样来达到通知弱指针的这个对象已经销毁了,可以设置为空了的目的。 感觉juce最后调用个clear还是觉得有点生硬,外层最好还是再嵌套一层,析构的时候自动调用clear就可以了,对象申明也写成宏,这样的话就简洁多了。

Java里什么是引用类型?

最简答来说除了8中基本类型以外剩下的都是引用类型

Java 提供两种不同的类型:引用类型和原始类型(或内置类型)。Int是java的原始数据类型,Integer是java为int提供的封装类。Java为每个原始类型提供了封装类。

原始类型封装类

boolean --Boolean

char ---Character

byte --Byte

short --Short

int --Integer

long --Long

float --Float

double --Double

引用类型和原始类型的行为完全不同,并且它们具有不同的语义。引用类型和原始类型具有不同的特征和用法,它们包括:大小和速度问题,这种类型以哪种类型的数据结构存储,当引用类型和原始类型用作某个类的实例数据时所指定的缺省值。对象引用实例变量的缺省值为 null,而原始类型实例变量的缺省值与它们的类型有关。同时为了面向对象操作的一致性,这些基本类型都有相应的封装类型:Integer、Short、Long、Byte、Float、Double、Character等。

因为封装类型是对象,所以可以进行相应的很多对象能力函数操作,这样就可以提供很多基本类型难以完成的工作的完成和实现。

你可以通过以下方式来声明该类型。

int a,a为int类型的变量

char a,a为char类型的

String对象

1. 首先String不属于8种基本数据类型,String是一个对象。

因为对象的默认值是null,所以String的默认值也是null;但它又是一种特殊的对象,有其它对象没有的一些特性。

2. new String()和new String(“”)都是申明一个新的空字符串,是空串不是null;

3. String str=”punkll”;

String str=new String (“punkll”);的区别:

在这里,我们不谈堆,也不谈栈,只先简单引入常量池这个简单的概念。

常量池(constant pool)指的是在编译期被确定,并被保存在已编译的.class文件中的一些数据。它包括了关于类、方法、接口等中的常量,也包括字符串常量。

看例1:

String s0=”punkll”;

String s1=”punkll”;

String s2=”punk” + “ll”;

System.out.println( s0==s1 );

System.out.println( s0==s2 );

结果为:

true

true

首先,我们要知结果为道Java会确保一个字符串常量只有一个拷贝。

因为例子中的s0和s1中的”punkll”都是字符串常量,它们在编译期就被确定了,所以s0==s1为true;而”punk”和”ll”也都是字符串常量,当一个字符串由多个字符串常量连接而成时,它自己肯定也是字符串常量,所以s2也同样在编译期就被解析为一个字符串常量,所以s2也是常量池中”punkll”的一个引用。

所以我们得出s0==s1==s2;

用new String() 创建的字符串不是常量,不能在编译期就确定,所以new String() 创建的字符串不放入常量池中,它们有自己的地址空间。

看例2:

String s0=”punkll”;

String s1=new String(”punkll”);

String s2=”punk” + new String(“ll”);

System.out.println( s0==s1 );

System.out.println( s0==s2 );

System.out.println( s1==s2 );

结果为:

false

false

false

例2中s0还是常量池中”punkll”的应用,s1因为无法在编译期确定,所以是运行时创建的新对象”punkll”的引用,s2因为有后半部分new String(“ll”)所以也无法在编译期确定,所以也是一个新创建对象”punkll”的应用;明白了这些也就知道为何得出此结果了。

Java 的垃圾回收如何判断哪个对象可以被回收

一般情况下java中对象可被回收的前提是:该对象不再被引用。

例如:

object

o

=

new

object();

o

=

null;

此时第一步

new

出来的对象不再被引用,垃圾回收器在回收的时候便会把这个对象清理掉。

特殊情况下

,java中存在弱引用(weakreference

很少用,不确定拼写的是否准确哈),对象即使被弱引用,垃圾回收机制也是可以回收的,我们正常直接赋值的引用属于强引用,除了系统内存不足等因素外,垃圾回收机制是不会清理的。

(责任编辑:IT教学网)

更多

推荐网页文字特效文章