java动态加载类及调用类的方法

我现在用xml传以下字段到服务器:class是类的完整名称,action是要调用的方法名,para的子元素是方法形参,data的子元素是方法实参。

 <user><class>cn.market</class><action>register</action><para><para1>int</para1><para2>String</para2><para3>Products</para3></para><data><name>we</name><password>123</password><Products><pname>food</pname><number>500</number></Products></data></user>

问题:我如何用这个字段,不管我传什么内容过来,只要服务器端有这个类,并且有这个方法,它都能调用。

2个回答

解析后,应该得到这样的结果:
String className = "cn.market";
String methodName = "register";
List paramTypes = new ArrayList();
List params = new ArrayList();
然后把参数类型的名字和参数都以String的形式存放在List中。

Class pTypes[ ] = new Class[paramTypes.size()];
for(int i=0;i<paramTypes.size();i++){
pTypes[i] = Class.forName(paramTypes.get(i));
}

Method method = getDeclaredMethod(methodName,pTypes);// 拿到你要执行的方法

至于参数:、
可以instanceof判断PTypes的某个元素是什么类型,比如String,int,然后创建一个对象,把params的值赋值给它,需要类型转换就进行转换。

wild84
wild84 谢谢!
大约 3 年之前 回复

首先你得解析xml,可以jdom的SAXReader解析,得到类的名字,方法,参数

然后用反射生成类的对象,同样用反射调用类的方法。

wild84
wild84 反射获取方法我是知道怎么用的,我用的时候都是提前知道方法的参数列表,然后getDeclaredMethod();但是现在我的参数列表不固定了,所以在服务器端用get方法行不通。我解析xml后都是字符串,我如何转成getdeclaredmethod()的第二参数:参数列表,当我用invoke()方法时候如何把xml的字符串值转换为invoke要的参数。恳请帮助,谢谢
大约 3 年之前 回复
wild84
wild84 你说的我大致理解,但是我的
大约 3 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
js中调用java类的方法
js调用java类的方法,在网页第一次加载的时候可以执行,再次加载的时候java类的方法不执行。无逻辑错误
java类中方法调用问题
import java.awt.*; import javax.swing.*; import java.awt.event.*; public class TestTextComponent extends JFrame { private JTextField textField = new JTextField(15); private JPasswordField passwordField = new JPasswordField(15); private JTextArea textArea = new JTextArea(6, 32); private final static String newline = "\n"; textField.addActionListener(new ActionListener(){ public void actionPerformed(ActionEvent e) { textArea.append("用户输入文本是:" + textField.getText() + newline); textField.setText(null); } }); passwordField.addActionListener(new ActionListener(){ public void actionPerformed(ActionEvent e) { String password = new String(passwordField.getPassword()); textArea.append("用户输入的密码是:" + password + newline); passwordField.setText(null); } }); public TestTextComponent() { /*setLayout(new BorderLayout()); textArea.setEditable(false); textField.setToolTipText("接收文本输入"); passwordField.setToolTipText("接收密码输入"); JPanel northPanel = new JPanel(); northPanel.setLayout(new FlowLayout()); northPanel.add(textField); northPanel.add(passwordField); add(northPanel, BorderLayout.NORTH); */ JPanel centerPanel = new JPanel(); centerPanel.setLayout(new FlowLayout()); centerPanel.add(new JScrollPane(textArea)); add(centerPanel, BorderLayout.CENTER); } public static void main(String[] args) { TestTextComponent frame = new TestTextComponent(); frame.setTitle("测试文本组件"); frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); frame.pack(); frame.setVisible(true); } } 请问为什么我将添加监听器的步骤从构造方法移到外面后程序就错了,我同学说类中只能定义方法,而不能直接调用方法,是不是啊?如果是的话,又是为什么呢?谢谢
Java动态加载jar包问题
请问哪位大神做过,Java通过读配置文件的jar路径,加载jar包并调用里面的类和方法,求解答
java 反射调用方法,方法内部调用了外部的jar
java 反射调用方法,方法内部调用了外部的jar,该外部jar怎么动态加载进来,现在报错: java.lang.reflect.InvocationTargetException at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:606) at com.ifec.blueair.quartz.TaskUtils.invokMethod(TaskUtils.java:51) at com.ifec.blueair.quartz.QuartzJobFactoryDisallowConcurrentExecution.execute(QuartzJobFactoryDisallowConcurrentExecution.java:21) at org.quartz.core.JobRunShell.run(JobRunShell.java:202) at org.quartz.simpl.SimpleThreadPool$WorkerThread.run(SimpleThreadPool.java:573) Caused by: java.lang.NoClassDefFoundError: com/ifec/blueair/framework/util/RandomNumberUtil at com.ifec.blueair.quartz.task.TaskContentPoolSpring.getContentPoolTaskContentPoolTest(TaskContentPoolSpring.java:16) ... 8 more
java中静态方法为什么无法调用非静态变量或者方法
我在网上搜到的回答都是类似下面这样: 静态方法是随着类的加载而加载的,对象是在类加载之后创建的,也就是说静态方法先于对象存在。当你创建一个对象时,程序为其在堆中分配内存,一般是通过this指针来指向该对象。静态方法不依赖于对象的调用,它是通过‘类名.静态方法名’这样的方式来调用的。而对于非静态方法,在对象创建的时候程序才会为其分配内存,然后通过类的对象去访问非静态方法/变量。因此在对象未存在时非静态方法/变量也不存在,静态方法自然不能调用一个不存在的方法。 这个解释我看完还是有一点不是很明白,想请教一下大家,以下面的代码为例: ``` public class D143Demo_Person3 { public static void main(String[] args) { Person p1 = new Person(); p1.name = "林青霞"; p1.speak(); } } class Person{ String name; //姓名 public static void speak() { System.out.println(name); } } ``` 当已经创建了一个p1的对象并为其变量name赋值后。此时的p1.name不是已经存在了吗,为什么还是使用静态方法p1.speak仍然会报错。 麻烦各位大神说说我的理解错在哪儿了。 我随后查阅资料,有一段是这么写的: 如果静态方法能调用动态方法的话,那如果别人通过类名调用静态方法时实例对象可能并不存在,但是方法内又调用了对象的方法,由于对象不存在,所以动态方法也不存在,程序肯定报错,所以java直接在编译阶段检查这种错误,避免运行时异常。这个解释我就懂了。
Java动态代理的invoke方法返回值如何够自己定义?
Java动态代理的invoke方法返回值,想根据不同的接口调用标识加载不同的xml获取相应的bean属性,设置对应的值返回。
Java反射机制的方法调用
大哥们,初学Java两个月的小白,这两天复习反射有点懵,今晚又发现个问题,就是再空参内添加一句输出语句,再创建个show方法给个输出语句,到测试类中时,当我获得构造器后再使用Method获取show方法时,两句语句会同时一起在控制台进行输出.可是我只想输出个show方法,该咋整啊?![图片说明](https://img-ask.csdn.net/upload/201905/13/1557755006_366482.png) 在这红框第一步操作时,控制台可输出a,但是使用method获得方法又不得去使用第一步的操作,我该怎么操作才能在控制台只输出一个b的结果.
opencv+java项目main方法能够成功运行但是监听文件夹服务调用opencv方法却无法加载CascadeClassifier的问题
## 在类的最前面添加了引入opencv库的代码 ``` System.loadLibrary(Core.NATIVE_LIBRARY_NAME); ``` ## detect方法 ``` public static void detect(String imagePath,String savePath,int length){ System.out.println("libraryName:"+Core.NATIVE_LIBRARY_NAME); // 从配置文件lbpcascade_frontalface.xml中创建一个人脸识别器,该文件位于opencv安装目录中 CascadeClassifier faceDetector = new CascadeClassifier("C:\\opencv\\sources\\data\\haarcascades\\haarcascade_frontalface_alt2.xml"); Mat image = Imgcodecs.imread(imagePath); // 在图片中检测人脸 MatOfRect faceDetections = new MatOfRect(); faceDetector.detectMultiScale(image, faceDetections); Rect[] rects = faceDetections.toArray(); for(int i = 0 ; i < rects.length ; i++){ Rect rect = rects[i]; Mat sub = image.submat(rect);//Mat sub = new Mat(image,rect); Mat mat = new Mat(); Size size = new Size(300, 300); Imgproc.resize(sub, mat, size);//将人脸进行截图并保存  //截图 File tempFile =new File( imagePath.trim()); String fileName = tempFile.getName(); System.out.println("filename:"+fileName); Imgcodecs.imwrite(savePath+"//"+fileName+length+".jpg", mat); ++length; } } ``` ## main方法中调用detect方法运行ok ``` ``` public static void main(String[] args) { ArrayList<File> file = null; //源文件 try { file = FileUtil.getFiles("C:\\image"); for(File files:file){ ArrayList<File> filess = FileUtil.getFiles("C:\\imageTemp") ;//保存路径 detect(files.getPath(), "C:\\imageTemp", filess.size()); } } catch (Exception e) { e.printStackTrace(); } } ``` ## 监听文件夹服务调用报错 ```System.out.println("libraryName:"+Core.NATIVE_LIBRARY_NAME); ArrayList<File> filess = FileUtil.getFiles("C:\\imageTemp") ;//保存路径 detect(path, "C:\\imageTemp", filess.size()); ArrayList<File> files = FileUtil.getFiles("C:\\imageTemp"); ArrayList<String> tempFaceList=new ArrayList<>(); ``` ## 报错内容: ``` Exception in thread "Thread-38" java.lang.UnsatisfiedLinkError: org.opencv.objdetect.CascadeClassifier.CascadeClassifier_0(Ljava/lang/String;)J at org.opencv.objdetect.CascadeClassifier.CascadeClassifier_0(Native Method) at org.opencv.objdetect.CascadeClassifier.<init>(CascadeClassifier.java:39) at com.kefo.receive.facerecognize.adaptor.FileListener.detect(FileListener.java:54) at com.kefo.receive.facerecognize.adaptor.FileListener.onFileCreate(FileListener.java:120) at org.apache.commons.io.monitor.FileAlterationObserver.doCreate(FileAlterationObserver.java:389) at org.apache.commons.io.monitor.FileAlterationObserver.checkAndNotify(FileAlterationObserver.java:329) at org.apache.commons.io.monitor.FileAlterationObserver.checkAndNotify(FileAlterationObserver.java:303) at org.apache.commons.io.monitor.FileAlterationMonitor.run(FileAlterationMonitor.java:183) at java.lang.Thread.run(Thread.java:748) ``` ## 控制台一直都可以输出libraryName:opencv_java349,library中已经导入opencv的jar包,dll文件调用也没问题,但是在文件监听的方法里调用opencv的检测人脸服务不通过,有大神能帮忙解答一下吗?
java 动态加载class问题
java 动态加载class;写了A B类,都没有main方法。其中 A类中有静态方法f,其功能是动态加载类B的class文件。类B中有个函数;在idea中运行是没问题的 A.T.sum(2,7)) 可以调用。但是一旦把这个程序打成jar包后。在其他工程里引入jar包,就不能动态加载该类B。请大神指导下 package fff.BB; /** * Created by ***** on 2017/6/22. */ public class B { public int sum(int x, int y){ return x+y; } } import fff.BB.B; import java.io.File; import java.io.IOException; import java.net.URL; import java.net.URLDecoder; import java.util.Enumeration; import java.util.LinkedHashSet; import java.util.Set; /** * Created by liweidong on 2017/6/22. */ public class A { public static B T = null; static { registerReset(); } private static void registerReset(){ Set<Class<?>> classSet = loadClass(); for(Class cl : classSet){ try { T = (B) cl.newInstance(); } catch (Exception e) { e.printStackTrace(); } } } private static Set<Class<?>> loadClass(){ String packageDir = "fff.BB"; Set<Class<?>> classSet = new LinkedHashSet<Class<?>>(); try { Enumeration<URL> dirs = Thread.currentThread().getContextClassLoader().getResources(packageDir.replace('.','/')); while (dirs.hasMoreElements()){ URL url = dirs.nextElement(); String packagePath = URLDecoder.decode(url.getFile(),"UTF-8"); Class<?> loadClass = findClass(packageDir,packagePath); if(loadClass != null){ classSet.add(loadClass); } } }catch (IOException e){ } return classSet; } private static Class<?> findClass(String packageName,String packagePath){ File dir = new File(packagePath); if(!dir.exists() || !dir.isDirectory()){ return null; } File[] dirfiles = dir.listFiles(file -> (file.getName().endsWith(".class"))); for(File file : dirfiles){ String className = file.getName().substring(0, file.getName().length() - ".class".length()); Class<?> clazz = null; try { clazz = Thread.currentThread().getContextClassLoader().loadClass(packageName + "." + className); if(clazz != null){ return clazz; } } catch (ClassNotFoundException e) { e.printStackTrace(); } } return null; } }
关于jvm类加载机制,虚拟机选择去调用那个类加载器
java语言没有类似于c/c++的连接,所有需要的类也是在运行期间动态加载到虚拟机中的,默认情况下我们使用的类加载器是系统默认的类加载器。在tomcat的lib下的jar包是通过tomcat对该web工程实例化的WebappClassLoader对象加载的,我现在有个疑问,以tomcat为例:当虚拟机运行tomcat的一个web工程时,在这个工程下虚拟机发现需要加载一个类,虚拟机是通过那个类加载器去加载这个类的.是通过调用Thread.currentThread.getContextClassLoader()返回的类加载器来加载这个类吗,还是先找到加载当前线程当前正在运行的方法的类类加载器,然后再用该加载器去加载? 简单一点:当虚拟机发现需要加载一个类时,虚拟机先去调用那个类加载器去加载?
调用java 类的final static 常量的时候虚拟机为什么没加载类
<p><span style="font-size: medium;"><span style="font-size: large;">      java类的static块会在java类被加载的时候执行,java会在使用到一个用户定义类的时候才动态加载它,这两句话对吧?</span></span></p> <p> </p> <p><span style="font-size: medium;"><span style="font-size: large;">      我定义了一个类如下</span></span></p> <p> </p> <p> </p> <pre name="code" class="java">public class Constant { public final static int CON=1; public static int SS=2; static { System.out.println("static"); } public static void print () { System.out.println("print"); } }</pre> <p> </p> <p><span style="font-size: large;">     我在main函数里分别使用如下代码的时候均会导致上边的类被加载从而static块执行输出了信息</span></p> <p> </p> <pre name="code" class="java"> Constant.print(); System.out.println(Constant.IS); Constant c=new Constant(); Class.forName("org.test.main.Constant");</pre> <p> </p> <p>    <span style="font-size: large;"> 但是使用如下语句上边类的static块却没执行输出也就意味着类没被加载</span></p> <p> </p> <pre name="code" class="java"> System.out.println(Constant.IS); </pre> <p> </p> <p>     <span style="font-size: 18px;">大家知道是怎么回事吗?</span></p><br /><strong>问题补充:</strong><br />哦 打错了哦 <br />Constant.print();&nbsp; <br />System.out.println(Constant.IS);&nbsp; <br />Constant c=new Constant();&nbsp;&nbsp; <br />Class.forName("org.test.main.Constant");&nbsp; <br /> <br />第二句应该是 <br />System.out.println(Constant.CON); <br /> <br /> <br />我补充一下 我说的意思是在main函数里面单独执行我列出的每个语句,用于观察static块执行与否,我说的结果全是经过实际的出来的,你们可以打开ide试一下。我就是不明白为什么引用类的静态常量不会导致类被加载(我刚才查到一篇文章也说了这个问题就是引用类的静态常量不会导致类被加载,但那篇文章同样没有解释为什么),难道jvm规范是就这么规定的?<br /><strong>问题补充:</strong><br /> 今天不知怎么了 眼神还不好使了呢。我定义的CON是静态常量,SS是静态变量,输出写错了。&nbsp; 下面王者之剑说他执行输出类的静态常量时会执行静态块 但我这确实没执行。 <br /><pre name="code" class="java">public static void main(String[] args){ System.out.println(Constant.CON); }</pre><br /><strong>问题补充:</strong><br />上边的代码只输出了1&nbsp; static块的System.out.println("static");并没有执行
java类加载是否会加载.class2019类似的文件?
今天遇到一个线上问题,A类调用B类的方法,出现异常:java.lang.NoSuchMethodError,经查看服务器上B类的目录,有B.class和B.class20190517两个文件,B.class20190517文件中确实没有报错的method,经与发布人员沟通,之前确实也出现过类似加载了.class2019的文件导致的问题。请 问sh是否有遇到过类似问题的小伙伴?不太了解为什么B.class20190517会被加载?
Scala中动态加载jar包并调用方法,有个匿名类出现ClassNotFoundException
测试环境为:scala 2.11.8和spark2.1.0 单独jar包中TextProcess.scala中的代码: ``` object TextProcess { def process(col: String, df: Dataset[Row]) = { val rdd = df.select(col).rdd.map { x => val word = x.getAs[String](0).split(".")(0).toString() (word, 1) } val spark = SparkSession.builder().getOrCreate() val words = Array("one", "two", "two", "three", "three", "three") val wordPairsRDD = spark.sparkContext.parallelize(words).map(word => (word, 1)) val wordCountsWithReduce = wordPairsRDD.reduceByKey(_ + _) wordCountsWithReduce.foreach { x => println(x._1 , x._2) } val rd = rdd.reduceByKey(_ + _).map { x => Row.fromSeq(Array(x._1, x._2)) } val schema = StructType(Array(StructField("word", StringType, false), StructField("num", IntegerType, false))) spark.createDataFrame(rd, schema) } } ``` 测试调用代码: ``` object ProcessTest { def main(args: Array[String]) = { val spark = SparkSession.builder().master("local").getOrCreate() val data = Array("a.", "b.", "b.", "c.", "b.", "d.", "b.", "d.", "b.aa") val rdd = spark.sparkContext.parallelize(data, 1).map { x => Row.fromSeq(Seq(x)) } val schema = StructType(Array(StructField("text", StringType, false))) val df = spark.createDataFrame(rdd, schema) df.show() invoke(df) } def invoke(df: Dataset[Row]):Unit = { val f = new File("F:\\360CloudUI\\textprocess.jar") val loader = new URLClassLoader(Array(f.toURI().toURL()), getClass.getClassLoader) val clazz = loader.loadClass("cc.eabour.spark.TextProcess") val process = clazz.getDeclaredMethod("process", classOf[String], classOf[Dataset[_]]) process.invoke(null, "text", df) } } ``` 错误信息堆栈: ``` 7/09/24 18:43:08 INFO TaskSetManager: Starting task 0.0 in stage 1.0 (TID 1, localhost, executor driver, partition 0, PROCESS_LOCAL, 5981 bytes) 17/09/24 18:43:08 INFO Executor: Running task 0.0 in stage 1.0 (TID 1) 17/09/24 18:43:08 ERROR Executor: Exception in task 0.0 in stage 1.0 (TID 1) java.lang.ClassNotFoundException: cc.eabour.spark.TextProcess$$anonfun$4 at java.net.URLClassLoader$1.run(URLClassLoader.java:366) at java.net.URLClassLoader$1.run(URLClassLoader.java:355) at java.security.AccessController.doPrivileged(Native Method) at java.net.URLClassLoader.findClass(URLClassLoader.java:354) at java.lang.ClassLoader.loadClass(ClassLoader.java:423) at java.lang.ClassLoader.loadClass(ClassLoader.java:356) at java.lang.Class.forName0(Native Method) at java.lang.Class.forName(Class.java:264) at org.apache.spark.serializer.JavaDeserializationStream$$anon$1.resolveClass(JavaSerializer.scala:67) at java.io.ObjectInputStream.readNonProxyDesc(ObjectInputStream.java:1593) at java.io.ObjectInputStream.readClassDesc(ObjectInputStream.java:1514) at java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:1750) at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1347) at java.io.ObjectInputStream.defaultReadFields(ObjectInputStream.java:1964) at java.io.ObjectInputStream.readSerialData(ObjectInputStream.java:1888) at java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:1771) at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1347) at java.io.ObjectInputStream.defaultReadFields(ObjectInputStream.java:1964) at java.io.ObjectInputStream.readSerialData(ObjectInputStream.java:1888) at java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:1771) at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1347) at java.io.ObjectInputStream.defaultReadFields(ObjectInputStream.java:1964) at java.io.ObjectInputStream.readSerialData(ObjectInputStream.java:1888) at java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:1771) at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1347) at java.io.ObjectInputStream.readObject(ObjectInputStream.java:369) at org.apache.spark.serializer.JavaDeserializationStream.readObject(JavaSerializer.scala:75) at org.apache.spark.serializer.JavaSerializerInstance.deserialize(JavaSerializer.scala:114) at org.apache.spark.scheduler.ShuffleMapTask.runTask(ShuffleMapTask.scala:85) at org.apache.spark.scheduler.ShuffleMapTask.runTask(ShuffleMapTask.scala:53) at org.apache.spark.scheduler.Task.run(Task.scala:99) at org.apache.spark.executor.Executor$TaskRunner.run(Executor.scala:282) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603) at java.lang.Thread.run(Thread.java:722) 17/09/24 18:43:08 WARN TaskSetManager: Lost task 0.0 in stage 1.0 (TID 1, localhost, executor driver): java.lang.ClassNotFoundException: cc.eabour.spark.TextProcess$$anonfun$4 at java.net.URLClassLoader$1.run(URLClassLoader.java:366) at java.net.URLClassLoader$1.run(URLClassLoader.java:355) at java.security.AccessController.doPrivileged(Native Method) at java.net.URLClassLoader.findClass(URLClassLoader.java:354) at java.lang.ClassLoader.loadClass(ClassLoader.java:423) at java.lang.ClassLoader.loadClass(ClassLoader.java:356) at java.lang.Class.forName0(Native Method) at java.lang.Class.forName(Class.java:264) at org.apache.spark.serializer.JavaDeserializationStream$$anon$1.resolveClass(JavaSerializer.scala:67) at java.io.ObjectInputStream.readNonProxyDesc(ObjectInputStream.java:1593) at java.io.ObjectInputStream.readClassDesc(ObjectInputStream.java:1514) at java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:1750) at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1347) at java.io.ObjectInputStream.defaultReadFields(ObjectInputStream.java:1964) at java.io.ObjectInputStream.readSerialData(ObjectInputStream.java:1888) at java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:1771) at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1347) at java.io.ObjectInputStream.defaultReadFields(ObjectInputStream.java:1964) at java.io.ObjectInputStream.readSerialData(ObjectInputStream.java:1888) at java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:1771) at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1347) at java.io.ObjectInputStream.defaultReadFields(ObjectInputStream.java:1964) at java.io.ObjectInputStream.readSerialData(ObjectInputStream.java:1888) at java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:1771) at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1347) at java.io.ObjectInputStream.readObject(ObjectInputStream.java:369) at org.apache.spark.serializer.JavaDeserializationStream.readObject(JavaSerializer.scala:75) at org.apache.spark.serializer.JavaSerializerInstance.deserialize(JavaSerializer.scala:114) at org.apache.spark.scheduler.ShuffleMapTask.runTask(ShuffleMapTask.scala:85) at org.apache.spark.scheduler.ShuffleMapTask.runTask(ShuffleMapTask.scala:53) at org.apache.spark.scheduler.Task.run(Task.scala:99) at org.apache.spark.executor.Executor$TaskRunner.run(Executor.scala:282) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603) at java.lang.Thread.run(Thread.java:722) 17/09/24 18:43:08 ERROR TaskSetManager: Task 0 in stage 1.0 failed 1 times; aborting job 17/09/24 18:43:08 INFO TaskSchedulerImpl: Removed TaskSet 1.0, whose tasks have all completed, from pool 17/09/24 18:43:08 INFO TaskSchedulerImpl: Cancelling stage 1 ``` 不知道是spark的使用问题还是scala的调用问题。求指导
调用其他类时不能识别中文正则表达式。
做了Console类(控制台)和Add类(添加到文件),Add类里将键入的汉字追加到ArrayList,然后输出到txt,用utf-8编码,这个类运行操作都没问题,可是用Console类调用Add类时,键入的汉字却不被识别了,为什么呢? 以下是部分代码 Add类的识别汉字的代码 ``` public static boolean rules(String newXingShi) { boolean flag = newXingShi.matches("[\\u4e00-\\u9fa5]{1,4}"); if (flag == true) { return true; } else { System.out.println("输入不符合规范,添加失败!"); return false; } } ``` Add类运行主方法结果 请输入要添加的: 即 添加成功! Console类调用Add类 ``` AddXingShi.main(null); ``` 运行结果 请输入要添加的: 即 输入不符合规范,添加失败! 请问这个是什么问题?
java调用dll的特别问题
不知道有没有人遇到过类似的情况,在测试调用dll的时候,创建java project是可以通过测试(dll不管是直接放到项目根目录还是jdk的bin目录都可以), 但是在移植到java web项目中时dll虽然加载成功了,但是在调用接口时程序退出,没有任何报错, 也没有产生任何日志信息,就简单的退出。 然后想将java project作为独立项目,然后通过开放接口的方式供原来的java web项目调用,但是测试了rmi接口与webservice接口都出现前面的情况,程序直接退出,也没有任何信息可以查询。 可以保证的是java project可以正常运行,java web项目dll是正常加载了的,接口方法在java project中正常调用,在web项目中就不行。 后来怀疑是内存不足,调大内存后重新创建了一个新的web项目,只在启动时加了个监听器,在监听器中进行dll调用及接口测试,依然不行。 现在很疑惑的是为什么在java project中可以正常运行,但是在java web项目中就出问题,不知道有没有人遇到过,希望能够提供一些思路
JSP页面的onclick()怎样调用Java方法?
``` @RequestMapping("/mail") public class Mail { @RequestMapping("/mailto") public void mail(){ MailSenderInfo mailInfo = new MailSenderInfo(); mailInfo.setMailServerHost("smtp.yeah.net"); mailInfo.setMailServerPort("25"); mailInfo.setValidate(true); mailInfo.setUserName("123456"); mailInfo.setPassword("456789"); mailInfo.setFromAddress("123456@yeah.net"); mailInfo.setToAddress("132456@163.com"); mailInfo.setSubject("有新申请"); mailInfo.setContent("content"); SimpleMailSender sms = new SimpleMailSender(); sms.sendTextMail(mailInfo); } } ``` 这是我一个Java类中的一个方法,是用来发送邮件的,现在我想在一个JSP页面中添加一个button,并且在点击时调用这个方法 ``` <input type="button" value="发送邮件" onclick="mail()"> ``` 请问我的后台方法function mail()应该怎么写呢?
关于线程上下文类加载器的疑问?
## 看了很多博客都会这样写: 在Java应用中存在着很多服务提供者接口(Service Provider Interface,SPI),这些接口允许第三方为它们提供实现,如常见的 SPI 有 JDBC、JNDI等,这些 SPI 的接口属于 Java 核心库,一般存在rt.jar包中,由Bootstrap类加载器加载,而 SPI 的第三方实现代码则是作为Java应用所依赖的 jar 包被存放在classpath路径下,由于SPI接口中的代码经常需要加载具体的第三方实现类并调用其相关方法,但SPI的核心接口类是由引导类加载器来加载的,而Bootstrap类加载器无法直接加载SPI的实现类,同时由于双亲委派模式的存在,Bootstrap类加载器也无法反向委托AppClassLoader加载器SPI的实现类。在这种情况下,我们就需要一种特殊的类加载器来加载第三方的类库,而线程上下文类加载器就是很好的选择。 ## 我的疑惑: 类加载器的双亲委派机制就是向上委派给父加载器去加载,父加载器不能加载的才让子加载器加载。Bootstrap类加载器无法加载的类会让ext类加载器加载,ext类加载器无法加载的类会让app类加载器加载。。。_**所以为什么Bootstrap类加载器也无法反向委托AppClassLoader加载器SPI的实现类**_??
如何使用java命令调用某个jar文件中的方法?
小弟前段时间制作了一个爬取某个新闻页面的类,并将其制作成了jar包,请问如何动态加载这个r包,请问下步如何实现?求帮助。 源码如下: ``` package Test01; import java.io.File; import java.lang.reflect.Method; import java.net.URL; import java.net.URLClassLoader; public class Demo2 { public static void main(String[] args) { URL[] urls = new URL[] {}; MyClassLoader classLoader = new MyClassLoader(urls, null); try { classLoader.addJar(new File("E:\\JoImages\\JsoupBaidu\\com.sdzw.test.spider.baidu.jar").toURI().toURL()); Class<?> testDAO = classLoader.loadClass("com.sdzw.test.dao.TestDAO"); Method method = testDAO.getDeclaredMethod("RunBaidu"); method.invoke(null, null); } catch (Exception e) { e.printStackTrace(); } } /** * URLClassLoader的子类 * 添加addJar方法 * @author Administrator * */ private static class MyClassLoader extends URLClassLoader { public MyClassLoader(URL[] urls) { super(urls); } public MyClassLoader(URL[] urls, ClassLoader parent) { super(urls, parent); } public void addJar(URL url) { this.addURL(url); } } } ``` 运行结果是这样的: ``` java.lang.reflect.InvocationTargetException at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) at java.lang.reflect.Method.invoke(Method.java:597) at Test01.Demo2.main(Demo2.java:16) Caused by: java.lang.NoClassDefFoundError: org/jsoup/Jsoup at com.sdzw.test.dao.TestDAO.RunBaidu(TestDAO.java:15) ... 5 more Caused by: java.lang.ClassNotFoundException: org.jsoup.Jsoup at java.net.URLClassLoader$1.run(URLClassLoader.java:200) at java.security.AccessController.doPrivileged(Native Method) at java.net.URLClassLoader.findClass(URLClassLoader.java:188) at java.lang.ClassLoader.loadClass(ClassLoader.java:307) at java.lang.ClassLoader.loadClass(ClassLoader.java:252) at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:320) ... 6 more ``` jar文件的源码是这样的: ``` package com.sdzw.test.dao; import org.jsoup.Jsoup; import org.jsoup.nodes.Document; import org.jsoup.nodes.Element; import org.jsoup.select.Elements; public class TestDAO { public static void RunBaidu(){ Document doc; String url="http://news.baidu.com/"; BaiduDAO dao =new BaiduDAO(); try { doc=Jsoup.connect(url).timeout(5000).get(); Elements mon=doc.select("#body a[mon]"); for(Element e: mon){ if(e.text().trim().length()>1&&e.attr("mon").length()>1){ String linkHref=e.attr("href"); String linkText=e.text().trim(); if(linkHref.startsWith("http://news.ifeng")){ dao.saveFengHuang(linkText, linkHref); }else if(linkHref.indexOf("baijia.baidu.com")!=-1){ System.out.println(linkHref); dao.saveBaijia(linkText, linkHref); }else if(linkHref.startsWith("http://news.xinhuanet.com")){ dao.savaXinhua(linkText, linkHref); } } } } catch (Exception e) { e.printStackTrace(); } } } ``` ``` public static void saveBaijia(String linkText,String linkHref) throws FileNotFoundException, IOException{ //将标题转换为合法标题 linkText=LinkTextSafe(linkText); //创建一个以标题为名称的txt文档,并将标题存放到文档中 dao.SaveFile("news/Baijia/"+linkText+".txt", linkText); //爬取页面中的指定内容,并将其存入相对应的文件当中 List<String> getContent = getContent(linkHref,"span.time", "div.article-author-time a", "div.article-detail p"); for(String content : getContent){ dao.SaveFile("news/Baijia/"+linkText+".txt", content); } } ```
动态生成 .java 和 .class 用什么加载器去加载?
![图片说明](https://img-ask.csdn.net/upload/201710/24/1508829673_92315.jpg) 调用当前方法,动态生成java文件,然后对其编译产生class文件。 ![图片说明](https://img-ask.csdn.net/upload/201710/24/1508829691_671834.jpg) 第一个断点生成了java文件,第二个断点产生class文件,然后想将这个class文件加载到内存。 第一种方式,用了ClassLoader.getSystemClassLoader() 获取的类加载器。如果这两个文件在运行方法前存在,去loadClass会正常运行。但是如果是调用方法产生的,就会抛一个java.lang.ClassNotFoundException: com.proxy.uproxy.$Proxy0的异常。 第二种方式,用了URLClassLoader的类加载器。结果发现,不管这两个文件什么时候产生的,都会正常执行。 之后看了一下这两个类加载器的的内容,不清楚是不是这个URLClassLoader路径的问题。 ![图片说明](https://img-ask.csdn.net/upload/201710/24/1508830066_876360.jpg) ![图片说明](https://img-ask.csdn.net/upload/201710/24/1508830075_292144.jpg) 发现SystemClassLoader会包含URLClassLoader,此时URLClassLoader所指向的路径是lib包。而直接调用URLClassLoader指向的我们指定的路径。 1.为什么使用SystemClassLoader,URLClassLoader会指向lib包。 2.为什么使用SystemClassLoader去加载,会报ClassNotFoundException。 3.SystemClassLoader和URLClassLoader的关系? 4.动态生成 .java 和 .class 用什么加载器去加载?加载机制是什么样的?
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
【JSON解析】浅谈JSONObject的使用
简介 在程序开发过程中,在参数传递,函数返回值等方面,越来越多的使用JSON。JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,同时也易于机器解析和生成、易于理解、阅读和撰写,而且Json采用完全独立于语言的文本格式,这使得Json成为理想的数据交换语言。 JSON建构于两种结构: “名称/值”对的集合(A Collection of name/va...
卸载 x 雷某度!GitHub 标星 1.5w+,从此我只用这款全能高速下载工具!
作者 | Rocky0429 来源 | Python空间 大家好,我是 Rocky0429,一个喜欢在网上收集各种资源的蒟蒻… 网上资源眼花缭乱,下载的方式也同样千奇百怪,比如 BT 下载,磁力链接,网盘资源等等等等,下个资源可真不容易,不一样的方式要用不同的下载软件,因此某比较有名的 x 雷和某度网盘成了我经常使用的工具。 作为一个没有钱的穷鬼,某度网盘几十 kb 的下载速度让我...
2019年还剩1天,我从外包公司离职了
这日子过的可真快啊,2019年还剩1天,外包公司干了不到3个月,我离职了
我一个37岁的程序员朋友
周末了,人一旦没有点事情干,心里就瞎想,而且跟几个老男人坐在一起,更容易瞎想,我自己现在也是 30 岁了,也是无时无刻在担心自己的职业生涯,担心丢掉工作没有收入,担心身体机能下降,担心突...
计算机网络的核心概念
这是《计算机网络》系列文章的第二篇文章 我们第一篇文章讲述了计算机网络的基本概念,互联网的基本名词,什么是协议以及几种接入网以及网络传输的物理媒体,那么本篇文章我们来探讨一下网络核心、交换网络、时延、丢包、吞吐量以及计算机网络的协议层次和网络攻击。 网络核心 网络的核心是由因特网端系统和链路构成的网状网络,下面这幅图正确的表达了这一点 那么在不同的 ISP 和本地以及家庭网络是如何交换信息的呢?...
python自动下载图片
近日闲来无事,总有一种无形的力量萦绕在朕身边,让朕精神涣散,昏昏欲睡。 可是,像朕这么有职业操守的社畜怎么能在上班期间睡瞌睡呢,我不禁陷入了沉思。。。。 突然旁边的IOS同事问:‘嘿,兄弟,我发现一个网站的图片很有意思啊,能不能帮我保存下来提升我的开发灵感?’ 作为一个坚强的社畜怎么能说自己不行呢,当时朕就不假思索的答应:‘oh, It’s simple. Wait for me for a ...
一名大专同学的四个问题
【前言】   收到一封来信,赶上各种事情拖了几日,利用今天要放下工作的时机,做个回复。   2020年到了,就以这一封信,作为开年标志吧。 【正文】   您好,我是一名现在有很多困惑的大二学生。有一些问题想要向您请教。   先说一下我的基本情况,高考失利,不想复读,来到广州一所大专读计算机应用技术专业。学校是偏艺术类的,计算机专业没有实验室更不用说工作室了。而且学校的学风也不好。但我很想在计算机领...
复习一周,京东+百度一面,不小心都拿了Offer
京东和百度一面都问了啥,面试官百般刁难,可惜我全会。
Java 14 都快来了,为什么还有这么多人固守Java 8?
从Java 9开始,Java版本的发布就让人眼花缭乱了。每隔6个月,都会冒出一个新版本出来,Java 10 , Java 11, Java 12, Java 13, 到2020年3月份,...
达摩院十大科技趋势发布:2020 非同小可!
【CSDN编者按】1月2日,阿里巴巴发布《达摩院2020十大科技趋势》,十大科技趋势分别是:人工智能从感知智能向认知智能演进;计算存储一体化突破AI算力瓶颈;工业互联网的超融合;机器间大规模协作成为可能;模块化降低芯片设计门槛;规模化生产级区块链应用将走入大众;量子计算进入攻坚期;新材料推动半导体器件革新;保护数据隐私的AI技术将加速落地;云成为IT技术创新的中心 。 新的画卷,正在徐徐展开。...
轻松搭建基于 SpringBoot + Vue 的 Web 商城应用
首先介绍下在本文出现的几个比较重要的概念: 函数计算(Function Compute): 函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传。函数计算准备计算资源,并以弹性伸缩的方式运行用户代码,而用户只需根据实际代码运行所消耗的资源进行付费。Fun: Fun 是一个用于支持 Serverless 应用部署的工具,能帮助您便捷地管理函数计算、API ...
讲真,这两个IDE插件,可以让你写出质量杠杠的代码
周末躺在床上看《拯救大兵瑞恩》 周末在闲逛的时候,发现了两个优秀的 IDE 插件,据说可以提高代码的质量,我就安装了一下,试了试以后发现,确实很不错,就推荐给大家。 01、Alibaba Java 代码规范插件 《阿里巴巴 Java 开发手册》,相信大家都不会感到陌生,其 IDEA 插件的下载次数据说达到了 80 万次,我今天又贡献了一次。嘿嘿。 该项目的插件地址: https://github....
Python+OpenCV实时图像处理
目录 1、导入库文件 2、设计GUI 3、调用摄像头 4、实时图像处理 4.1、阈值二值化 4.2、边缘检测 4.3、轮廓检测 4.4、高斯滤波 4.5、色彩转换 4.6、调节对比度 5、退出系统 初学OpenCV图像处理的小伙伴肯定对什么高斯函数、滤波处理、阈值二值化等特性非常头疼,这里给各位分享一个小项目,可通过摄像头实时动态查看各类图像处理的特点,也可对各位调参、测试...
2020年一线城市程序员工资大调查
人才需求 一线城市共发布岗位38115个,招聘120827人。 其中 beijing 22805 guangzhou 25081 shanghai 39614 shenzhen 33327 工资分布 2020年中国一线城市程序员的平均工资为16285元,工资中位数为14583元,其中95%的人的工资位于5000到20000元之间。 和往年数据比较: yea...
为什么猝死的都是程序员,基本上不见产品经理猝死呢?
相信大家时不时听到程序员猝死的消息,但是基本上听不到产品经理猝死的消息,这是为什么呢? 我们先百度搜一下:程序员猝死,出现将近700多万条搜索结果: 搜索一下:产品经理猝死,只有400万条的搜索结果,从搜索结果数量上来看,程序员猝死的搜索结果就比产品经理猝死的搜索结果高了一倍,而且从下图可以看到,首页里面的五条搜索结果,其实只有两条才是符合条件。 所以程序员猝死的概率真的比产品经理大,并不是错...
害怕面试被问HashMap?这一篇就搞定了!
声明:本文以jdk1.8为主! 搞定HashMap 作为一个Java从业者,面试的时候肯定会被问到过HashMap,因为对于HashMap来说,可以说是Java集合中的精髓了,如果你觉得自己对它掌握的还不够好,我想今天这篇文章会非常适合你,至少,看了今天这篇文章,以后不怕面试被问HashMap了 其实在我学习HashMap的过程中,我个人觉得HashMap还是挺复杂的,如果真的想把它搞得明明白...
毕业5年,我问遍了身边的大佬,总结了他们的学习方法
我问了身边10个大佬,总结了他们的学习方法,原来成功都是有迹可循的。
程序员如何通过造轮子走向人生巅峰?
前言:你所做的事情,也许暂时看不到成果。但不要灰心,你不是没有成长,而是在扎根。 程序员圈经常流行的一句话:“不要重复造轮子”。在计算机领域,我们将封装好的组件、库,叫做轮子。因为它可以拿来直接用,直接塞进我们的项目中,就能实现对应的功能。 有些同学会问,人家都已经做好了,你再来重新弄一遍,有什么意义?这不是在浪费时间吗。 殊不知,造轮子是一种学习方式,能快速进步,造得好,是自己超强能力的表...
推荐10个堪称神器的学习网站
每天都会收到很多读者的私信,问我:“二哥,有什么推荐的学习网站吗?最近很浮躁,手头的一些网站都看烦了,想看看二哥这里有什么新鲜货。” 今天一早做了个恶梦,梦到被老板辞退了。虽然说在我们公司,只有我辞退老板的份,没有老板辞退我这一说,但是还是被吓得 4 点多都起来了。(主要是因为我掌握着公司所有的核心源码,哈哈哈) 既然 4 点多起来,就得好好利用起来。于是我就挑选了 10 个堪称神器的学习网站,推...
这些软件太强了,Windows必装!尤其程序员!
Windows可谓是大多数人的生产力工具,集娱乐办公于一体,虽然在程序员这个群体中都说苹果是信仰,但是大部分不都是从Windows过来的,而且现在依然有很多的程序员用Windows。 所以,今天我就把我私藏的Windows必装的软件分享给大家,如果有一个你没有用过甚至没有听过,那你就赚了????,这可都是提升你幸福感的高效率生产力工具哦! 走起!???? NO、1 ScreenToGif 屏幕,摄像头和白板...
阿里面试,面试官没想到一个ArrayList,我都能跟他扯半小时
我是真的没想到,面试官会这样问我ArrayList。
曾经优秀的人,怎么就突然不优秀了。
职场上有很多辛酸事,很多合伙人出局的故事,很多技术骨干被裁员的故事。说来模板都类似,曾经是名校毕业,曾经是优秀员工,曾经被领导表扬,曾经业绩突出,然而突然有一天,因为种种原因,被裁员了,...
大学四年因为知道了这32个网站,我成了别人眼中的大神!
依稀记得,毕业那天,我们导员发给我毕业证的时候对我说“你可是咱们系的风云人物啊”,哎呀,别提当时多开心啦????,嗯,我们导员是所有导员中最帅的一个,真的???? 不过,导员说的是实话,很多人都叫我大神的,为啥,因为我知道这32个网站啊,你说强不强????,这次是绝对的干货,看好啦,走起来! PS:每个网站都是学计算机混互联网必须知道的,真的牛杯,我就不过多介绍了,大家自行探索,觉得没用的,尽管留言吐槽吧???? 社...
良心推荐,我珍藏的一些Chrome插件
上次搬家的时候,发了一个朋友圈,附带的照片中不小心暴露了自己的 Chrome 浏览器插件之多,于是就有小伙伴评论说分享一下我觉得还不错的浏览器插件。 我下面就把我日常工作和学习中经常用到的一些 Chrome 浏览器插件分享给大家,随便一个都能提高你的“生活品质”和工作效率。 Markdown Here Markdown Here 可以让你更愉快的写邮件,由于支持 Markdown 直接转电子邮...
看完这篇HTTP,跟面试官扯皮就没问题了
我是一名程序员,我的主要编程语言是 Java,我更是一名 Web 开发人员,所以我必须要了解 HTTP,所以本篇文章就来带你从 HTTP 入门到进阶,看完让你有一种恍然大悟、醍醐灌顶的感觉。 最初在有网络之前,我们的电脑都是单机的,单机系统是孤立的,我还记得 05 年前那会儿家里有个电脑,想打电脑游戏还得两个人在一个电脑上玩儿,及其不方便。我就想为什么家里人不让上网,我的同学 xxx 家里有网,每...
史上最全的IDEA快捷键总结
现在Idea成了主流开发工具,这篇博客对其使用的快捷键做了总结,希望对大家的开发工作有所帮助。
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
谁是华为扫地僧?
是的,华为也有扫地僧!2020年2月11-12日,“养在深闺人不知”的华为2012实验室扫地僧们,将在华为开发者大会2020(Cloud)上,和大家见面。到时,你可以和扫地僧们,吃一个洋...
Idea 中最常用的10款插件(提高开发效率),一定要学会使用!
学习使用一些插件,可以提高开发效率。对于我们开发人员很有帮助。这篇博客介绍了开发中使用的插件。
立即提问