包含javareflectutils的词条

今天,嗨壳技术分享网给大家整理一些包含javareflectutils的词条内容。

  今天给各位分享javareflectutils的知识,其中也会对进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!

  本文目录一览:

  1、Java程序性能优化-代理模式(5)

2、实验: metaspace区域OOM

3、Bean找对象方法执行

4、后端自定义的异常 在dubbo 怎么抛到前端

  Java程序性能优化-代理模式(5)

  代理模式( )

  在以上代码中 使用CtField make()方法和CtNewMehod make()方法在运行时生成了代理类的字段和方法 这些逻辑由Javassist的CtClass对象处理 将Java代码转换为对应的字节码 并生成动态代理类的实例

  注意 与静态代理相比 动态代理可以很大幅度地减少代码行数 并提升系统的灵活性

  在Java中 动态代理类的生成主要涉及对ClassLoader的使用 这里以CGLIB为例 简要阐述动态类的加载过程 使用CGLIB生成动态代理 首先需要生成Enhancer类实例 并指定用于处理代理业务的回调类 在Enhancer create()方法中 会使用DefaultGeneratorStrategy Generate()方法生成动态代理类的字节码 并保存在byte数组中 接着使用ReflectUtils defineClass()方法 通过反射 调用ClassLoader defineClass()方法 将字节码装载到ClassLoader中 完成类的加载 最后使用ReflectUtils newInstance()方法 通过反射 生成动态类的实例 并返回该实例 无论使用何种方法生成动态代理 虽然实现细节不同 但主要逻辑都如图 所示

  图   实现动态代理的基本步骤

  前文介绍的几种动态代理的生成方法 性能有一定差异 为了能更好地测试它们的性能 去掉DBQuery类中的sleep()代码 并使用以下方法测试

  public static final int CIRCLE= ;

  public static void main(String[] args) throws Exception {

  IDBQuery d=null;

  long begin=System currentTimeMillis()

  d=createJdkProxy()                      //测试JDK动态代理

  System out println( createJdkProxy: +(System currentTimeMillis() beg    in))

  System out println( JdkProxy class: +d getClass() getName())

  begin=System currentTimeMillis()

  for(int i= ;iCIRCLE;i++)

  d request()

  System out println( callJdkProxy: +(System currentTimeMillis() begin    ))

  begin=System currentTimeMillis()

  d=createCglibProxy()                    //测试CGLIB动态代理

  System out println( createCglibProxy: +(System currentTimeMillis() b    egin))

  System out println( CglibProxy class: +d getClass() getName())

  begin=System currentTimeMillis()

  for(int i= ;iCIRCLE;i++)

  d request()

  System out println( callCglibProxy: +(System currentTimeMillis() beg    in))

  begin=System currentTimeMillis()

  d=createJavassistDynProxy()             //测试Javaassist动态代理

  System out println( createJavassistDynProxy: +(System currentTimeMil    lis() begin))

  System out println( JavassistDynProxy class: +d getClass() getName())

  begin=System currentTimeMillis()

  for(int i= ;iCIRCLE;i++)

  d request()

  System out println( callJavassistDynProxy: +(System currentTimeMilli    s() begin))

  begin=System currentTimeMillis()

  d=createJavassistBytecodeDynamicProxy()     //测试Javassist动态代理

  System out println( createJavassistBytecodeDynamicProxy: +(System cu    rrentTimeMillis() begin))

  System out println( JavassistBytecodeDynamicProxy class: +d getClass()

  getName())

  begin=System currentTimeMillis()

  for(int i= ;iCIRCLE;i++)

  d request()

  System out println( callJavassistBytecodeDynamicProxy: +(System curr    entTimeMillis() begin))

  }

  返回目录 Java程序性能优化 让你的Java程序更快 更稳定

  编辑推荐

  Java程序设计培训视频教程

  J EE高级框架实战培训视频教程

  J ME移动开发实战教学视频

  Visual C++音频/视频技术开发与实战

  Oracle索引技术

  lishixinzhi/Article/program/Java/gj/201311/27830

  实验: metaspace区域OOM

  Cglib 动态代理,会动态创建类 如果使用不当会导致生成大量的类元数据 塞满metaspace

  依赖包

  执行报错

  java.lang.OutOfMemoryError: Metaspace

  Dumping heap to …

  Heap dump file created [2923143 bytes in 0.037 secs]

  Exception in thread “main” net.sf.cglib.core.CodeGenerationException: java.lang.reflect.InvocationTargetException–null

  at net.sf.cglib.core.AbstractClassGenerator.generate(AbstractClassGenerator.java:348)

  at net.sf.cglib.proxy.Enhancer.generate(Enhancer.java:492)

  at net.sf.cglib.core.AbstractClassGenerator$ClassLoaderData.get(AbstractClassGenerator.java:117)

  at net.sf.cglib.core.AbstractClassGenerator.create(AbstractClassGenerator.java:294)

  at net.sf.cglib.proxy.Enhancer.createHelper(Enhancer.java:480)

  at net.sf.cglib.proxy.Enhancer.create(Enhancer.java:305)

  at MetaspaceOOM.main(MetaspaceOOM.java:42)

  Caused by: java.lang.reflect.InvocationTargetException

  at sun.reflect.GeneratedMethodAccessor1.invoke(Unknown Source)

  at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)

  at java.lang.reflect.Method.invoke(Method.java:498)

  at net.sf.cglib.core.ReflectUtils.defineClass(ReflectUtils.java:459)

  at net.sf.cglib.core.AbstractClassGenerator.generate(AbstractClassGenerator.java:339)

  … 6 more

  Caused by: java.lang.OutOfMemoryError: Metaspace

  at java.lang.ClassLoader.defineClass1(Native Method)

  at java.lang.ClassLoader.defineClass(ClassLoader.java:763)

  … 11 more

  4.669: [GC (Allocation Failure) 4.669: [ParNew: 34944K-2104K(39296K), 0.0033046 secs] 34944K-2104K(126720K), 0.0035844 secs] [Times: user=0.00 sys=0.00, real=0.00 secs]

  5.218: [GC (Allocation Failure) 5.218: [ParNew: 37048K-2256K(39296K), 0.0051226 secs] 37048K-2256K(126720K), 0.0053311 secs] [Times: user=0.00 sys=0.00, real=0.01 secs]

  5.633: [GC (Allocation Failure) 5.633: [ParNew: 37200K-2664K(39296K), 0.0101116 secs] 37200K-2664K(126720K), 0.0102989 secs] [Times: user=0.00 sys=0.00, real=0.01 secs]

  Gc日志还是比较清晰的打印出 Metadata 到达阈值引起的fullgc

  5.973: [ Full GC (Metadata GC Threshold) 5.973: [CMS: 0K-2302K(87424K), 0.0538876 secs] 28792K-2302K(126720K), [Metaspace: 9186K-9186K(1058816K)], 0.0543441 secs] [Times: user=0.08 sys=0.03, real=0.06 secs]

  6.027: [Full GC (Last ditch collection) 6.027: [CMS: 2302K-1410K(87424K), 0.0168118 secs] 2302K-1410K(126848K), [Metaspace: 9186K-9186K(1058816K)], 0.0169643 secs] [Times: user=0.03 sys=0.00, real=0.02 secs]

  6.046: [GC (CMS Initial Mark) [1 CMS-initial-mark: 1410K(87424K)] 1410K(126848K), 0.0003738 secs] [Times: user=0.00 sys=0.00, real=0.00 secs]

  6.046: [CMS-concurrent-mark-start]

  6.089: [CMS-concurrent-mark: 0.014/0.043 secs] [Times: user=0.06 sys=0.00, real=0.04 secs]

  6.089: [CMS-concurrent-preclean-start]

  6.091: [CMS-concurrent-preclean: 0.001/0.001 secs] [Times: user=0.00 sys=0.00, real=0.00 secs]

  6.091: [GC (CMS Final Remark) [YG occupancy: 687 K (39424 K)]6.091: [Rescan (parallel) , 0.0003632 secs]6.091: [weak refs processing, 0.0001684 secs]6.091: [class unloading, 0.0022085 secs]6.094: [scrub symbol table, 0.0013801 secs]6.095: [scrub string table, 0.0003217 secs][1 CMS-remark: 1410K(87424K)] 2097K(126848K), 0.0048304 secs] [Times: user=0.00 sys=0.00, real=0.01 secs]

  6.096: [CMS-concurrent-sweep-start]

  6.096: [CMS-concurrent-sweep: 0.001/0.001 secs] [Times: user=0.00 sys=0.00, real=0.00 secs]

  6.097: [CMS-concurrent-reset-start]

包含javareflectutils的词条

  6.099: [CMS-concurrent-reset: 0.002/0.002 secs] [Times: user=0.00 sys=0.00, real=0.00 secs]

  Heap

  par new generation total 39424K, used 1038K [0x0000000081200000, 0x0000000083cc0000, 0x0000000095ec0000)

  eden space 35072K, 2% used [0x0000000081200000, 0x0000000081303890, 0x0000000083440000)

  from space 4352K, 0% used [0x0000000083440000, 0x0000000083440000, 0x0000000083880000)

  to space 4352K, 0% used [0x0000000083880000, 0x0000000083880000, 0x0000000083cc0000)

  concurrent mark-sweep generation total 87424K, used 1410K [0x0000000095ec0000, 0x000000009b420000, 0x0000000100000000)

  Metaspace used 9214K, capacity 10134K, committed 10240K, reserved 1058816K

  class space used 790K, capacity 841K, committed 896K, reserved 1048576K

  通过mat分析oom时候自动dump的文件

  首先发现应用程序类加载器 AppClassLoader 加载了很多东西

  cglib 总共动态生成了 668个类

  list outgoing objects 进去看,这个名字怪怪的类 父类是 Car, 关联了一堆 cglib的代理对象 也就是说肯定是通过cglib加强 car 的时候有问题

  Bean找对象方法执行

  package cn.wisefly.miims.util;

  import org.springframework.beans.BeansException;

  import org.springframework.context.ApplicationContext;

  import org.springframework.context.ApplicationContextAware;

  import org.springframework.stereotype.Component;

  import org.springframework.util.ReflectionUtils;

  import java.lang.reflect.Method;

  @Component

  public class SpringReflectUtils implements ApplicationContextAware {

  /**

  * Spring容器 spring应用上下文对象

  */

  private static ApplicationContext applicationContext;

  @Override

  public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {

  SpringReflectUtils.applicationContext = applicationContext;

  System.out.println(“========ApplicationContext配置成功,在普通类可以通过调用SpringUtil.getAppContext()获取applicationContext对象,applicationContext=” + SpringReflectUtils.applicationContext + “========”);

  }

  /**

  * 对象名称获取spring bean对象

  * @param name

  * @return

  * @throws BeansException

  */

  public static Object getBean(String name) throws BeansException {

  return applicationContext.getBean(name);

  }

  /**

  * 根据 服务名称 ,方法名 反射调用  spring bean 中的 方法

  * @param serviceName 服务名

  * @param methodName 方法名

  * @param params 参数

  * @return

  * @throws Exception

  */

  public static Object springInvokeMethod(String serviceName, String methodName, Object[] params) throws Exception {

  Object service = getBean(serviceName);

  Class? extends Object[] paramClass = null;

  if (params != null) {

  int paramsLength = params.length;

  paramClass = new Class[paramsLength];

  for (int i = 0; i paramsLength; i++) {

  paramClass[i] = params[i].getClass();

  }

  }

  // 找到方法

  Method method = ReflectionUtils.findMethod(service.getClass(), methodName, paramClass);

  // 执行方法

  return ReflectionUtils.invokeMethod(method, service, params);

  }

  }

  后端自定义的异常 在dubbo 怎么抛到前端

  public Result invoke(Invoker? invoker, Invocation invocation) throws RpcException {

  try {

  Result result = invoker.invoke(invocation);

  if (result.hasException() GenericService.class != invoker.getInterface()) {

  try {

  Throwable exception = result.getException();

  // 如果是checked异常,直接抛出

  if (! (exception instanceof RuntimeException) (exception instanceof Exception)) {

  return result;

  }

  // 在方法签名上有声明,直接抛出

  try {

  Method method = invoker.getInterface().getMethod(invocation.getMethodName(), invocation.getParameterTypes());

  Class?[] exceptionClassses = method.getExceptionTypes();

  for (Class? exceptionClass : exceptionClassses) {

  if (exception.getClass().equals(exceptionClass)) {

  return result;

  }

  }

  } catch (NoSuchMethodException e) {

  return result;

  }

  // 未在方法签名上定义的异常,在服务器端打印ERROR日志

  logger.error(“Got unchecked and undeclared exception which called by ” + RpcContext.getContext().getRemoteHost()

  + “. service: ” + invoker.getInterface().getName() + “, method: ” + invocation.getMethodName()

  + “, exception: ” + exception.getClass().getName() + “: ” + exception.getMessage(), exception);

  // 异常类和接口类在同一jar包里,直接抛出

  String serviceFile = ReflectUtils.getCodeBase(invoker.getInterface());

  String exceptionFile = ReflectUtils.getCodeBase(exception.getClass());

  if (serviceFile == null || exceptionFile == null || serviceFile.equals(exceptionFile)){

  return result;

  }

  // 是JDK自带的异常,直接抛出

  String className = exception.getClass().getName();

  if (className.startsWith(“java.”) || className.startsWith(“javax.”)) {

  return result;

  }

  // 是Dubbo本身的异常,直接抛出

  if (exception instanceof RpcException) {

  return result;

  }

  // 否则,包装成RuntimeException抛给客户端

  return new RpcResult(new RuntimeException(StringUtils.toString(exception)));

  } catch (Throwable e) {

  logger.warn(“Fail to ExceptionFilter when called by ” + RpcContext.getContext().getRemoteHost()

  + “. service: ” + invoker.getInterface().getName() + “, method: ” + invocation.getMethodName()

  + “, exception: ” + e.getClass().getName() + “: ” + e.getMessage(), e);

  return result;

  }

  }

  return result;

  } catch (RuntimeException e) {

  logger.error(“Got unchecked and undeclared exception which called by ” + RpcContext.getContext().getRemoteHost()

  + “. service: ” + invoker.getInterface().getName() + “, method: ” + invocation.getMethodName()

  + “, exception: ” + e.getClass().getName() + “: ” + e.getMessage(), e);

  throw e;

  }

  }

  所以在dubbo的service端想抛出自定义异常,只能通过在service端的接口方法上声明所要抛出的异常,或者将异常类与接口同包,再或者是接口的实现类再实现dubbo的GenericService接口。

  对于第一种方案没有使用,因为它对代码的入侵比较严重。

  第二种方案可以实现,可对于目前的业务框架,让接口类和异常类同包则变得不太可能。

  所以最后选择了让接口实现类再实现GenericService接口,而对于其需要实现的$invoke方法则没有做任何的方法体处理,直接废弃。

  对于dubbo的service端自定义异常类的处理,有些不理解的就是,为什么dubbo需要对自定义异常类做一次Runtime异常的转化,而不是直接抛出原异常类型。或者有没有对dubbo更了解的朋友,有对自定义异常更好的处理方法。

  javareflectutils的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于、javareflectutils的信息别忘了在本站进行查找喔。

关于 包含javareflectutils的词条 的问题,嗨壳技术分享网(www.heikehao.com)小编就分享到这里吧!如果大家有疑问欢迎留言询问。

原创文章,作者:java,如若转载,请注明出处:https://www.heikehao.com/22754.html

(0)
javajava
上一篇 2022年6月23日
下一篇 2022年6月23日

相关推荐

  • 文章管理系统java源码

    今日,嗨壳技术分享网小编分享文章管理系统java源码 相关内容,内容如下。   求Java+Oracle文档管理系统源代码   载入数据库驱动,连接数据库,输入数据库root和密码…

    2020年3月11日
  • 滚动广告javascript(滚动广告箱)

    滚动广告javascript(滚动广告箱)   今天给各位分享滚动广告javascript的知识,其中也会对滚动广告箱进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在…

    2020年2月12日
  • 怎么清理java注册表,java注册表在哪

    关于怎么清理java注册表,java注册表在哪话题,今日,嗨壳技术分享网小编抽出大半天的时间整理一些怎么清理java注册表,java注册表在哪内容,让我们一起了解一些技术吧!   …

    2020年3月31日
  • 文件太大java下载,文件大小java

    关于文件太大java下载,文件大小java话题,今日,嗨壳技术分享网小编抽出大半天的时间整理一些文件太大java下载,文件大小java内容,让我们一起了解一些技术吧!   java…

    2020年2月9日
  • java百分比进度条

    java百分比进度条   java中如何编写一个进度条代码,需要显示百分比   使用 JProgressBar 对象可以实现进度条。   这个你完全可以参考jQuery UI里面的…

    2020年9月15日
  • 微信支付javasdk,微信支付扣款顺序怎么设置

    今日,嗨壳技术分享网小编分享微信支付javasdk,微信支付扣款顺序怎么设置 相关内容,内容如下。   api的目的是   1、API之主要目的是提供应用程序与开发人员以访问一组例…

    2020年1月5日
  • 关于java斗破苍穹3的信息

    关于java斗破苍穹3的信息   安利你最喜欢的三个app?   安利给大家,希望能够对正在读文章的你起到一点小小的帮助,(),嘻嘻。①网易蜗牛读书 我非常喜欢的一款读书app, …

    2021年3月29日
  • java快速写入文件(java读取文件)

    java快速写入文件(java读取文件)   本篇文章给大家谈谈java快速写入文件,以及java读取文件对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。   本文目录一览:…

    2020年1月8日
  • 关于theimportjava.sql的信息

    今日,嗨壳技术分享网小编分享关于theimportjava.sql的信息 相关内容,内容如下。   提问者评价谢谢   (1) 用肯定的形式表示否定。例如:毛主席都是如此,我们还有…

    2020年6月14日
  • java字符串指定长度换行,java字符串自动换行

    关于java字符串指定长度换行,java字符串自动换行话题,今日,嗨壳技术分享网小编抽出大半天的时间整理一些java字符串指定长度换行,java字符串自动换行内容,让我们一起了解一…

    2020年7月22日

网上怎么找黑客帮忙多少钱

怎么网上找到的黑客?黑客的收费标准是什么呢?找黑客一般费用是多少?


找黑客帮忙一般要多少钱

黑客服务的价格范围很广,主要取决于服务的类型和难度。根据提供的信息如下:


1.攻击服务:


攻击范围:这包括了通过扫描入侵、种植木马等方式对他人计算机实施非法控制,并利用被控制的计算机对网站、App等服务器发起攻击


。1

2.特定账户的售价:


账户信息:如垂钓者、而勒索软件,显示市场对特定黑客工具的需求和价格波动。

3.攻击工具:

“RIG”攻击工具包的租用费用,提供了不同时长的选择。

4.远程访问木马(RAT)的价格:

相比去年有所下降,显示出市场价格的波动。

5.DDOS攻击的报价:

DDOS攻击服务按不同时长定价选择。

黑客服务的价格因服务类型、难度、以及市场需求的不同而有很大的差异。这些价格反映了黑客服务市场的复杂性和多样性,同时也提醒人们网络安全的重要性。