摘要记录小技巧-小知识点总结
2012-11-19 19:51
323 查看
1。注解实现的原来 ,注解分好几种,一种给编译器看的javac,如overwrite ,(jdk5是不支持这个的),一种是给java.exe看的!,jdk5.0也支持!
2.马士兵模拟SPIRNG 第四讲 (个人百度知道)
A
B
我来帮他解答
图片
符号
编号
排版
地图
您提交的参考资料超过50字,请删除
参考资料:
提交回答
满意回答
2012-08-27 17:14
3,关于classforname
Class.forName 介绍2009-07-31 15:42Class.forName(xxx.xx.xx) 返回的是一个类
首先你要明白在java里面任何class都要装载在虚拟机上才能运行。这句话就是装载类用的(和new 不一样,要分清楚)。
至于什么时候用,你可以考虑一下这个问题,给你一个字符串变量,它代表一个类的包名和类名,你怎么实例化它?只有你提到的这个方法了,不过要再加一点。
A a = (A)Class.forName("pacage.A").newInstance();
这和你
A a = new A();
是一样的效果。
关于补充的问题
答案是肯定的,jvm会执行静态代码段,你要记住一个概念,静态代码是和class绑定的,class装载成功就表示执行了你的静态代码了。而且以后不会再走这段静态代码了。
Class.forName(xxx.xx.xx)返回的是一个类
Class.forName(xxx.xx.xx)的作用是要求JVM查找并加载指定的类,也就是说JVM会执行该类的静态代码段
动态加载和创建Class 对象,比如想根据用户输入的字符串来创建对象
String str = "用户输入的字符串" ;
Class t = Class.forName(str);
t.newInstance();
在初始化一个类,生成一个实例的时候,newInstance()方法和new关键字除了一个是方法,一个是关键字外,最主要有什么区别?它们的区别在于创建对象的方式不一样,前者是使用类加载机制,后者是创建一个新类。那么为什么会有两种创建对象方式?这主要考虑到软件的可伸缩、可扩展和可重用等软件设计思想。
Java中工厂模式经常使用newInstance()方法来创建对象,因此从为什么要使用工厂模式上可以找到具体答案。 例如:
class c = Class.forName(“Example”);
factory = (ExampleInterface)c.newInstance();
其中ExampleInterface是Example的接口,可以写成如下形式:
String className = "Example";
class c = Class.forName(className);
factory = (ExampleInterface)c.newInstance();
进一步可以写成如下形式:
String className = readfromXMlConfig;//从xml 配置文件中获得字符串
class c = Class.forName(className);
factory = (ExampleInterface)c.newInstance();
上面代码已经不存在Example的类名称,它的优点是,无论Example类怎么变化,上述代码不变,甚至可以更换Example的兄弟类Example2 , Example3 , Example4……,只要他们继承ExampleInterface就可以。
从JVM的角度看,我们使用关键字new创建一个类的时候,这个类可以没有被加载。但是使用newInstance()方法的时候,就必须保证:1、这个类已经加载;2、这个类已经连接了。而完成上面两个步骤的正是Class的静态方法forName()所完成的,这个静态方法调用了启动类加载器,即加载 java API的那个加载器。
现在可以看出,newInstance()实际上是把new这个方式分解为两步,即首先调用Class加载方法加载某个类,然后实例化。 这样分步的好处是显而易见的。我们可以在调用class的静态加载方法forName时获得更好的灵活性,提供给了一种降耦的手段。
最后用最简单的描述来区分new关键字和newInstance()方法的区别:
newInstance: 弱类型。低效率。只能调用无参构造。
new: 强类型。相对高效。能调用任何public构造。
-----------------------------------------------------------------------------------------
2.马士兵模拟SPIRNG 第四讲 (个人百度知道)
A
SAXBuilder是一个JDOM解析器 能将路径中的XML文件解析为Document对象 例如 SAXBuilder builder=new SAXBuilder(); Document doc=builder.build(path);
B
InputStream inputStream =getClass().getClassLoader().getResourceAsStream("nihao.xml"); nihao.xml这个文件的路径可以修改吗?getClass().getClassLoader().getResourceAsStream又是什么意思呢?
我来帮他解答
图片
符号
编号
排版
地图
您还可以输入9999 个字 |
参考资料:
提交回答
满意回答
2012-08-27 17:14
可以修改。 作用是找 当前这个class 文件所在目录下的 nihao.xml 文件。nihao.xml 是文件的名称,可以更改,但更改后,你对应的文件名称也要更改 调用对象的getClass()方法是获得"对象当前的类类型",这部分数据存在方法区中,而后在类类型上调用getClassLoader()方法是得到"当前类型的类加载器",最后调用了类加载器的getResourceAsStream()方法来"加载资源"。 ClassLoader提供了两个方法用于从装载的类路径中取得资源: public URL getResource(String name); public InputStream getResourceAsStream(String name); 这里name是资源的类路径,它是相对与“/”根路径下的位置。getResource得到的是一个URL对象来定位资源,而getResourceAsStream取得该资源输入流的引用保证程序可以从正确的位置抽取数据。
3,关于classforname
Class.forName 介绍2009-07-31 15:42Class.forName(xxx.xx.xx) 返回的是一个类
首先你要明白在java里面任何class都要装载在虚拟机上才能运行。这句话就是装载类用的(和new 不一样,要分清楚)。
至于什么时候用,你可以考虑一下这个问题,给你一个字符串变量,它代表一个类的包名和类名,你怎么实例化它?只有你提到的这个方法了,不过要再加一点。
A a = (A)Class.forName("pacage.A").newInstance();
这和你
A a = new A();
是一样的效果。
关于补充的问题
答案是肯定的,jvm会执行静态代码段,你要记住一个概念,静态代码是和class绑定的,class装载成功就表示执行了你的静态代码了。而且以后不会再走这段静态代码了。
Class.forName(xxx.xx.xx)返回的是一个类
Class.forName(xxx.xx.xx)的作用是要求JVM查找并加载指定的类,也就是说JVM会执行该类的静态代码段
动态加载和创建Class 对象,比如想根据用户输入的字符串来创建对象
String str = "用户输入的字符串" ;
Class t = Class.forName(str);
t.newInstance();
在初始化一个类,生成一个实例的时候,newInstance()方法和new关键字除了一个是方法,一个是关键字外,最主要有什么区别?它们的区别在于创建对象的方式不一样,前者是使用类加载机制,后者是创建一个新类。那么为什么会有两种创建对象方式?这主要考虑到软件的可伸缩、可扩展和可重用等软件设计思想。
Java中工厂模式经常使用newInstance()方法来创建对象,因此从为什么要使用工厂模式上可以找到具体答案。 例如:
class c = Class.forName(“Example”);
factory = (ExampleInterface)c.newInstance();
其中ExampleInterface是Example的接口,可以写成如下形式:
String className = "Example";
class c = Class.forName(className);
factory = (ExampleInterface)c.newInstance();
进一步可以写成如下形式:
String className = readfromXMlConfig;//从xml 配置文件中获得字符串
class c = Class.forName(className);
factory = (ExampleInterface)c.newInstance();
上面代码已经不存在Example的类名称,它的优点是,无论Example类怎么变化,上述代码不变,甚至可以更换Example的兄弟类Example2 , Example3 , Example4……,只要他们继承ExampleInterface就可以。
从JVM的角度看,我们使用关键字new创建一个类的时候,这个类可以没有被加载。但是使用newInstance()方法的时候,就必须保证:1、这个类已经加载;2、这个类已经连接了。而完成上面两个步骤的正是Class的静态方法forName()所完成的,这个静态方法调用了启动类加载器,即加载 java API的那个加载器。
现在可以看出,newInstance()实际上是把new这个方式分解为两步,即首先调用Class加载方法加载某个类,然后实例化。 这样分步的好处是显而易见的。我们可以在调用class的静态加载方法forName时获得更好的灵活性,提供给了一种降耦的手段。
最后用最简单的描述来区分new关键字和newInstance()方法的区别:
newInstance: 弱类型。低效率。只能调用无参构造。
new: 强类型。相对高效。能调用任何public构造。
-----------------------------------------------------------------------------------------
在上面这个例子 增强型的for循环 和普通for循环一样 增强型的for循环 优点主要体现在集合中,随便举个例子 比如对 set 的遍历 一般是迭代遍历: Set<String> set = new HashSet<String>(); Iterator<String> it = set.iterator(); while (it.hasNext()) { String str = it.next(); System.out.println(str); } for循环遍历: for (String str : set) { System.out.println(str); } 是不是简单些? 优点还体现在泛型 假如 set中存放的是Object Set<Object> set = new HashSet<Object>(); for循环遍历: for (Object obj: set) { if(obj instanceof Integer){ int aa= (Integer)obj; }else if(obj instanceof String){ String aa = (String)obj } ........ } 如果你用Iterator遍历,那就晕了 map list 也一样 唯一的缺点就是 在遍历 集合过程中,不能对集合本身进行操作 for (String str : set) { set.remove(str);//错误! }
相关文章推荐
- 2017年9月份知识点记录总结
- 6个琐碎知识点总结:①找html快捷键+②看请求信息+③页面语法错误+④plsql看表关联关系+⑤关联很多,慎重操作表记录+⑥302表示重定向报错
- 深度学习训练的小技巧,调参经验。总结与记录。
- 在这里记录自己学习中遇到的零碎的容易忽略的知识点,不定时总结更新
- 深度学习训练的小技巧,调参经验。总结与记录。
- 总结一下近来记录下来的知识点
- Hbase 知识点记录总结(1)
- 阅读《LEARNING HARD C#学习笔记》知识点总结与摘要五
- 深度学习训练的小技巧,调参经验。总结与记录。
- 阅读《LEARNING HARD C#学习笔记》知识点总结与摘要三
- 做imooc仿大众点评遇到的坑总结以及知识点记录
- 阅读《LEARNING HARD C#学习笔记》知识点总结与摘要四
- 深度学习训练的小技巧,调参经验。总结与记录
- 编程小技巧总结记录
- linux小技巧/知识点记录
- 阅读《LEARNING HARD C#学习笔记》知识点总结与摘要二
- 做patBasic的感受总结和知识点记录
- 阅读《LEARNING HARD C#学习笔记》知识点总结与摘要系列文章索引
- 字符串知识点 记录+总结
- iOS面试知识点总结记录一