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中局部类调用它所在的局部方法中的变量问题

``` package com.review; public class P205Demo_LocalClass { public static void main(String[] args) { Outer5 o = new Outer5(); o.method(); } } class Outer5{ public void method() { int num = 10; class Inner5{ public void print() { System.out.println("局部类只能在所在方法中被调用 ,方法中的num的调用" +num); } } Inner5 i = new Inner5(); i.print(); } } ``` 在我看的JAVA教学视频中举了这个例子。 在这个的例子里,在测试类中执行完o.method()方法后,method()方法弹栈,int num这个变量也就消失了。老师说而i这个对象可能还没消失,i.print()已经找不到num了,所以会报错,在视频里老师使用editplus也确实报错了。所以需要在num前面加final延长它的生命周期。 但是我在使用eclipse编译运行上面的代码时并没有并没有报错,运行结果也是正确的。 我的想法是,在method方法弹栈后,i这个对象其实也被回收了,所以才没有报错。 请问各位大佬我这么想对不对,还是因为其他的原因。

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 反射调用方法,方法内部调用了外部的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反射,自动调用方法,方法的返回值类型是不一定的,怎么得到方法的返回值类型的原来的类型!

java反射动态获取方法的返回值类型? ![图片说明](https://img-ask.csdn.net/upload/201811/08/1541668477_850877.png) ![图片说明](https://img-ask.csdn.net/upload/201811/08/1541668489_297052.png) 代码如下: ``` package javase; import java.lang.reflect.Constructor; import java.lang.reflect.Method; import java.lang.reflect.Type; import java.util.ArrayList; import java.util.List; public class Person { static List<String> list; public void eat() { System.out.println("我是eat()函数"); } public String sayHello(String name) { return "hello,我是" + name + "!"; } public String jump(String name, int age) { return "hello,我是" + name + ",我今年" + age + "岁了!"; } public List<String> returnList() { // List<String> list = new ArrayList<String>(); list = new ArrayList<String>(); list.add("令狐冲"); list.add("韦小宝"); list.add("张无忌"); list.add("杨过"); list.add("乔峰"); return list; } public static void main(String[] args) throws Exception { Class cla = Class.forName("javase.Person"); Constructor constructor = cla.getConstructor(); Object obj = constructor.newInstance(); Method[] declaredMethods = cla.getDeclaredMethods(); for (Method method : declaredMethods) { System.out.println(method.getName() + " / " + method); Class[] parameterTypes = method.getParameterTypes(); if (parameterTypes.length > 0) { System.out.print(method.getName() + "方法的参数类型:"); } else { System.out.print(method.getName() + "方法没有参数"); } for (Class parameterType : parameterTypes) { System.out.print(parameterType.getName() + "\t"); } System.out.println("\n--------------------------------------------------"); } System.out.println("******************************"); // 使用反射,动态调用对象的函数 Method method = cla.getMethod("eat"); Object returnValue = method.invoke(obj); System.out.println(returnValue); // 动态调用对象的函数 Method method2 = cla.getMethod("sayHello", String.class); Object returnValue2 = method2.invoke(obj, "令狐冲"); System.out.println(returnValue2); // 动态调用对象的函数 Method method3 = cla.getMethod("jump", String.class, int.class); Object returnValue3 = method3.invoke(obj, "令狐冲", 16); System.out.println(returnValue3); // 动态调用对象的函数 Method method4 = cla.getMethod("returnList"); Type returnType = method4.getGenericReturnType(); System.out.println(method4.getName() + "方法的返回值类型=" + returnType); /* * returnList方法返回值类型是List<String>,所以returnValue4变量原本的类型是List<String> * 还有一个问题值得我们思考,每个方法的返回值类型都可能不一样,我们在利用反射调用完invoke()方法后,得到的返回值类 * 型都是Object,怎么转换回每个方法它自己的原本的返回值类型呢? */ Object returnValue4 = method4.invoke(obj); System.out.println("方法的返回值类型:" + method4.getReturnType().cast(method4.invoke(obj))); System.out.println(returnValue4 + " / " + returnValue4.getClass()); for (String str : list) { System.out.println("利用反射自动调用完returnList方法后集合元素" + str); } List<String> returnValue5 = (List<String>) method4.invoke(obj); for (String string : returnValue5) { System.out.println(string); } } } ``` 一言以蔽之,我就是想做到如下的代码这样: ``` Method method4 = cla.getMethod("returnList"); //我想下面的Object变成动态数据类型(即returnList方法的返回值类型) Object returnValue4 = method4.invoke(obj); //有没有可能变成下面这样 method4.getReturnType() returnValue4 = (method4.getReturnType())method4.invoke(obj); //到时候就可以拿到每个方法的具体的返回值,方法返回Map,我就可以拿到Map,方法返回int,我就拿到int,方法返回String,我就拿到String,方法返回List<Student>,我就可以拿到List<Student> ``` 运行结果截图: ![图片说明](https://img-ask.csdn.net/upload/201811/08/1541668669_521947.png) ![图片说明](https://img-ask.csdn.net/upload/201811/08/1541668680_381683.png)

关于jvm类加载机制,虚拟机选择去调用那个类加载器

java语言没有类似于c/c++的连接,所有需要的类也是在运行期间动态加载到虚拟机中的,默认情况下我们使用的类加载器是系统默认的类加载器。在tomcat的lib下的jar包是通过tomcat对该web工程实例化的WebappClassLoader对象加载的,我现在有个疑问,以tomcat为例:当虚拟机运行tomcat的一个web工程时,在这个工程下虚拟机发现需要加载一个类,虚拟机是通过那个类加载器去加载这个类的.是通过调用Thread.currentThread.getContextClassLoader()返回的类加载器来加载这个类吗,还是先找到加载当前线程当前正在运行的方法的类类加载器,然后再用该加载器去加载? 简单一点:当虚拟机发现需要加载一个类时,虚拟机先去调用那个类加载器去加载?

Java中toString()方法调用的疑问

最近在学习Java时,发现一个对象.toString()之后,还能再.toString(),但是输出结果一样,都是完整类名 + @ + 十六进制的哈希码。 自己重写的toString方法也是可以在一个类时多次调用,而且输出结果相同,所以有些疑惑,这个相同方法的多次调用到底是在干什么,他们两次穿进去的obj应该是不同的(第一次穿进去的是对象a,第二次穿进去的是a.toString())但是最后输出的结果却是一样的,这是为什么呢? 求大佬解答

Java反射机制的方法调用

大哥们,初学Java两个月的小白,这两天复习反射有点懵,今晚又发现个问题,就是再空参内添加一句输出语句,再创建个show方法给个输出语句,到测试类中时,当我获得构造器后再使用Method获取show方法时,两句语句会同时一起在控制台进行输出.可是我只想输出个show方法,该咋整啊?![图片说明](https://img-ask.csdn.net/upload/201905/13/1557755006_366482.png) 在这红框第一步操作时,控制台可输出a,但是使用method获得方法又不得去使用第一步的操作,我该怎么操作才能在控制台只输出一个b的结果.

java使用jna调用c++动态库

在java调用c++动态库时,需要将C++结构体和Java类进行映射。但是c++中结构体实现了1字节对齐,那么java中应该怎么处理才能实现相应操作?谢谢各位老铁了

java实体类怎么传入动态属性值

![图片说明](https://img-ask.csdn.net/upload/201704/12/1491968410_714353.png) 如图,skuList是已经存在的属性值,下面的{["测试":"测试"]}值是动态的,key值怎么填,怎么写实体类

java子类构造方法的问题--必须要先调用父类的构造方法么?

好像有这样一说法在子类的构造方法中,如果没有调用父类的构造方法,就会默认加一个super() 如果父类没有这一构造方法,就会报错。我想问java在子类的构造方法时候是先检验是否能生成父类的对象还是先检测是否调用了该子类的其他构造方法,因为我这样试了试通过了编译。![图片说明](https://img-ask.csdn.net/upload/201507/13/1436786382_906296.png)

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在接口实例化类对象后可以调用这个类自身的成员方法吗?

比如说: interface Inter { public void function(); } class Main implements Inter { Main(){} private int n; public void function() { } public int add(int a,int b) { return a+b; } public static void main(String[] args) { Inter p=new Main(); //这里是可以使用p.function()的,但是可不可以使用p.add()呢?? } }

如何在一个类中调用另一个类的方法?

问题是这样的:小弟先定义了一个DB_Operation类,然后在该类中定义了一个操作数据库的方法,源代码如下: [code="java"]package com.chaliezhou.sms.service; import java.sql.CallableStatement; import java.sql.Connection; import java.sql.ResultSet; import java.sql.Statement; import com.chaliezhou.sms.conn.JDBC_Connections; public class DB_Operations { // 抽出添加数据的方法 public static void getOracleAddData() throws Exception{ String str = null; String[] st = new String[6]; Connection conn = JDBC_Connections.getOracleConnection(); String sql = "{call PRO_STU_ADD(?,?,?,?,?,?)}"; CallableStatement cstmt = conn.prepareCall(sql); cstmt.clearBatch(); try{ //将学号数据转整形 int i = Integer.parseInt(st[0]); //将分数数据转浮点型 float f1 = Float.parseFloat(st[2]); float f2 = Float.parseFloat(st[3]); float f3 = Float.parseFloat(st[4]); float f4 = (f1+f2+f3)/3; cstmt.setInt(1,i); cstmt.setString(2,st[1]); cstmt.setFloat(3,f1); cstmt.setFloat(4,f2); cstmt.setFloat(5,f3); cstmt.setFloat(6,f4); //提交数据缓冲 cstmt.addBatch(); //提交数据 conn.commit(); System.out.println("数据插入成功!"); }catch(Exception ex){ ex.printStackTrace(); } }[/code] 然后又定义了一个操作类用来从控制台接收数据,代码如下: [code="java"]package com.chaliezhou.sms.view; import java.sql.Connection; import java.util.Scanner; import com.chaliezhou.sms.conn.JDBC_Connections; import com.chaliezhou.sms.service.DB_Operations; public class Data_IO { public static void main(String[] args) throws Exception { Connection conn = JDBC_Connections.getOracleConnection(); Object ob = null; String[] st = new String[6]; Scanner sc = new Scanner(System.in); System.out.println("请输入学号:"); st[0] = sc.nextLine(); System.out.println("请输入姓名:"); st[1] = sc.nextLine(); System.out.println("请输入语文分数:"); st[2] = sc.nextLine(); System.out.println("请输入数学分数:"); st[3] = sc.nextLine(); System.out.println("请输入英语分数:"); st[4] = sc.nextLine(); [color=darkred] getOracleAddData();[/color] } }[/code] 请问怎样在这个操作类中调用方法呢?我在这里写了getOracleAddData()(红字所示),但提示出错。正确的写法应该是怎样呢?

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的调用问题。求指导

java为什么类体中不能创建对象并调用方法??

import java.util.*; public class TestMap{ String s; public static void main(String args[]){ TestMap tt=new TestMap(); System.out.println(tt.s); } Map map=new HashMap(); map.put(1,"wumin"); map.put(2,"donghuan"); map.put(3,"dong"); String s=(String)map.get(1); } 报错如下: D:\用户目录\桌面\java\contains\TestMap.java:21: 错误: 需要<标识符> map.put(1,"wumin"); ^ D:\用户目录\桌面\java\contains\TestMap.java:21: 错误: 非法的类型开始 map.put(1,"wumin"); ^ D:\用户目录\桌面\java\contains\TestMap.java:21: 错误: 非法的类型开始 map.put(1,"wumin"); ^ D:\用户目录\桌面\java\contains\TestMap.java:22: 错误: 需要<标识符> map.put(2,"donghuan"); ^ D:\用户目录\桌面\java\contains\TestMap.java:22: 错误: 非法的类型开始 map.put(2,"donghuan"); ^ D:\用户目录\桌面\java\contains\TestMap.java:22: 错误: 非法的类型开始 map.put(2,"donghuan"); ^ D:\用户目录\桌面\java\contains\TestMap.java:23: 错误: 需要<标识符> map.put(3,"dong"); ^ D:\用户目录\桌面\java\contains\TestMap.java:23: 错误: 非法的类型开始 map.put(3,"dong"); ^ D:\用户目录\桌面\java\contains\TestMap.java:23: 错误: 非法的类型开始 map.put(3,"dong"); ^ 9 个错误 <<< Process finished. (Exit code 1) ================ READY ================

如何使用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); } } ```

学Python后到底能干什么?网友:我太难了

感觉全世界营销文都在推Python,但是找不到工作的话,又有哪个机构会站出来给我推荐工作? 笔者冷静分析多方数据,想跟大家说:关于超越老牌霸主Java,过去几年间Python一直都被寄予厚望。但是事实是虽然上升趋势,但是国内环境下,一时间是无法马上就超越Java的,也可以换句话说:超越Java只是时间问题罢。 太嚣张了会Python的人!找工作拿高薪这么简单? https://edu....

大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了

大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...

在中国程序员是青春饭吗?

今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...

Java校招入职华为,半年后我跑路了

何来 我,一个双非本科弟弟,有幸在 19 届的秋招中得到前东家华为(以下简称 hw)的赏识,当时秋招签订就业协议,说是入了某 java bg,之后一系列组织架构调整原因等等让人无法理解的神操作,最终毕业前夕,被通知调往其他 bg 做嵌入式开发(纯 C 语言)。 由于已至于校招末尾,之前拿到的其他 offer 又无法再收回,一时感到无力回天,只得默默接受。 毕业后,直接入职开始了嵌入式苦旅,由于从未...

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

@程序员:GitHub这个项目快薅羊毛

今天下午在朋友圈看到很多人都在发github的羊毛,一时没明白是怎么回事。 后来上百度搜索了一下,原来真有这回事,毕竟资源主义的羊毛不少啊,1000刀刷爆了朋友圈!不知道你们的朋友圈有没有看到类似的消息。 这到底是啥情况? 微软开发者平台GitHub 的一个区块链项目 Handshake ,搞了一个招募新会员的活动,面向GitHub 上前 25万名开发者派送 4,246.99 HNS币,大约价...

用python打开电脑摄像头,并把图像传回qq邮箱【Pyinstaller打包】

前言: 如何悄悄的打开朋友的摄像头,看看她最近过的怎么样,嘿嘿!这次让我带你们来实现这个功能。 注: 这个程序仅限在朋友之间开玩笑,别去搞什么违法的事情哦。 代码 发送邮件 使用python内置的email模块即可完成。导入相应的代码封装为一个send函数,顺便导入需要导入的包 注: 下面的代码有三处要修改的地方,两处写的qq邮箱地址,还有一处写的qq邮箱授权码,不知道qq邮箱授权码的可以去百度一...

做了5年运维,靠着这份监控知识体系,我从3K变成了40K

从来没讲过运维,因为我觉得运维这种东西不需要太多的知识面,然后我一个做了运维朋友告诉我大错特错,他就是从3K的运维一步步到40K的,甚至笑着说:我现在感觉自己什么都能做。 既然讲,就讲最重要的吧。 监控是整个运维乃至整个产品生命周期中最重要的一环,事前及时预警发现故障,事后提供详实的数据用于追查定位问题。目前业界有很多不错的开源产品可供选择。选择一款开源的监控系统,是一个省时省力、效率最高的方...

计算机网络——浅析网络层

一、前言 注意,关于ipv4和ipv6,ipv4是ip协议第4版本,也表示这个版本的ip一共4个字节,同样地,ipv6是ip协议第6版本,也表示这个版本的ip一共6个字节。 关于网络层使用路由器实现互联:在计算机网络的分层结构中,不同层有不同的中继设备: 计算机网络层 中继设备/中继系统 物理层 中继器、集线器Hub 数据链路层 网桥或交换机(交换机是多端口网桥,两者本质上是一个东西) 网络层 路...

我以为我学懂了数据结构,直到看了这个导图才发现,我错了

数据结构与算法思维导图

技术大佬:我去,你写的 switch 语句也太老土了吧

昨天早上通过远程的方式 review 了两名新来同事的代码,大部分代码都写得很漂亮,严谨的同时注释也很到位,这令我非常满意。但当我看到他们当中有一个人写的 switch 语句时,还是忍不住破口大骂:“我擦,小王,你丫写的 switch 语句也太老土了吧!” 来看看小王写的代码吧,看完不要骂我装逼啊。 private static String createPlayer(PlayerTypes p...

华为初面+综合面试(Java技术面)附上面试题

华为面试整体流程大致分为笔试,性格测试,面试,综合面试,回学校等结果。笔试来说,华为的难度较中等,选择题难度和网易腾讯差不多。最后的代码题,相比下来就简单很多,一共3道题目,前2题很容易就AC,题目已经记不太清楚,不过难度确实不大。最后一题最后提交的代码过了75%的样例,一直没有发现剩下的25%可能存在什么坑。 笔试部分太久远,我就不怎么回忆了。直接将面试。 面试 如果说腾讯的面试是挥金如土...

和黑客斗争的 6 天!

互联网公司工作,很难避免不和黑客们打交道,我呆过的两家互联网公司,几乎每月每天每分钟都有黑客在公司网站上扫描。有的是寻找 Sql 注入的缺口,有的是寻找线上服务器可能存在的漏洞,大部分都...

讲一个程序员如何副业月赚三万的真实故事

loonggg读完需要3分钟速读仅需 1 分钟大家好,我是你们的校长。我之前讲过,这年头,只要肯动脑,肯行动,程序员凭借自己的技术,赚钱的方式还是有很多种的。仅仅靠在公司出卖自己的劳动时...

win10暴力查看wifi密码

刚才邻居打了个电话说:喂小灰,你家wifi的密码是多少,我怎么连不上了。 我。。。 我也忘了哎,就找到了一个好办法,分享给大家: 第一种情况:已经连接上的wifi,怎么知道密码? 打开:控制面板\网络和 Internet\网络连接 然后右击wifi连接的无线网卡,选择状态 然后像下图一样: 第二种情况:前提是我不知道啊,但是我以前知道密码。 此时可以利用dos命令了 1、利用netsh wlan...

上班一个月,后悔当初着急入职的选择了

最近有个老铁,告诉我说,上班一个月,后悔当初着急入职现在公司了。他之前在美图做手机研发,今年美图那边今年也有一波组织优化调整,他是其中一个,在协商离职后,当时捉急找工作上班,因为有房贷供着,不能没有收入来源。所以匆忙选了一家公司,实际上是一个大型外包公司,主要派遣给其他手机厂商做外包项目。**当时承诺待遇还不错,所以就立马入职去上班了。但是后面入职后,发现薪酬待遇这块并不是HR所说那样,那个HR自...

女程序员,为什么比男程序员少???

昨天看到一档综艺节目,讨论了两个话题:(1)中国学生的数学成绩,平均下来看,会比国外好?为什么?(2)男生的数学成绩,平均下来看,会比女生好?为什么?同时,我又联想到了一个技术圈经常讨...

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

记一次腾讯面试,我挂在了最熟悉不过的队列上……

腾讯后台面试,面试官问:如何自己实现队列?

如果你是老板,你会不会踢了这样的员工?

有个好朋友ZS,是技术总监,昨天问我:“有一个老下属,跟了我很多年,做事勤勤恳恳,主动性也很好。但随着公司的发展,他的进步速度,跟不上团队的步伐了,有点...

离职半年了,老东家又发 offer,回不回?

有小伙伴问松哥这个问题,他在上海某公司,在离职了几个月后,前公司的领导联系到他,希望他能够返聘回去,他很纠结要不要回去? 俗话说好马不吃回头草,但是这个小伙伴既然感到纠结了,我觉得至少说明了两个问题:1.曾经的公司还不错;2.现在的日子也不是很如意。否则应该就不会纠结了。 老实说,松哥之前也有过类似的经历,今天就来和小伙伴们聊聊回头草到底吃不吃。 首先一个基本观点,就是离职了也没必要和老东家弄的苦...

2020阿里全球数学大赛:3万名高手、4道题、2天2夜未交卷

阿里巴巴全球数学竞赛( Alibaba Global Mathematics Competition)由马云发起,由中国科学技术协会、阿里巴巴基金会、阿里巴巴达摩院共同举办。大赛不设报名门槛,全世界爱好数学的人都可参与,不论是否出身数学专业、是否投身数学研究。 2020年阿里巴巴达摩院邀请北京大学、剑桥大学、浙江大学等高校的顶尖数学教师组建了出题组。中科院院士、美国艺术与科学院院士、北京国际数学...

HTTP与HTTPS的区别

面试官问HTTP与HTTPS的区别,我这样回答让他竖起大拇指!

男生更看重女生的身材脸蛋,还是思想?

往往,我们看不进去大段大段的逻辑。深刻的哲理,往往短而精悍,一阵见血。问:产品经理挺漂亮的,有点心动,但不知道合不合得来。男生更看重女生的身材脸蛋,还是...

程序员为什么千万不要瞎努力?

本文作者用对比非常鲜明的两个开发团队的故事,讲解了敏捷开发之道 —— 如果你的团队缺乏统一标准的环境,那么即使勤劳努力,不仅会极其耗时而且成果甚微,使用...

为什么程序员做外包会被瞧不起?

二哥,有个事想询问下您的意见,您觉得应届生值得去外包吗?公司虽然挺大的,中xx,但待遇感觉挺低,马上要报到,挺纠结的。

当HR压你价,说你只值7K,你该怎么回答?

当HR压你价,说你只值7K时,你可以流畅地回答,记住,是流畅,不能犹豫。 礼貌地说:“7K是吗?了解了。嗯~其实我对贵司的面试官印象很好。只不过,现在我的手头上已经有一份11K的offer。来面试,主要也是自己对贵司挺有兴趣的,所以过来看看……”(未完) 这段话主要是陪HR互诈的同时,从公司兴趣,公司职员印象上,都给予对方正面的肯定,既能提升HR的好感度,又能让谈判气氛融洽,为后面的发挥留足空间。...

面试:第十六章:Java中级开发(16k)

HashMap底层实现原理,红黑树,B+树,B树的结构原理 Spring的AOP和IOC是什么?它们常见的使用场景有哪些?Spring事务,事务的属性,传播行为,数据库隔离级别 Spring和SpringMVC,MyBatis以及SpringBoot的注解分别有哪些?SpringMVC的工作原理,SpringBoot框架的优点,MyBatis框架的优点 SpringCould组件有哪些,他们...

面试阿里p7,被按在地上摩擦,鬼知道我经历了什么?

面试阿里p7被问到的问题(当时我只知道第一个):@Conditional是做什么的?@Conditional多个条件是什么逻辑关系?条件判断在什么时候执...

立即提问
相关内容推荐