什么是反射

官方的解释 https://docs.oracle.com/javase/8/docs/api/
    Package java.lang.reflect Description Provides classes and interfaces for obtaining reflective information about classes and objects. Reflection allows programmatic access to information about the fields, methods and constructors of loaded classes, and the use of reflected fields, methods, and constructors to operate on their underlying counterparts, within security restrictions.
    AccessibleObject allows suppression of access checks if the necessary ReflectPermission is available.
    Array provides static methods to dynamically create and access arrays.
    Classes in this package, along with java.lang.Class accommodate applications such as debuggers,interpreters, object inspectors, class browsers, and services such as Object Serialization and JavaBeans that need access to either the public members of a target object (based on its runtime class) or the members declared by a given class.

这段话的大概意思就是:软件包java.lang.reflect提供用于获取有关类和对象的反射信息的类和接口。 通过反射,可以在安全性限制内以编程方式访问有关已加载类的字段,方法和构造函数的信息,并可以使用反射的字段,方法和构造函数对其基础副本进行操作。
如果必要的ReflectPermission可用,AccessibleObject允许禁止访问检查。
数组提供静态方法来动态创建和访问数组
此包中的类以及java.lang.Class需要访问目标对象的公共成员(基于其对象)的应用程序,例如调试器,解释器,对象检查器,类浏览器以及服务,例如对象序列化和JavaBeans。 运行时类)或给定类声明的成员。

通过官方给出的定义,我们可以看到他的介绍,那么我们思考既然已经有new来创建对象了,反射的意义是什么呢?对什么反射?

在Java中创建对象,获取属性,调用对象的方法通常都是通过 Object o = new Object(), 然后通过 o.getXXX(), o.setXXX() o.doSomething()来实现。这个可以满足大多数的业务场景需求,那么在下面的几个场景下是否也同样满足呢?
一、公司要你实现一个底层组件,此组件要根据上层的业务能在运行时动态的实例化对象,从而实现一些功能,如何实现?
二、在这个组件中,要动态的获取它的属性,并更新属性的值和状态又该如何实现?
三、同样在这个组件中,某个业务要根据不同业务参数动态的调用实例化对象的不同方法,又该如何实现?

要解决以上的问题,普通的对象实例化方式是无法实现的,于是JVM提供了一种动态实例化对象,并且可以获取到实例对象的属性,方法,并对其进行一些操作。

通过以上示例的对比,可以发现反射的方式创建实例的方式比普通方式更加灵活,也就是扩展性好。

从 JVM 层面理解反射原理

JVM 通过 Class 的类名找到 Class 的字节码文件,然后再通过 ClassLoader 的类加载机制在堆内存中分配对象(暂不考虑对象在栈,TLAB 上分配的情况) 。

反射的例子

    @sun.reflect.CallerSensitivepublic static native java.lang.Class<?> getCallerClass();@CallerSensitivepublic static Class<?> forName(String className)throws ClassNotFoundException {// 调用 native 方法获取调用者的 ClassClass<?> caller = Reflection.getCallerClass();// 调用 native 方法根据 className 查找字节码对象,并进行加载、解析return forName0(className, true, ClassLoader.getClassLoader(caller), caller);}/*** Called after security check for system loader access checks have been made.*/private static native Class<?> forName0(String name, boolean initialize,ClassLoader loader,Class<?> caller)throws ClassNotFoundException;@CallerSensitivepublic T newInstance()throws InstantiationException, IllegalAccessException {// 通过反射进行实例化的时候,如果有配置 SecurityManager 则要先进行安全校验,普通方式实例化则不需要if (System.getSecurityManager() != null) {checkMemberAccess(Member.PUBLIC, Reflection.getCallerClass(), false);}// NOTE: the following code may not be strictly correct under// the current Java memory model.// Constructor lookupif (cachedConstructor == null) {if (this == Class.class) {throw new IllegalAccessException("Can not call newInstance() on the Class for java.lang.Class");}try {Class<?>[] empty = {};final Constructor<T> c = getConstructor0(empty, Member.DECLARED);// Disable accessibility checks on the constructor// since we have to do the security check here anyway// (the stack depth is wrong for the Constructor's// security check to work)// 安全校验第一次java.security.AccessController.doPrivileged(new java.security.PrivilegedAction<Void>() {public Void run() {c.setAccessible(true);return null;}});// 将构造器进行缓存,提高下次通过反射创建对象时的性能cachedConstructor = c;} catch (NoSuchMethodException e) {throw (InstantiationException)new InstantiationException(getName()).initCause(e);}}Constructor<T> tmpConstructor = cachedConstructor;// Security check (same as in java.lang.reflect.Constructor)// 安全校验第二次,这个 modifier 在 JDK 里是以一个 int 值来表示,int modifiers = tmpConstructor.getModifiers();if (!Reflection.quickCheckMemberAccess(this, modifiers)) {Class<?> caller = Reflection.getCallerClass();if (newInstanceCallerCache != caller) {Reflection.ensureMemberAccess(caller, this, null, modifiers);newInstanceCallerCache = caller;}}// Run constructortry {// 通过构造器来实例化对象return tmpConstructor.newInstance((Object[]) null);} catch (InvocationTargetException e) {Unsafe.getUnsafe().throwException(e.getTargetException());// Not reachedreturn null;}}

反射的优缺点

优点:
1、增加程序的灵活性,避免将固有逻辑写死
2、代码简洁,可读性强,可提高代码的复用率
缺点:
1、相比较于直接调用,在访问量较大的情况下,反射会导致系统性能明显下降
2、打破了类的封装性,存在一定的安全隐患
3、反射性能慢。原因:同构 (1)反射调用会进行一系列的安全性校验(2)反射需要调用一系列的 native 方法来实现(3)寻找 Class 字节码的过程,比如通过 ClassName 找到对应的字节码 Class,然后进行加载、解析,这也会比较慢,而 new 的方式则无需寻找,因为在连接的解析阶段已经将符号引用转为了直接引用(4)入参校验

 

反射在类加载中的应用

类加载过程

类装载的三部曲,加载、连接、初始化(简要介绍,详情请看博主另一篇类加载机制的博文)
加载
加载.class文件,主要有以下几个途径:
从本地的文件系统中加载
通过网络下载
从 zip.jar 包加载.class 文件
从存储中间件中加载(数据库、缓存…)
在 JVM 运行期间通过动态字节码重组的方式(ASM)

连接
连接就是将已经读入到内存的类的二进制数据合并到 JVM 的运行时环境中,连接过程主要有三个阶段
类的验证,对类的文件进行检查(版本号、模数。。)以保证.class 符合 JVM 规范
类的准备,分配常量池空间,解析常量池,静态变量的分配,但不会初始化,只会给默认值
类的解析,解析父类,解析接口,解析 Filed,解析方法列表(包含栈、字节码表、异常表、局部变量表、运行指针),把类二进制的符号引用转变为直接引用

初始化
JVM 执行类的初始话语句,为类的静态变量赋值
如果这个类还没有被加载和连接,那就先进行加载和连接
如果这个类存在父类,并且父类还没有初始话,那就先初始化父类
如果类中存在初始化语句(Static 块),依次执行初始化语句

类完成初始化的时机

1、创建类的实例 new xxxClass() || Class.newInstance() || constructor.newInstance()访问某种的某个静态变量,或者对静态变量进行赋值
2、调用类的静态方法
3、Class.forName("包类名"),因为 forName 里有一个 init 参数是 true
4、完成子类的初始化,也会完成对本类的初始化(接口除外)
5、该类是程序引导入口(main 入口 或者 test 入口)

Class 对象的获取方式

Class clazz = xxxClass.class;     // 没有完成初始化过程
Class class = instanceObj.getClass;    // 对象已生成,完成初始化过程
Class clazz = xxxClassLoader.load("包类名");    // 未完成初始化过程
Class clazz = Class.forName("包类名");    // 完成初始化过程

为什么 JDBC 用 Class.forName 的方式加载驱动而不是 ClassLoader.loadClass()?
因为 Driver 的注册是通过 static 的静态块注册,所以得通过 Class.forName 的方式完成类的初始化,才能完成驱动的注册

 

反射在Spring设计中的应用

在 spring 中的 IOC 实例创建 

    protected BeanWrapper createBeanInstance(String beanName, RootBeanDefinition mbd,@Nullable Object[] args) {// Make sure bean class is actually resolved at this point.Class<?> beanClass = resolveBeanClass(mbd, beanName);if (beanClass != null && !Modifier.isPublic(beanClass.getModifiers())&& !mbd.isNonPublicAccessAllowed()) {throw new BeanCreationException(mbd.getResourceDescription(), beanName,"Bean class isn't public, and non-public access not allowed: " +beanClass.getName());}Supplier<?> instanceSupplier = mbd.getInstanceSupplier();if (instanceSupplier != null) {return obtainFromSupplier(instanceSupplier, beanName);}if (mbd.getFactoryMethodName() != null) {return instantiateUsingFactoryMethod(beanName, mbd, args);}// Shortcut when re-creating the same bean...boolean resolved = false;boolean autowireNecessary = false;if (args == null) {synchronized (mbd.constructorArgumentLock) {if (mbd.resolvedConstructorOrFactoryMethod != null) {resolved = true;autowireNecessary = mbd.constructorArgumentsResolved;}}}if (resolved) {if (autowireNecessary) {return autowireConstructor(beanName, mbd, null, null);} else {return instantiateBean(beanName, mbd);}}// Candidate constructors for autowiring?Constructor<?>[] ctors = determineConstructorsFromBeanPostProcessors(beanClass,beanName);if (ctors != null || mbd.getResolvedAutowireMode() == AUTOWIRE_CONSTRUCTOR ||mbd.hasConstructorArgumentValues() || !ObjectUtils.isEmpty(args)) {return autowireConstructor(beanName, mbd, ctors, args);}// Preferred constructors for default construction?ctors = mbd.getPreferredConstructors();if (ctors != null) {return autowireConstructor(beanName, mbd, ctors, null);}// No special handling: simply use no-arg constructor.// 实例化 Bean 的方法return instantiateBean(beanName, mbd);}/*** Instantiate the given bean using its default constructor.** @param beanName the name of the bean* @param mbd      the bean definition for the bean* @return a BeanWrapper for the new instance*/protected BeanWrapper instantiateBean(final String beanName, final RootBeanDefinitionmbd) {try {Object beanInstance;final BeanFactory parent = this;if (System.getSecurityManager() != null) {beanInstance = AccessController.doPrivileged((PrivilegedAction<Object>) ()->getInstantiationStrategy().instantiate(mbd, beanName, parent),getAccessControlContext());} else {beanInstance = getInstantiationStrategy().instantiate(mbd, beanName,parent);}BeanWrapper bw = new BeanWrapperImpl(beanInstance);initBeanWrapper(bw);return bw;} catch (Throwable ex) {throw new BeanCreationException(mbd.getResourceDescription(), beanName, "Instantiation of bean failed",ex);}}public T newInstance(Object... initargs)throws InstantiationException, IllegalAccessException,IllegalArgumentException, InvocationTargetException {if (!override) {if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) {Class<?> caller = Reflection.getCallerClass();checkAccess(caller, clazz, null, modifiers);}}if ((clazz.getModifiers() & Modifier.ENUM) != 0)throw new IllegalArgumentException("Cannot reflectively create enum objects");ConstructorAccessor ca = constructorAccessor; // read volatileif (ca == null) {ca = acquireConstructorAccessor();}@SuppressWarnings("unchecked")T inst = (T) ca.newInstance(initargs);return inst;}public static <T> T instantiateClass(Constructor<T> ctor, Object... args) throwsBeanInstantiationException {Assert.notNull(ctor, "Constructor must not be null");try {ReflectionUtils.makeAccessible(ctor);return (KotlinDetector.isKotlinReflectPresent() &&KotlinDetector.isKotlinType(ctor.getDeclaringClass()) ?KotlinDelegate.instantiateClass(ctor, args) : ctor.newInstance(args));} catch (InstantiationException ex) {throw new BeanInstantiationException(ctor, "Is it an abstract class?", ex);} catch (IllegalAccessException ex) {throw new BeanInstantiationException(ctor, "Is the constructor accessible?",ex);} catch (IllegalArgumentException ex) {throw new BeanInstantiationException(ctor, "Illegal arguments for constructor",ex);} catch (InvocationTargetException ex) {throw new BeanInstantiationException(ctor, "Constructor threw exception",ex.getTargetException());}}

解析 Bean 的 class,spring 里使用的是通过 classLoader 的方式

    @Nullableprivate Class<?> doResolveBeanClass(RootBeanDefinition mbd, Class<?>... typesToMatch)throws ClassNotFoundException {ClassLoader beanClassLoader = getBeanClassLoader();ClassLoader dynamicLoader = beanClassLoader;boolean freshResolve = false;if (!ObjectUtils.isEmpty(typesToMatch)) {// When just doing type checks (i.e. not creating an actual instance yet),// use the specified temporary class loader (e.g. in a weaving scenario).ClassLoader tempClassLoader = getTempClassLoader();if (tempClassLoader != null) {dynamicLoader = tempClassLoader;freshResolve = true;if (tempClassLoader instanceof DecoratingClassLoader) {DecoratingClassLoader dcl = (DecoratingClassLoader) tempClassLoader;for (Class<?> typeToMatch : typesToMatch) {dcl.excludeClass(typeToMatch.getName());}}}}String className = mbd.getBeanClassName();if (className != null) {Object evaluated = evaluateBeanDefinitionString(className, mbd);if (!className.equals(evaluated)) {// A dynamically resolved expression, supported as of 4.2...if (evaluated instanceof Class) {return (Class<?>) evaluated;} else if (evaluated instanceof String) {className = (String) evaluated;freshResolve = true;} else {throw new IllegalStateException("Invalid class name expression result:" + evaluated);}}if (freshResolve) {// When resolving against a temporary class loader, exit early in order// to avoid storing the resolved Class in the bean definition.if (dynamicLoader != null) {try {return dynamicLoader.loadClass(className);} catch (ClassNotFoundException ex) {if (logger.isTraceEnabled()) {logger.trace("Could not load class [" + className + "] from " +dynamicLoader + ": " + ex);}}}return ClassUtils.forName(className, dynamicLoader);}}// Resolve regularly, caching the result in the BeanDefinition...return mbd.resolveBeanClass(beanClassLoader);}

设置实例属性

    protected void populateBean(String beanName, RootBeanDefinition mbd, @Nullable BeanWrapperbw) {if (bw == null) {if (mbd.hasPropertyValues()) {throw new BeanCreationException(mbd.getResourceDescription(), beanName, "Cannot apply property values tonull instance ");} else {// Skip property population phase for null instance.return;}}// Give any InstantiationAwareBeanPostProcessors the opportunity to modify the// state of the bean before properties are set. This can be used, for example,// to support styles of field injection.boolean continueWithPropertyPopulation = true;if (!mbd.isSynthetic() && hasInstantiationAwareBeanPostProcessors()) {for (BeanPostProcessor bp : getBeanPostProcessors()) {if (bp instanceof InstantiationAwareBeanPostProcessor) {InstantiationAwareBeanPostProcessor ibp =(InstantiationAwareBeanPostProcessor) bp;if (!ibp.postProcessAfterInstantiation(bw.getWrappedInstance(),beanName)) {continueWithPropertyPopulation = false;break;}}}}if (!continueWithPropertyPopulation) {return;}PropertyValues pvs = (mbd.hasPropertyValues() ? mbd.getPropertyValues() : null);if (mbd.getResolvedAutowireMode() == AUTOWIRE_BY_NAME || mbd.getResolvedAutowireMode()== AUTOWIRE_BY_TYPE) {MutablePropertyValues newPvs = new MutablePropertyValues(pvs);// Add property values based on autowire by name if applicable.if (mbd.getResolvedAutowireMode() == AUTOWIRE_BY_NAME) {// 根据名称注入autowireByName(beanName, mbd, bw, newPvs);}// Add property values based on autowire by type if applicable.if (mbd.getResolvedAutowireMode() == AUTOWIRE_BY_TYPE) {// 根据类型注入autowireByType(beanName, mbd, bw, newPvs);}pvs = newPvs;}boolean hasInstAwareBpps = hasInstantiationAwareBeanPostProcessors();boolean needsDepCheck = (mbd.getDependencyCheck() !=AbstractBeanDefinition.DEPENDENCY_CHECK_NONE);PropertyDescriptor[] filteredPds = null;if (hasInstAwareBpps) {if (pvs == null) {pvs = mbd.getPropertyValues();}for (BeanPostProcessor bp : getBeanPostProcessors()) {if (bp instanceof InstantiationAwareBeanPostProcessor) {InstantiationAwareBeanPostProcessor ibp =(InstantiationAwareBeanPostProcessor) bp;// 通过@Resource @Autowre 的 BeanPostProcessorPropertyValues pvsToUse = ibp.postProcessProperties(pvs,bw.getWrappedInstance(), beanName);if (pvsToUse == null) {if (filteredPds == null) {filteredPds = filterPropertyDescriptorsForDependencyCheck(bw,mbd.allowCaching);}pvsToUse = ibp.postProcessPropertyValues(pvs, filteredPds,bw.getWrappedInstance(), beanName);if (pvsToUse == null) {return;}}pvs = pvsToUse;}}}if (needsDepCheck) {if (filteredPds == null) {filteredPds = filterPropertyDescriptorsForDependencyCheck(bw,mbd.allowCaching);}checkDependencies(beanName, mbd, filteredPds, pvs);}if (pvs != null) {applyPropertyValues(beanName, mbd, bw, pvs);}}/*** Either this or {@link #getResourceToInject} needs to be overridden.*/// 通过反射注入属性protected void inject(Object target, @Nullable String requestingBeanName, @NullablePropertyValues pvs)throws Throwable {if (this.isField) {Field field = (Field) this.member;ReflectionUtils.makeAccessible(field);field.set(target, getResourceToInject(target, requestingBeanName));} else {if (checkPropertySkipping(pvs)) {return;}try {Method method = (Method) this.member;ReflectionUtils.makeAccessible(method);method.invoke(target, getResourceToInject(target, requestingBeanName));} catch (InvocationTargetException ex) {throw ex.getTargetException();}}}

反射Spring场景总结

动态创建对象实例
动态操作(设置)实例对象的方法、属性
Spring IOC
Spring DI
Testing Framework

那么什么是反射呢,怎么回答呢?

官网回答 + 反射的属性(优缺点、性能分析) + JVM中反射的应用 + Spring中反射的应用

查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. MySQL中使用In()函数中使用foreach 循环

    <select id"selectMarkIds">select name from t_userwhere user_mark in<foreach item "code" collection"userIDs" separator"," open"(" close")">#{code}</foreach></select>...

    2024/5/9 20:40:08
  2. 进程上下文频繁切换导致load average过高

    进程上下文频繁切换导致load average过高 现象 最近发现有台虚拟机主机95%的cpu处于idle状态&#xff0c;内存使用率也不是特别高&#xff0c;而主机的load average很高 问题分析 先在主机上通过top、free、ps、iostat 等常用工具分析了下主机的CPU、内存、IO使用情况&#…...

    2024/5/9 15:21:45
  3. CodeForces1399D. Binary String To Subsequences(栈+思维)

    题意&#xff1a;给定一个01序列&#xff0c;然后一个合法的子序列的定义是&#xff0c;这个子序列的01要交替出现&#xff0c;即不能出现连续的1或者0&#xff0c;然后原序列的每一个位置最多只能属于一个合法的子序列中&#xff0c;求出最后合法的子序列个数&#xff0c;以及…...

    2024/5/9 20:52:25
  4. Tensorflow环境搭建流程

    Ten...

    2024/5/9 15:55:20
  5. (2020-09-25)一起学习css3

    归纳&#xff1a; CSS 的概述 CSS 指层叠样式表 (Cascading Style Sheets) 样式定义如何显示 HTML 元素样式通常存储在样式表中把样式添加到 HTML 4.0 中&#xff0c;是为了解决内容与表现分离的问题外部样式表可以极大提高工作效率 外部样式表通常存储在 CSS 文件中多个样式…...

    2024/5/9 18:49:01
  6. 《C++个人学习笔记》从堆栈中实例化对象以及访问对象成员

    栈相当于装衣服的箱子&#xff0c;先放入的在最底下&#xff0c;后放入的在最上方&#xff0c;所以当取出数据时&#xff0c;采用的是先进后出的顺序&#xff0c;每次取出数据需要从最后一个放入的数据开始。 堆相当于一个书架&#xff0c;也是采用一定的顺序存放数据&#xf…...

    2024/5/9 13:46:32
  7. 透过技术社区看未来趋势

    技术人员是行业创新的原动力&#xff0c;他们是最早掌握技术动态的那群人。为什么AI变得这么热门&#xff1f;大家看Gartner报告就会发现&#xff0c;很多热门技术最终都是昙花一现。什么技术才是真正的革命&#xff1f;其实我们可以透过开发者社区的动态来进行预测&#xff0c…...

    2024/4/18 10:42:08
  8. 假如面试官问你java内部类是如何处理外部引用的,你该怎么回答?

    在java内部类里&#xff0c;我们是能直接访问外部类的变量的。如下面例子所述&#xff1a; public class OutterClass {private String outterStr;class InnerClass{public void innerMethod(){System.out.printf(outterStr);}} }外部类OutterClass 的属性能够被InnerClass直接…...

    2024/5/5 5:59:05
  9. 贝叶斯推断-要点整理

    贝叶斯推断1 贝叶斯推断的介绍及公式2 先验概率分布的选择2.1共轭先验2.2无信息先验分布3 共轭先验公式推导&#xff08;待补充&#xff09;在上一篇文章中&#xff0c;我们提到了最大似然估计法 来在已知样本的情况下求分布的参数。这一次整理一下贝叶斯推断。 1 贝叶斯推断的…...

    2024/4/26 13:45:15
  10. Conan建筑基本思路

    建筑规划: 在观察柯南的建筑方式的时候&#xff0c;很容易能归纳出几个通用的规则&#xff1a; 1、占用&#xff1b;占用就是空间的占用&#xff0c;就像墙占用了某个竖直的面&#xff0c;护栏就不能再建造到这个竖直面&#xff0c;他两在配表里是有互斥关系的。再比如柱子就是…...

    2024/4/26 1:36:41
  11. 学习制作交叉编译工具链参考(crosstool-ng)

    交叉编译详解:https://www.crifan.com/files/doc/docbook/cross_compile/release/html/cross_compile.html#purpose crosstool-ng详解&#xff1a;https://www.crifan.com/files/doc/docbook/crosstool_ng/release/html/crosstool_ng.html crosstool-ng的基本使用流程&#x…...

    2024/4/18 13:54:18
  12. 黑马探花交友----4.动态评论-FastDFS视频上传

    学习目标&#xff1a; 圈子实现点赞、喜欢功能圈子实现评论圈子实现评论的点赞视频功能说明FastDFS环境搭建视频的功能实现1、动态评论 点赞、喜欢、评论等均可理解为用户对动态的评论。 点赞、取消点赞、喜欢、发布动态、删除动态等接口实现.... 完成效果如下&#xff0c;代…...

    2024/4/20 6:20:47
  13. Scala——if,while,for循环语句

    if循环语句 if条件是否为真&#xff0c;如果为真&#xff0c;就执行对应的语句块&#xff0c;如果为假&#xff0c;就执行下一个条件分支。 scala> val x 6 x: Int 6scala> if (x>0) {println("This is a positive number")| } else {| println(&qu…...

    2024/5/2 15:47:44
  14. C时代有几十万开发者?

    PC时代有几十万开发者&#xff0c;到互联网时代这个数字上升到了几百万。移动互联网时代&#xff0c;现在CSDN的注册会员是2600万&#xff0c;GitHub是3100万量&#xff0c;未来随着区块链、物联网、AI等技术的进一步发展&#xff0c;所有公司都会变成互联网公司&#xff0c;如…...

    2024/4/7 14:32:43
  15. 是否完全二叉搜索树 (30分)

    将一系列给定数字顺序插入一个初始为空的二叉搜索树&#xff08;定义为左子树键值大&#xff0c;右子树键值小&#xff09;&#xff0c;你需要判断最后的树是否一棵完全二叉树&#xff0c;并且给出其层序遍历的结果。 输入格式&#xff1a; 输入第一行给出一个不超过20的正整数…...

    2024/4/18 10:45:45
  16. Elsevier 投稿

    Elsevier 投稿心得分享做了什么收获了什么做了什么 发论文也是第一次发&#xff0c;完全没有什么经验。不过还好老师非常的耐心&#xff0c;在这个过程中给了很多帮助。 第一次开始筹备论文的写作是在六月份&#xff0c;那个时候老师通知我问我想不想写review&#xff0c;我说…...

    2024/4/19 9:14:41
  17. Nginx 基础入门篇 .6

    文章目录Nginx 访问限制ngx_http_limit_req_modulengx_http_limit_conn_moduleNginx 访问控制基于主机(ip) &#xff08;ngx_http_access_module&#xff09;基于用户(ngx_http_auth_basic_module)Nginx 访问限制 ngx_http_limit_req_module 网站请求 测试未限制情况下的访问…...

    2024/4/28 12:23:42
  18. 用Java实现代码字符画效果

    算法及思路 众所周知&#xff0c;我们的计算机在处理图形的时候&#xff0c;实际上是将图形分成N个像素点&#xff0c;对于每个像素点来说&#xff0c;有这个像素点自己的像素值。无数个带有自己特定的像素值的像素点才汇成了我们所见的图片。而在Java中&#xff0c;RGB值以及像…...

    2024/5/3 15:06:26
  19. 数据库中的三级范式(1NF、2NF、3NF)

    一级范式&#xff08;1NF&#xff09; 保证列的原子性什么是列的原子性呢&#xff1f;就是每一列的数据&#xff08;字段值&#xff09;是不可再分的比如说一个列名为address&#xff0c;value为“中国山东”&#xff0c;那么这就不满足1NF&#xff0c;因为“中国山东”可以再…...

    2024/4/17 10:52:54
  20. Callable and Future in Java(java中的Callable和Future)

    需要Callable的理由 通常&#xff0c;我们有两种方式创建线程&#xff0c;一种方式是继承Thread类&#xff0c;另外一种方式是实现Runnable接口。然而&#xff0c;Runnable方式缺少的一个特性就是&#xff0c;当线程终止的时候&#xff0c;即run运行完成的时候&#xff0c;我们…...

    2024/4/28 0:08:31

最新文章

  1. 产品评测:SmartX 与 Nutanix 超融合在数据库场景下的性能表现

    重点内容 SmartX 与 Nutanix 超融合分布式存储设计差异如何影响数据库性能表现。重点测试结论&#xff1a;数据库场景下&#xff0c;SmartX 超融合基于单卷部署的性能&#xff0c;依旧优于 Nutanix 超融合基于多卷部署最佳配置的性能。更多 SmartX、VMware、Nutanix 超融合技术…...

    2024/5/9 22:43:05
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/5/9 21:23:04
  3. 518. 零钱兑换 II(力扣LeetCode)

    文章目录 518. 零钱兑换 II题目描述动态规划一维数组为什么不能交换两个for循环的顺序&#xff1f; 二维数组 518. 零钱兑换 II 题目描述 给你一个整数数组 coins 表示不同面额的硬币&#xff0c;另给一个整数 amount 表示总金额。 请你计算并返回可以凑成总金额的硬币组合数…...

    2024/5/4 9:01:49
  4. C# 构建可定时关闭的异步提示弹窗

    C# 构建可定时关闭的异步提示弹窗 引言1、调用接口的实现2、自动定时窗口的实现 引言 我们在最常用最简单的提示弹框莫过于MessageBox.Show( )的方法了&#xff0c;但是使用久了之后&#xff0c;你会发现这个MessageBox并不是万能的&#xff0c;有事后并不想客户去点击&#x…...

    2024/5/2 6:14:07
  5. JVM学习笔记

    文章目录 一、内存模型1. 程序计数器2. 栈3. 本地方法栈4. 堆5. 方法区方法区位置字符串常量池位置 6. 直接内存 二、虚拟机参数设置三、类的生命周期1. 加载2. 连接1&#xff09;验证2&#xff09;准备3&#xff09;解析 3. 初始化4. 卸载 四、类加载器1. 启动类加载器2. 扩展…...

    2024/5/7 6:47:46
  6. 416. 分割等和子集问题(动态规划)

    题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义&#xff1a;dp[i][j]表示当背包容量为j&#xff0c;用前i个物品是否正好可以将背包填满&#xff…...

    2024/5/8 19:32:33
  7. 【Java】ExcelWriter自适应宽度工具类(支持中文)

    工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...

    2024/5/9 7:40:42
  8. Spring cloud负载均衡@LoadBalanced LoadBalancerClient

    LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon&#xff0c;直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件&#xff0c;我们讨论Spring负载均衡以Spring Cloud2020之后版本为主&#xff0c;学习Spring Cloud LoadBalance&#xff0c;暂不讨论Ribbon…...

    2024/5/9 2:44:26
  9. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

    一、背景需求分析 在工业产业园、化工园或生产制造园区中&#xff0c;周界防范意义重大&#xff0c;对园区的安全起到重要的作用。常规的安防方式是采用人员巡查&#xff0c;人力投入成本大而且效率低。周界一旦被破坏或入侵&#xff0c;会影响园区人员和资产安全&#xff0c;…...

    2024/5/8 20:33:13
  10. VB.net WebBrowser网页元素抓取分析方法

    在用WebBrowser编程实现网页操作自动化时&#xff0c;常要分析网页Html&#xff0c;例如网页在加载数据时&#xff0c;常会显示“系统处理中&#xff0c;请稍候..”&#xff0c;我们需要在数据加载完成后才能继续下一步操作&#xff0c;如何抓取这个信息的网页html元素变化&…...

    2024/5/9 3:15:57
  11. 【Objective-C】Objective-C汇总

    方法定义 参考&#xff1a;https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...

    2024/5/9 5:40:03
  12. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

    &#x1f468;‍&#x1f4bb;博客主页&#xff1a;花无缺 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】&#x1f30f;题目描述&#x1f30f;输入格…...

    2024/5/9 7:40:40
  13. 【ES6.0】- 扩展运算符(...)

    【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数&#xff0…...

    2024/5/8 20:58:56
  14. 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?

    文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕&#xff0c;各大品牌纷纷晒出优异的成绩单&#xff0c;摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称&#xff0c;在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁&#xff0c;多个平台数据都表现出极度异常…...

    2024/5/9 1:35:21
  15. Go语言常用命令详解(二)

    文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令&#xff0c;这些命令可以帮助您在Go开发中进行编译、测试、运行和…...

    2024/5/9 4:12:16
  16. 用欧拉路径判断图同构推出reverse合法性:1116T4

    http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b&#xff0c;我们在 a i a_i ai​ 和 a i 1 a_{i1} ai1​ 之间连边&#xff0c; b b b 同理&#xff0c;则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然&#xff0…...

    2024/5/9 7:40:35
  17. 【NGINX--1】基础知识

    1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息&#xff0c;并安装一些有助于配置官方 NGINX 软件包仓库的软件包&#xff1a; apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...

    2024/5/9 19:47:07
  18. Hive默认分割符、存储格式与数据压缩

    目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限&#xff08;ROW FORMAT&#xff09;配置标准HQL为&#xff1a; ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...

    2024/5/9 7:40:34
  19. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

    文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中&#xff0c;传感器和控制器产生大量周…...

    2024/5/9 1:42:21
  20. --max-old-space-size=8192报错

    vue项目运行时&#xff0c;如果经常运行慢&#xff0c;崩溃停止服务&#xff0c;报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中&#xff0c;通过JavaScript使用内存时只能使用部分内存&#xff08;64位系统&…...

    2024/5/9 5:02:59
  21. 基于深度学习的恶意软件检测

    恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞&#xff0c;例如可以被劫持的合法软件&#xff08;例如浏览器或 Web 应用程序插件&#xff09;中的错误。 恶意软件渗透可能会造成灾难性的后果&#xff0c;包括数据被盗、勒索或网…...

    2024/5/9 4:31:45
  22. JS原型对象prototype

    让我简单的为大家介绍一下原型对象prototype吧&#xff01; 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定&#xff0c;每一个构造函数都有一个 prototype 属性&#xff0c;指向另一个对象&#xff0c;所以我们也称为原型对象…...

    2024/5/9 16:54:42
  23. C++中只能有一个实例的单例类

    C中只能有一个实例的单例类 前面讨论的 President 类很不错&#xff0c;但存在一个缺陷&#xff1a;无法禁止通过实例化多个对象来创建多名总统&#xff1a; President One, Two, Three; 由于复制构造函数是私有的&#xff0c;其中每个对象都是不可复制的&#xff0c;但您的目…...

    2024/5/8 9:51:44
  24. python django 小程序图书借阅源码

    开发工具&#xff1a; PyCharm&#xff0c;mysql5.7&#xff0c;微信开发者工具 技术说明&#xff1a; python django html 小程序 功能介绍&#xff1a; 用户端&#xff1a; 登录注册&#xff08;含授权登录&#xff09; 首页显示搜索图书&#xff0c;轮播图&#xff0…...

    2024/5/9 6:36:49
  25. 电子学会C/C++编程等级考试2022年03月(一级)真题解析

    C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...

    2024/5/9 4:33:29
  26. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  27. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  28. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  29. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  30. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  31. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  32. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  33. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  34. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  35. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  36. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  37. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  38. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  39. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  40. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  41. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  42. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  43. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  44. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  45. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57