关于Junit+getResourceAsStream返回Null和junitwhenthenreturn的问题就给大家分享到这里,感谢你花时间阅读本站内容,更多关于SpringMVC(7):对Cla
关于Junit + getResourceAsStream返回Null和junit when then return的问题就给大家分享到这里,感谢你花时间阅读本站内容,更多关于<转载>SpringMVC(7): 对Class.getResourceAsStream和ClassLoader.getResourceAsStream方法所使用的资源路径的解释、c# – GetManifestResourceStream给出Null引用异常(参数名称:streamSource)、class.getResource()和getResourceAsStream乱码问题、ClassLoader getResourceAsStream返回null等相关知识的信息别忘了在本站进行查找喔。
本文目录一览:- Junit + getResourceAsStream返回Null(junit when then return)
- <转载>SpringMVC(7): 对Class.getResourceAsStream和ClassLoader.getResourceAsStream方法所使用的资源路径的解释
- c# – GetManifestResourceStream给出Null引用异常(参数名称:streamSource)
- class.getResource()和getResourceAsStream乱码问题
- ClassLoader getResourceAsStream返回null
Junit + getResourceAsStream返回Null(junit when then return)
不知道这怎么可能。我重新阅读了getResourceAsStream,它始终返回null。
InputStream source = this.getClass().getResourceAsStream("test.xml");
在Finder中(使用OS X和Eclipse),在test.java的旁边是test.xml
我可以在TextWrangler中打开它,并查看其中是否存在数据。
如果有什么不同,这是Junit测试。我去查看了系统上现有的Junit测试,并以与工作示例完全相同的方式来使用它(如文件所在的位置和代码本身)。
我认为getClass()返回正确的路径有什么小的区别?
谢谢!
答案1
小编典典getResourceAsStream()
正在使用CLASSPATH,因此它将从 您的类所在的位置 (而不是源文件)加载。
我怀疑您需要将XML复制到与.class文件相同的目录中。
<转载>SpringMVC(7): 对Class.getResourceAsStream和ClassLoader.getResourceAsStream方法所使用的资源路径的解释
18/1/9
一、Class.getResourceAsStream和ClassLoader.getResourceAsStream方法
Class.getResourceAsStream() 会指定要加载的资源路径与当前类所在包的路径一致。
例如你写了一个MyTest类在包com.test.mycode 下,那么MyTest.class.getResourceAsStream("name") 会在com.test.mycode包下查找相应的资源。
如果这个name是以 ''/'' 开头的,那么就会从classpath的根路径下开始查找。
ClassLoader.getResourceAsStream() 无论要查找的资源前面是否带''/'' 都会从classpath的根路径下查找。
所以: MyTest.getClassLoader().getResourceAsStream("name") 和
MyTest.getClassLoader().getResourceAsStream("name") 的效果是一样的。
顺便提下JAVA中类的加载器:
一共有三种加载器
bootstrap classloader :负责加载JAVA核心类( jre 下lib和class目录中的内容)
extension classloader :负责加载JAVA扩展类(jre 下lib/ext 目录中的内容)
system classloader :负责加载应用指定的类 (环境变量classpath中配置的内容)
一个类的加载顺序也是按上面的排列来的,这样就能保证系统的类能先加载。
与此同时用户也可以自己定义ClassLoader,用来加载特殊的资源。
这里就涉及到 Class.getClassLoader() 和 Thread.currentThread.getContextClassLoader()的区别。
举一个简单的例子:
假如某天JAVA给我们提供了一个叫 StartCamera 的类用来启动电脑的标准摄像头,并将这个类打包在一个jar中。
正常情况下,我们要启动摄像头时只需将这个jar配置到classpath中。系统启动时system classloader会将这个类加载到应用中。
但因为摄像头的生产厂家不一样,针对新的设备会有多个不同的StartCamera实现,在应用中我们不知道实际的用户会用到哪种。于是我们就自定义了一个ClassLoader,用来针对具体的设备类型加载相应的StartCamera类。
这样一来就出现:优先加载我们定义的类,加载不到的情况下再加载系统的。 这样的需求,是系统默认的父委托加载机制无法满足的。
Thread.currentThread.getContextClassLoader() 就是这样产生的。 我们使用Thread.currentThread.setContextClassLoader() 可以为当前线程指定相应的ClassLoader,然后用get的方式来获取。
那么上面的加载代码就可能是这样子的:
public void useCamera(){
StartCamera s = this.findClassLoader().loadClass("StartCamera");
s.start();
}
private ClassLoader findClassLoader(){
ClassLoader loader = Thread.currentThread().getContextClassLoader();
if(loader==null){
loader = ClassLoader.getSystemClassLoader();
}
return loader;
}
----------------------------------------------------------------------------------------------
二、Java中getResourceAsStream的用法
1. Class.getResourceAsStream(String path) : path 不以’/''开头时默认是从此类所在的包下取资源,以’/''开头则是从ClassPath根下获取。其只是通过path构造一个绝对路径,最终还是由ClassLoader获取资源。
2. Class.getClassLoader.getResourceAsStream(String path) :默认则是从ClassPath根下获取,path不能以’/''开头,最终是由ClassLoader获取资源。
3. ServletContext. getResourceAsStream(String path):默认从WebAPP根目录下取资源,Tomcat下path是否以’/''开头无所谓,当然这和具体的容器实现有关。
4. Jsp下的application内置对象就是上面的ServletContext的一种实现。
其次,getResourceAsStream 用法大致有以下几种:
第一: 要加载的文件和.class文件在同一目录下,例如:com.x.y 下有类me.class ,同时有资源文件myfile.xml
那么,应该有如下代码:
me.class.getResourceAsStream("myfile.xml");
第二:在me.class目录的子目录下,例如:com.x.y 下有类me.class ,同时在 com.x.y.file 目录下有资源文件myfile.xml
那么,应该有如下代码:
me.class.getResourceAsStream("file/myfile.xml");
第三:不在me.class目录下,也不在子目录下,例如:com.x.y 下有类me.class ,同时在 com.x.file 目录下有资源文件myfile.xml
那么,应该有如下代码:
me.class.getResourceAsStream("/com/x/file/myfile.xml");
总结一下,可能只是两种写法
第一:前面有 “ / ”
“ / ”代表了工程的根目录,例如工程名叫做myproject,“ / ”代表了myproject
me.class.getResourceAsStream("/com/x/file/myfile.xml");
第二:前面没有 “ / ”
代表当前类的目录
me.class.getResourceAsStream("myfile.xml");
me.class.getResourceAsStream("file/myfile.xml");
最后,自己的理解:
getResourceAsStream读取的文件路径只局限与工程的源文件夹中,包括在工程src根目录下,以及类包里面任何位置,但是如果配置文件路径是在除了源文件夹之外的其他文件夹中时,该方法是用不了的。
c# – GetManifestResourceStream给出Null引用异常(参数名称:streamSource)
是指LR__ http://social.msdn.microsoft.com/Forums/en-US/lightswitch/thread/2d16c638-f833-4c4c-beec-656912a87b8e/#76fa5382-0135-41ba-967c-02efc3f8c3a2
System.Windows.Media.Imaging.BitmapImage image = new System.Windows.Media.Imaging.BitmapImage(); image.SetSource(Assembly.GetExecutingAssembly().GetManifestResourceStream( Application.Current.Details.Name + ".Resources.logo.jpg")); Image myImage = new Image() { Source = image,Stretch = System.Windows.Media.Stretch.Uniform,HorizontalAlignment = HorizontalAlignment.Left,Margin = new Thickness(2,2,14),Cursor = System.Windows.Input.Cursors.Hand };
我尝试了很多东西,但我找不到问题所在!
解决方法
只是这个
class.getResource()和getResourceAsStream乱码问题
getResource方法使用了utf-8对路径信息进行了编码,当路径中存在中文和空格时,他会对这些字符进行转换,这样,得到的往往不是我们想要的真实路径,在此,调用了URLDecoder的decode方法进行解码,以便得到原始的中文及空格路径。
String configPath = this.getClass().getClassLoader().getResource("allowPath.xml").getFile();
configPath = java.net.URLDecoder.decode(configPath,"utf-8");
ClassLoader getResourceAsStream返回null
我的项目目录结构(在Eclipse中):
MyProject/
src/ --> "source directory" on Eclipse's classpath/buildpath
com.me.myapp
Driver
myconfig.txt
在中Driver
,我有以下代码:
public class Driver {
public static void main(String[] args) {
InputStream is = ClassLoader.getSystemClassLoader.getResourceAsStream("myconfig.txt");
if(is == null)
System.out.println("input stream is null");
else
System.out.println("input stream is NOT null :-)");
}
}
运行此命令时,将获得以下控制台输出:
input stream is null
为什么? 我放置myconfig.txt
在错误的位置了吗?我是否使用了ClassLoader API错误?还有吗 提前致谢!
关于Junit + getResourceAsStream返回Null和junit when then return的问题就给大家分享到这里,感谢你花时间阅读本站内容,更多关于<转载>SpringMVC(7): 对Class.getResourceAsStream和ClassLoader.getResourceAsStream方法所使用的资源路径的解释、c# – GetManifestResourceStream给出Null引用异常(参数名称:streamSource)、class.getResource()和getResourceAsStream乱码问题、ClassLoader getResourceAsStream返回null等相关知识的信息别忘了在本站进行查找喔。
本文标签: