import java.io.File;
import java.io.FileFilter;
import java.io.IOException;
import java.lang.reflect.Field;
import java.net.JarURLConnection;
import java.net.URL;
import java.net.URLDecoder;
import java.util.ArrayList;
import java.util.Enumeration;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Set;
import java.util.jar.JarEntry;
import java.util.jar.JarFile;
public class ClassUtil {
/**
* 返回一个类的所有成员变量名列表.
*
* @param clazz
* @return
*/
public static List <String> getClassProperties(Class clazz) {
Field[] fields = clazz.getDeclaredFields();
List <String> result = new ArrayList<String>();
for (int i=0; i<fields.length; i++) {
String name = fields[i].getName();
result.add(name);
}
return result;
}
/**
* 取得某一类所在包的所有类名 不含迭代
*/
public static String[] getPackageAllClassName(String classLocation, String packageName){
//将packageName分解
String[] packagePathSplit = packageName.split("[.]");
String realClassLocation = classLocation;
int packageLength = packagePathSplit.length;
for(int i = 0; i< packageLength; i++){
realClassLocation = realClassLocation + File.separator+packagePathSplit[i];
}
File packeageDir = new File(realClassLocation);
if(packeageDir.isDirectory()){
String[] allClassName = packeageDir.list();
return allClassName;
}
return null;
}
/**
* 注意,调用这个方法时,必须要求已经加载过packageName下的一个类.
* @param packageName String
* @return Set<Class<?>>
*/
public static Set<Class<?>> getClasses(String packageName) {
Package pkg = Package.getPackage(packageName);
return getClasses(pkg);
}
/**
* 从包package中获取所有的Class.
* 注意,调用Package.getPackage(String)这个方法时,必须要求已经加载过name下的一个类.
* @param pack Package pack
* @return Set<Class<?>>
*/
public static Set<Class<?>> getClasses(Package pack){
//第一个class类的集合
Set<Class<?>> classes = new LinkedHashSet<Class<?>>();
//是否循环迭代
boolean recursive = true;
//获取包的名字 并进行替换
String packageName = pack.getName();
String packageDirName = packageName.replace('.', '/');
//定义一个枚举的集合 并进行循环来处理这个目录下的things
Enumeration<URL> dirs;
try {
dirs = Thread.currentThread().getContextClassLoader().getResources(packageDirName);
//循环迭代下去
while (dirs.hasMoreElements()){
//获取下一个元素
URL url = dirs.nextElement();
//得到协议的名称
String protocol = url.getProtocol();
//如果是以文件的形式保存在服务器上
if ("file".equals(protocol)) {
//获取包的物理路径
String filePath = URLDecoder.decode(url.getFile(), "UTF-8");
//以文件的方式扫描整个包下的文件 并添加到集合中
findAndAddClassesInPackageByFile(packageName, filePath, recursive, classes);
} else if ("jar".equals(protocol)){
//如果是jar包文件
//定义一个JarFile
JarFile jar;
try {
//获取jar
jar = ((JarURLConnection) url.openConnection()).getJarFile();
//从此jar包 得到一个枚举类
Enumeration<JarEntry> entries = jar.entries();
//同样的进行循环迭代
while (entries.hasMoreElements()) {
//获取jar里的一个实体 可以是目录 和一些jar包里的其他文件 如META-INF等文件
JarEntry entry = entries.nextElement();
String name = entry.getName();
//如果是以/开头的
if (name.charAt(0) == '/') {
//获取后面的字符串
name = name.substring(1);
}
//如果前半部分和定义的包名相同
if (name.startsWith(packageDirName)) {
int idx = name.lastIndexOf('/');
//如果以"/"结尾 是一个包
if (idx != -1) {
//获取包名 把"/"替换成"."
packageName = name.substring(0, idx).replace('/', '.');
}
//如果可以迭代下去 并且是一个包
if ((idx != -1) || recursive){
//如果是一个.class文件 而且不是目录
if (name.endsWith(".class") && !entry.isDirectory()) {
//去掉后面的".class" 获取真正的类名
String className = name.substring(packageName.length() + 1, name.length() - 6);
try {
//添加到classes
classes.add(Class.forName(packageName + '.' + className));
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
}
}
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
} catch (IOException e) {
e.printStackTrace();
}
return classes;
}
/**
* 以文件的形式来获取包下的所有Class
* @param packageName
* @param packagePath
* @param recursive
* @param classes
*/
public static void findAndAddClassesInPackageByFile(String packageName, String packagePath, final boolean recursive, Set<Class<?>> classes){
//获取此包的目录 建立一个File
File dir = new File(packagePath);
//如果不存在或者 也不是目录就直接返回
if (!dir.exists() || !dir.isDirectory()) {
return;
}
//如果存在 就获取包下的所有文件 包括目录
File[] dirfiles = dir.listFiles(new FileFilter() {
//自定义过滤规则 如果可以循环(包含子目录) 或则是以.class结尾的文件(编译好的java类文件)
public boolean accept(File file) {
return (recursive && file.isDirectory()) || (file.getName().endsWith(".class"));
}
});
//循环所有文件
for (File file : dirfiles) {
//如果是目录 则继续扫描
if (file.isDirectory()) {
findAndAddClassesInPackageByFile(packageName + "." + file.getName(),
file.getAbsolutePath(),
recursive,
classes);
}
else {
//如果是java类文件 去掉后面的.class 只留下类名
String className = file.getName().substring(0, file.getName().length() - 6);
try {
//添加到集合中去
classes.add(Class.forName(packageName + '.' + className));
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
}
}
}
分享到:
相关推荐
在使用spring mvc 使用反射自动生成对象 的代码 方便使用
ClassUtil::callMethodForArgs($this,$args); } public function construct_() { echo ("0 args function is called "); } public function construct_number($num) { echo "arg 1 function is ...
在Java编程中,工具类(Util Class)是包含各种实用函数的静态类,它们提供了一种简化常见任务的方法。在给定的`UtilClass`中,我们有五个主要的工具类:`StringUtil`、`FileUtil`、`ConnectDB`、`DateUtil`和`...
dropwizard-webjars-bundle.zip,dropwizard bundle使使用webjars(http://webjars.org)更容易。dropwizard bundle使使用webjars(http://webjars.org)更容易。
4. **字符串操作**:StringUtil是Jodd提供的字符串处理工具,包含了一系列方便的静态方法,如分割、替换、去除空白、检查格式等,极大地增强了Java字符串处理的能力。 5. **I/O流**:IoUtil是处理输入/输出流的利器...
`ClassUtil.java`可能是一个工具类,包含了动态编译代码的相关方法。例如,它可能会有如下功能: ```java import javax.tools.*; import java.io.IOException; import java.util.Arrays; public class ClassUtil {...
这是 Anjuta 开发 IDE 的插件,这是面向对象编程 (C++) 的实用程序。 您可以向现有类插入新项目(函数或变量)。
Android 实现IOS 滚轮选择控件的实例 最近根据项目需要,整理了一个相对比较全面的 ...public class Util { /** * 时间选择回调 */ public interface TimerPickerCallBack { void onTimeSelect(String date)
由于第一版有很多问题,比如double和float没有保留小数,每次新建一个bean需要在数据库创建表单 第二版更完整好用,只需要2步,.../daoCreator/Util/ClassUtil.java /daoCreator/Util/DBUtil.java test /test/test.java
以下是对给定的文件名"ClassUtil"、"FirstExam"和"SecondExam"的详细解释及相关知识点: 1. **ClassUtil**: 这个文件可能是一个工具类,包含了与类操作相关的静态方法。在Java中,工具类通常用于封装一些常用的功能...
我们可以使用一个名为 `ClassUtil` 的工具类来获取同一路径下所有类及其方法。这个类中有一个 `getAllAssignedClass` 方法,用于获取同一路径下所有子类或接口实现类。这个方法使用 `getClasses` 方法来获取当前类...
资源内容:工欲善其事必先利其器,本资源内容为Java开发常用工具类打包,如BeanUtil,ArrayUtil,HtmlUtil,ClassUtil,DateUtil,FileUtil,FontUtil,ImageUtil,IOUtil, IPUtil, MapUtil,MailUtil, NumberUtil,...
class Util { public void print(int num) { System.out.println("Printing integer: " + num); } public void print(String str) { System.out.println("Printing string: " + str); } } ``` 在这个例子中,...
`java.lang.reflect` 包提供了`Class`、`Field`、`Method` 等类,`ClassUtil` 或类似的工具类可以封装这些反射操作,如创建对象、调用私有方法、修改私有属性等。 5. **Json**: JSON (JavaScript Object Notation) ...
public class Util { public static void printMessage() { // 静态方法 System.out.println("Hello, World!"); } } Util.printMessage(); // 调用静态方法 ``` 3. **静态块(Static Initialization Blocks...
public class Util { static { System.loadLibrary("md5"); } public native String calculateMD5(String input); } ``` 2. **编写JNI头文件**: 使用`javah`命令(或者在Android Studio中自动配置的...
class Util { public: static std::string GetFileOpenExecutor(const std::string& extension); }; ``` 这样,你就可以在其他VC++代码中调用`Util::GetFileOpenExecutor(".txt")`来获取与.txt文件关联的默认打开...
public class Util { public static void generateQRCode(String data, String filePath, int width, int height) throws WriterException, IOException { QRCodeWriter qrCodeWriter = new QRCodeWriter(); ...