文章目录

  • 1. 先创建自定义类加载器
  • 2. demo程序
    • 2.1 最初版程序
    • 2.2 第二版---使用命令行执行,设置指定的类加载器作为系统类加载器
  • 3. Launcher源码分析
    • 3.1 分析入口在哪里---ClassLoader官方文档
    • 3.2 有些人就要问了,为什么直接锁定入口就是在ClassLoader.getSystemClassLoader()呢
    • 3.3 系统类加载器和扩展类加载器是如何创建和初始化的
    • 3.4 如何将自定义类加载器作为默认的系统类加载器的
      • 3.4.1 通过 SystemClassLoaderAction 构造方法将默认的系统类的类加载器,后续通过判断看是否返回
      • 3.4.2 判断是否配置了自定义系统类加载器
      • 3.4.3 根据传入的自定义系统类加载器类全名,来实例化该类加载
  • 4. 添加构造方法,完善程序
    • 4.1 在自定义类加载器CustomClassLoader中添加构造方法
    • 4.2 也许有人会问 为什么类Test17(当前类)为什么不是被当前默认的自定义系统类加载器所加载,而是还是被jvm的AppClassLoader所加载?
  • 5. 也许有人会问,如何验证以上的说法是正确的,如何证明我们自定义的系统类加载器能够使用?
    • 5.1 我们调整一下demo,添加一个加载指定类的操作,代码如下:
    • 5.2 添加参数 -Djava.system.class.loader=com.lonely.jvmstudy.examples.CustomClassLoader
    • 5.3 删除项目中Test14编译后的class文件
    • 5.4 也许有人会问,为什么路径是这个呢。

1. 先创建自定义类加载器

在之前的demo中,已经存在该自定义类加载代码,避免再次寻找,这里再次输出出来

package com.lonely.jvmstudy.examples;import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.text.MessageFormat;
import java.util.Optional;public class CustomClassLoader extends ClassLoader {/*** 类加载器名称*/private String classLoaderName;/*** 类加载器根目录,默认D盘*/
private String path = "D:/";private static final String suffixName = ".class";/*** 默认以systemClassLoader为父类加载器** @param classLoaderName*/public CustomClassLoader(String classLoaderName) {super();this.classLoaderName = classLoaderName;}/*** 使用传入的classlaoder作为其双亲** @param parent* @param classLoaderName*/public CustomClassLoader(ClassLoader parent, String classLoaderName) {super(parent);this.classLoaderName = classLoaderName;}/*** Finds the class with the specified <a href="#name">binary name</a>.* This method should be overridden by class loader implementations that * follow the delegation model for loading classes, and will be invoked by * the {@link #loadClass <tt>loadClass</tt>} method after checking the* parent class loader for the requested class.  The default implementation * throws a <tt>ClassNotFoundException</tt>.* * @param name The <a href="#name">binary name</a> of the class * @return The resulting <tt>Class</tt> object * @throws ClassNotFoundException If the class could not be found* @since 1.2*/  @Overrideprotected Class<?> findClass(String name) throws ClassNotFoundException {System.out.println("findClass..");byte[] bytes = this.loadClassData(name);return this.defineClass(name, bytes, 0, bytes.length);}/*** 加载指定className对应的文件,返回对应的数据,这里注意使用 read()读取class文件内容时,只能一个一个字节的读取,不能一次多个。** @param className* @return*/private byte[] loadClassData(String className) {className = className.replace(".", "/");byte[] readDatas = null;try (ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();FileInputStream fileInputStream = new FileInputStream(new File(Optional.ofNullable(this.path).orElse("") + className + suffixName));) {int result;while ((result = fileInputStream.read()) != -1) {byteArrayOutputStream.write(result);}/*byte[] datas = new byte[1];while (fileInputStream.read(datas) != -1) { byteArrayOutputStream.write(datas); }*/  readDatas = byteArrayOutputStream.toByteArray();} catch (Exception e) {e.printStackTrace();}return readDatas;}@Overridepublic String toString() {return this.getClass().toString();}public void setPath(String path) {this.path = path;}
}

2. demo程序

2.1 最初版程序

package com.lonely.jvmstudy.examples;/*** @author ztkj-hzb* @Date 2019/12/26 16:52* @Description 分析自定义类加载器,使用参数设置自定义类加载器,分析Launcher源码*/
public class Test17 {public static void main(String[] args) {//获取指定属性值System.out.println(System.getProperty("java.system.class.loader"));//输出当前类加载器System.out.println(Test17.class.getClassLoader());//输出应用类加载器System.out.println(ClassLoader.getSystemClassLoader());}}

执行后,得到以下结果:

null
sun.misc.Launcher$AppClassLoader@18b4aac2
sun.misc.Launcher$AppClassLoader@18b4aac2

分析结果:
1.首先 “java.system.class.loader” 该属性是用来使用指定的自定义类加载来覆盖默认的系统类加载器(AppClassLoader),因为这里是直接启动,没有为该参数赋值,所以返回null
2.因为当前程序还是使用的最初的系统类加载器,因此下面的结果都是系统类加载器,没疑问。

2.2 第二版—使用命令行执行,设置指定的类加载器作为系统类加载器

使用以下命令,指定自定义类加载器位置,注意这里的包路径写法,注意!
[使用java命令运行class文件提示“错误:找不到或无法加载主类“的问题分析][https://www.cnblogs.com/guohu/p/11101285.html]
[https://www.cnblogs.com/guohu/p/11101285.html]: https://www.cnblogs.com/guohu/p/11101285.html “使用java命令运行class文件提示“错误:找不到或无法加载主类“的问题分析”

D:\workspace_demo\jvm-study\target\classes>java -Djava.system.class.loader=com.lonely.jvmstudy.examples.CustomClassLoader com.lonely.jvmstudy.examples.Test17
Error occurred during initialization of VM
java.lang.Error: java.lang.NoSuchMethodException: com.lonely.jvmstudy.examples.CustomClassLoader.<init>(java.lang.ClassLoader)at java.lang.ClassLoader.initSystemClassLoader(Unknown Source)at java.lang.ClassLoader.getSystemClassLoader(Unknown Source)
Caused by: java.lang.NoSuchMethodException: com.lonely.jvmstudy.examples.CustomClassLoader.<init>(java.lang.ClassLoader)at java.lang.Class.getConstructor0(Unknown Source)at java.lang.Class.getDeclaredConstructor(Unknown Source)at java.lang.SystemClassLoaderAction.run(Unknown Source)at java.lang.SystemClassLoaderAction.run(Unknown Source)at java.security.AccessController.doPrivileged(Native Method)at java.lang.ClassLoader.initSystemClassLoader(Unknown Source)at java.lang.ClassLoader.getSystemClassLoader(Unknown Source)

分析以上结果:
1.首先,在这里使用属性 “java.system.class.loader” 指定了自定义类加载器路径,从异常结果中可以看到确实加载了该类。
2.结果中提示我们自定义的类加载器缺少一个带以ClassLoader为入参的构造方法,我们再次查看我们的自定义类加载器,发现确实没有该种情况的构造方法。那么问题来了,为什么需要这样一个构造方法。我们开始分析其源码,go~~

3. Launcher源码分析

3.1 分析入口在哪里—ClassLoader官方文档

我们进入类 ClassLoader.getSystemClassLoader()方法,打开其官方文档,发现会有这么一段话

If the system property "<tt>java.system.class.loader</tt>" is defined
when this method is first invoked then the value of that property is
taken to be the name of a class that will be returned as the system
class loader.  The class is loaded using the default system class loader
and must define a public constructor that takes a single parameter of
type <tt>ClassLoader</tt> which is used as the delegation parent.  An
instance is then created using this constructor with the default system
class loader as the parameter.  The resulting class loader is defined
to be the system class loader.

翻译后,就是

如果在首次调用此方法时定义了系统属性“ java.system.class.loader”,则该属性的值将作为要作为系统类加载器返回的类的名称。该类使用默认的系统类加载器加载,并且必须定义一个公共构造函数,该构造函数采用单个类型为ClassLoader的参数作为委托父级。然后使用此构造函数创建一个实例,并使用默认系统类加载器作为参数。结果类加载器定义为系统类加载器。

从文档中,我们就可以看出我们刚才使用的属性,以及为什么需要这么一个以ClassLoader为参数的构造方法了。虽然说一切学习以官方文档为准,但是还是要真正看到如何实现才放心,下面就开始验证这部分文档的代码寻找之旅,go~~~

3.2 有些人就要问了,为什么直接锁定入口就是在ClassLoader.getSystemClassLoader()呢

首先,该结论我也不知道,哈哈,曾经看教程时看到的,在jvm启动时启动类加载器会初始化ClassLoader类,以及扩展类加载器,系统类加载器。但是启动类加载器不是java类,看不到代码,因此,只能使用一个小demo来测试,表示在程序的最开始就会调用ClassLoader.getSystemClassLoader()。

package com.lonely.jvmstudy.examples;/*** @author ztkj-hzb* @Date 2020/1/9 11:23* @Description*/
public class Test18 {public static void main(String[] args) {System.out.println("----------------------start---------------------");System.out.println(ClassLoader.getSystemClassLoader());System.out.println("-----------------------end----------------------");}}

我们断点启动该类,且在ClassLoader.getSystemClassLoader()方法中加断点,启动程序后就会发现,首先进入到ClassLoader的断点中,执行在程序的第一行输出之前,且可以使用调试工具,向上执行,可以发现在System类中会调用该类。因此,首先可以确定一点,ClassLoader.getSystemClassLoader()会在很早之前执行。

3.3 系统类加载器和扩展类加载器是如何创建和初始化的

我们进入到ClassLoader.getSystemClassLoader()方法的源码中

public static ClassLoader getSystemClassLoader() {//初始化系统类加载器initSystemClassLoader();if (scl == null) {return null;}SecurityManager sm = System.getSecurityManager();if (sm != null) {checkClassLoaderPermission(scl, Reflection.getCallerClass());}return scl;
}

这段代码,我们只需要分析 initSystemClassLoader()方法,进入其中

private static synchronized void initSystemClassLoader() {if (!sclSet) {if (scl != null)throw new IllegalStateException("recursive invocation");sun.misc.Launcher l = sun.misc.Launcher.getLauncher();if (l != null) {Throwable oops = null;scl = l.getClassLoader();try {scl = AccessController.doPrivileged(new SystemClassLoaderAction(scl));} catch (PrivilegedActionException pae) {oops = pae.getCause();if (oops instanceof InvocationTargetException) {oops = oops.getCause();}}if (oops != null) {if (oops instanceof Error) {throw (Error) oops;} else {// wrap the exceptionthrow new Error(oops);}}}sclSet = true;}
}

该段代码主要任务:

  1. Launcher类的初始化,该类会初始化扩展类加载器以及默认的系统类加载器
  2. 判断是否由自定义类加载器作为系统类加载器

sun.misc.Launcher l = sun.misc.Launcher.getLauncher();

这段代码 调用了Launcher的静态方法getLauncher(),属于主动调用,会导致该类的初始化,所以进入该类,分析其构造方法,源码如下:

public Launcher() {Launcher.ExtClassLoader var1;try {var1 = Launcher.ExtClassLoader.getExtClassLoader();} catch (IOException var10) {throw new InternalError("Could not create extension class loader", var10);}try {this.loader = Launcher.AppClassLoader.getAppClassLoader(var1);} catch (IOException var9) {throw new InternalError("Could not create application class loader", var9);}Thread.currentThread().setContextClassLoader(this.loader);String var2 = System.getProperty("java.security.manager");if (var2 != null) {SecurityManager var3 = null;if (!"".equals(var2) && !"default".equals(var2)) {try {var3 = (SecurityManager)this.loader.loadClass(var2).newInstance();} catch (IllegalAccessException var5) {;} catch (InstantiationException var6) {;} catch (ClassNotFoundException var7) {;} catch (ClassCastException var8) {;}} else {var3 = new SecurityManager();}if (var3 == null) {throw new InternalError("Could not create SecurityManager: " + var2);}System.setSecurityManager(var3);}}

该段代码,首先使用 Launcher.ExtClassLoader.getExtClassLoader(); 初始化扩展类加载器,进入该方法中,查看是如何初始化的

public static Launcher.ExtClassLoader getExtClassLoader() throws IOException {if (instance == null) {Class var0 = Launcher.ExtClassLoader.class;synchronized(Launcher.ExtClassLoader.class) {if (instance == null) {instance = createExtClassLoader();}}}return instance;
}private static Launcher.ExtClassLoader createExtClassLoader() throws IOException {try {return (Launcher.ExtClassLoader)AccessController.doPrivileged(new PrivilegedExceptionAction<Launcher.ExtClassLoader>() {public Launcher.ExtClassLoader run() throws IOException {//从属性 java.ext.dirs 中加载对应的jar包文件File[] var1 = Launcher.ExtClassLoader.getExtDirs();int var2 = var1.length;for(int var3 = 0; var3 < var2; ++var3) {MetaIndex.registerDirectory(var1[var3]);}return new Launcher.ExtClassLoader(var1);}});} catch (PrivilegedActionException var1) {throw (IOException)var1.getException();}
}private static File[] getExtDirs() {String var0 = System.getProperty("java.ext.dirs");File[] var1;if (var0 != null) {StringTokenizer var2 = new StringTokenizer(var0, File.pathSeparator);int var3 = var2.countTokens();var1 = new File[var3];for(int var4 = 0; var4 < var3; ++var4) {var1[var4] = new File(var2.nextToken());}} else {var1 = new File[0];}return var1;
}

这段代码主要意思就是:创建一个扩展类加载器,且从指定路径中:java.ext.dirs 获取jar包,class文件,由扩展类加载器加载到内存中。

下面以同样的方式初始化默认的系统类加载器,稍微有点区别

  1. 系统类加载器是从路径:java.class.path 中获取
  2. 系统类加载器以扩展类加载器作为其父级加载器,这里就体现了双亲模式的建立。

3.4 如何将自定义类加载器作为默认的系统类加载器的

针对方法initSystemClassLoader(),刚才模块3.3主要分析了如何初始化扩展类加载器以及系统类加载器,现在,就刚才的后面继续分析,如何将自定义的类加载器作为默认的系统类加载器的
ClassLoader.initSystemClassLoader()#
scl = AccessController.doPrivileged(new SystemClassLoaderAction(scl));
这段代码就介绍了如何使用自定义类加载器作为默认的系统类加载器,同时说明了使用自定义类加载器需要定义一个以ClassLoader作为参数的构造方法。废话不多说,go

class SystemClassLoaderActionimplements PrivilegedExceptionAction<ClassLoader> {private ClassLoader parent;SystemClassLoaderAction(ClassLoader parent) {this.parent = parent;}public ClassLoader run() throws Exception {String cls = System.getProperty("java.system.class.loader");if (cls == null) {return parent;}Constructor<?> ctor = Class.forName(cls, true, parent).getDeclaredConstructor(new Class<?>[] { ClassLoader.class });ClassLoader sys = (ClassLoader) ctor.newInstance(new Object[] { parent });Thread.currentThread().setContextClassLoader(sys);return sys;}
}

3.4.1 通过 SystemClassLoaderAction 构造方法将默认的系统类的类加载器,后续通过判断看是否返回

SystemClassLoaderAction(ClassLoader parent) {this.parent = parent;
}

3.4.2 判断是否配置了自定义系统类加载器

通过属性 java.system.class.loader 的值来判断是否需要替换默认的系统类加载器。如果没有值,则返回传入的默认的系统类加载器。如果有值,那么进入下一步

3.4.3 根据传入的自定义系统类加载器类全名,来实例化该类加载

Constructor<?> ctor = Class.forName(cls, true, parent).getDeclaredConstructor(new Class<?>[] { ClassLoader.class });
ClassLoader sys = (ClassLoader) ctor.newInstance(new Object[] { parent });
Thread.currentThread().setContextClassLoader(sys);

这段代码是什么意思呢,就是首先通过反射根据全类名获取对应的Class对象,然后获取其中以ClassLoader为参数的构造方法,将默认的系统类加载器作为其父类加载传入,来构建对象。这就解释了,为什么使用我们自定义系统类加载器执行代码时会提示缺少一个以ClassLoader为参数的构造方法了。

4. 添加构造方法,完善程序

4.1 在自定义类加载器CustomClassLoader中添加构造方法

/*** 添加带参构造方法* @param parent*/
public CustomClassLoader(ClassLoader parent){super(parent);
}

首先在idea执行,不输入参数 java.system.class.loader 输出结果如下:

null
sun.misc.Launcher$AppClassLoader@18b4aac2
sun.misc.Launcher$AppClassLoader@18b4aac2

出现这些结果,在我们意料之中,这里不在重复说明,下面使用cmd控制台 执行,添加参数,控制台命令如下:

D:\workspace_demo\jvm-study\target\classes>java -Djava.system.class.loader=com.lonely.jvmstudy.examples.CustomClassLoader com.lonely.jvmstudy.examples.Test17

输出结果如下:

com.lonely.jvmstudy.examples.CustomClassLoader
sun.misc.Launcher$AppClassLoader@18b4aac2
class com.lonely.jvmstudy.examples.CustomClassLoader

从结果中可以看出,jvm默认的系统类加载器变成了我们指定的自定义系统类加载器了。

4.2 也许有人会问 为什么类Test17(当前类)为什么不是被当前默认的自定义系统类加载器所加载,而是还是被jvm的AppClassLoader所加载?

从源码中,我们可以看到下面这一部分

public ClassLoader run() throws Exception {String cls = System.getProperty("java.system.class.loader");if (cls == null) {return parent;}Constructor<?> ctor = Class.forName(cls, true, parent).getDeclaredConstructor(new Class<?>[] { ClassLoader.class });ClassLoader sys = (ClassLoader) ctor.newInstance(new Object[] { parent });Thread.currentThread().setContextClassLoader(sys);return sys;
}

这里将原来的jvmApp系统类加载器作为了自定义系统类加载的父加载器,即保留了双亲委托的机制,这也是本文章核心,为什么需要添加一个以ClassLoader为参数的构造方法。根据双亲委托机制,加载Test17.class,会首先交于父类AppClassLoader来加载,而类Test17能被AppClassloader加载,所以输出的是AppClassLoader。

5. 也许有人会问,如何验证以上的说法是正确的,如何证明我们自定义的系统类加载器能够使用?

5.1 我们调整一下demo,添加一个加载指定类的操作,代码如下:

package com.lonely.jvmstudy.examples;/*** @author ztkj-hzb* @Date 2019/12/26 16:52* @Description 分析自定义类加载器,使用参数设置自定义类加载器,分析Launcher源码*/
public class Test17 {public static void main(String[] args) throws ClassNotFoundException {//获取指定属性值System.out.println(System.getProperty("java.system.class.loader"));//输出当前类加载器System.out.println(Test17.class.getClassLoader());//输出应用类加载器System.out.println(ClassLoader.getSystemClassLoader());//使用默认系统类加载器加载Test14Class<?> aClass = ClassLoader.getSystemClassLoader().loadClass("com.lonely.jvmstudy.examples.Test14");System.out.println(aClass.getClassLoader());}}

执行以上代码,结果如下:

null
sun.misc.Launcher$AppClassLoader@18b4aac2
sun.misc.Launcher$AppClassLoader@18b4aac2
sun.misc.Launcher$AppClassLoader@18b4aac2

注意:大家可能执行的时候会报错,因为你们的项目中可能没有最后我添加的Test14那个类,所以这里这是参考我的项目
以上结果,因为没有配置参数,所以结果不难获取。

5.2 添加参数 -Djava.system.class.loader=com.lonely.jvmstudy.examples.CustomClassLoader

我们添加参数,再次执行,看看结果

com.lonely.jvmstudy.examples.CustomClassLoader
sun.misc.Launcher$AppClassLoader@18b4aac2
class com.lonely.jvmstudy.examples.CustomClassLoader
sun.misc.Launcher$AppClassLoader@18b4aac2

对比5.1 结果,在获取应用类加载器这里结果有点不同,但是根据4.x模块以及解释了这种情况,这种情况可以表示我们自定义的系统类加载器已经生效。但是由于AppClassLoader类加载器的存在,项目中的业务类都会被它加载,不能很明确的证明我们的自定义类加载器能否正确读取、加载、运行Class对象,下面,就来看我们如何实现它。

5.3 删除项目中Test14编译后的class文件

首先在编辑器中,不配置参数执行程序,得出以下结果:

null
sun.misc.Launcher$AppClassLoader@18b4aac2
sun.misc.Launcher$AppClassLoader@18b4aac2
Exception in thread "main" java.lang.ClassNotFoundException: Test14at java.net.URLClassLoader.findClass(URLClassLoader.java:381)at java.lang.ClassLoader.loadClass(ClassLoader.java:424)at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:349)at java.lang.ClassLoader.loadClass(ClassLoader.java:357)at com.lonely.jvmstudy.examples.Test17.main(Test17.java:24)

因为Test14.class文件已经被我们删除了,所以使用AppClassLoader来加载Test14根据找不到,所以会提示类找不到异常。这里就能体现出目前使用的是AppClassLoader来加载。

现在,我们配置参数,指定自定义系统类加载器位置,然后将我们的编译后的Test14.class文件放到磁盘 D:\com\lonely\jvmstudy\examples中,再次执行程序,得到以下结果:

com.lonely.jvmstudy.examples.CustomClassLoader
sun.misc.Launcher$AppClassLoader@18b4aac2
class com.lonely.jvmstudy.examples.CustomClassLoader
findClass..
class com.lonely.jvmstudy.examples.CustomClassLoader

从结果上看,对比上面未删除class之前的结果,可以看出最后Test14类是由我们的自定义系统类加载器加载。

5.4 也许有人会问,为什么路径是这个呢。

  1. 首先观察一下我们的自定义类加载器,指定了默认的path路径是 D:/,这是什么意思呢。就是如果我们不指定从哪个路径下找class文件,就使用默认的D:/,这个跟jvm的默认配置路径,例如默认的AppClassLoader是从路径:java.class.path来加载class文件。
  2. 那么又有人会问了,那么创建的文件夹应该也是 D:/,那么为什么需要的创建的路径是 D:\com\lonely\jvmstudy\examples 呢。其实 com.lonely.jvmstudy.examples是我们的类的包路径,因此创建的路径需要带上包路径。
  3. 最后,也许还有人会问,那么我们将自定义的类加载器的path字段,设置为带上包名的全路径,在加载的时候,只要写上类名就行了,这样行吗。

现在,稍稍修改一下程序,

  1. 修改我们的自定义系统类加载器,将path修改成以下路径:
private String path = "D:/com/lonely/jvmstudy/examples/";
  1. 修改我们的测试类,修改Class.forname()方法的路径为如下:
Class<?> aClass = ClassLoader.getSystemClassLoader().loadClass("Test14");

然后带上参数,执行程序,得到以下结果:

Exception in thread "main" java.lang.NoClassDefFoundError: Test14 (wrong name: com/lonely/jvmstudy/examples/Test14)at java.lang.ClassLoader.defineClass1(Native Method)at java.lang.ClassLoader.defineClass(ClassLoader.java:763)at java.lang.ClassLoader.defineClass(ClassLoader.java:642)at com.lonely.jvmstudy.examples.CustomClassLoader.findClass(CustomClassLoader.java:71)at java.lang.ClassLoader.loadClass(ClassLoader.java:424)at java.lang.ClassLoader.loadClass(ClassLoader.java:357)at com.lonely.jvmstudy.examples.Test17.main(Test17.java:24)
com.lonely.jvmstudy.examples.CustomClassLoader
sun.misc.Launcher$AppClassLoader@18b4aac2
class com.lonely.jvmstudy.examples.CustomClassLoader
findClass..

事实证明,不行。至于原因,因为该段代是native方法,看不到源码,所以暂时也就这么理解吧。

private native Class<?> defineClass1(String name, byte[] b, int off, int len,ProtectionDomain pd, String source);

最后,由于我也是刚刚接触jvm类加载器,写这篇文章只是为了记下笔记,以后忘记了,还可以看看记录,不喜勿喷,谢谢!

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

相关文章

  1. 小程序菜鸟的模板(template)学习

    小程序菜鸟的模板template学习 新建template(header.wxml) *使用 name 属性,作为模板的名字,在一个模板文件中,可以有多个模板<template name="header"><view class="title">{{title}}</view></template> ...引用模板header.…...

    2024/4/29 14:11:26
  2. springcloud运行报错:InstantiationException: tk.mybatis.mapper.provider.base.BaseSelectProvider

    1.错误:InstantiationException: tk.mybatis.mapper.provider.base.BaseSelectProvider2.产生原因:一般为整合了tk包依赖后,在扫包时引入的包不对,导致mapper查询时报错; 3.解决: 错误的包:应该为:...

    2024/4/29 14:11:21
  3. 基于问题学习安卓系统架构

    基于问题学习安卓系统架构 文章目录基于问题学习安卓系统架构1 原理1.1 什么是安卓系统架构APP层Framework层Native/ArtNative: C/C++ArtHAL层Kernal层1.2 Android8源码与系统架构的关系源码目录结构源码目录描述1.3 为什么安卓系统架构要这么设计 1 原理 本节要了解、弄懂安卓…...

    2024/4/29 14:11:18
  4. 网页性能优化:延迟加载资源

    延迟加载 延迟加载是一种在加载页面时,延迟加载非关键资源的一种方法,而这些非关键资源则在需要时才进行加载,就图像而言,‘非关键’通常指的是‘屏幕外’。延迟加载图像和视频时,可以减少初始页面加载时间、初始页面负载以及系统资源使用量,所有这一切都会对性能产生积极…...

    2024/4/29 14:11:14
  5. 推荐Scrum书籍

    推荐Scrum书籍 直接上干货,推荐书籍清单如下(推荐有顺序的哦)Scrum指南 Scrum精髓 Scrum敏捷软件开发 Scrum捷径 硝烟中的Scrum和XP : 我们如何实施Scrum 敏捷软件开发:Scrum实战指南 Scrum要素 大规模Scrum:大规模敏捷组织的设计 用户故事地图 用户故事与敏捷方法Scrum指南…...

    2024/4/29 2:08:43
  6. 分布式锁的几种实现方式

    分布式锁的几种实现方式 目前几乎很多大型网站及应用都是分布式部署的,分布式场景中的数据一致性问题一直是一个比较重要的话题。分布式的CAP理论告诉我们“任何一个分布式系统都无法同时满足一致性(Consistency)、可用性(Availability)和分区容错性(Partition tolerance…...

    2024/4/29 2:08:38
  7. BundleFusion 转

    https://blog.csdn.net/ffcjjhv/article/details/89221992介绍一、配置1、cuda8.0安装2、DirectX SDK安装二、vs2013代码生成1、mLib与 mLib external配置mLibmLib external2、cuda设置修改cuda版本显卡计算能力设置3、相机类型设置(以apt0.sens离线数据为例)输入类型修改Glo…...

    2024/4/29 14:11:09
  8. 安卓权限总结 AndroidManifest权限描述

    权限名称描述android.permission.ACCESS_CHECKIN_PROPERTIES访问登记属性读取或写入登记check-in数据库属性表的权限android.permission.ACCESS_COARSE_LOCATION获取错略位置通过WiFi或移动基站的方式获取用户错略的经纬度信息,定位精度大概误差在30~1500米android.permission.…...

    2024/4/29 14:11:07
  9. 在WIN10上安装python3.8 + Robotframework +RIDE安装全过程

    在WIN10上安装python3.8 + Robotframework +RIDE安装全过程请将安装包copy到d:\RF\进行安装1.安装Python 参考 https://www.python.org/downloads Python 3.8 若已安装了Python35,建议卸载后,再安装Python 3.8 直接点击安装包python-3.8.1-amd64.exe进行安装(经测试3.8.5安…...

    2024/4/29 14:11:03
  10. 在Jetson tx2安装 mmdetection环境

    目录环境:STEP1 安装pytorch STEP2 安装依赖库STEP3 安装mmdetectoin、mmcv编译mmcv编译mmdetection总结相关资源下载参考装了好几天,终于装成功了。环境:1 tx2系统参数:查看命令head -n 1 /etc/nv_tegra_releaseR32 (release), REVISION: 1.0, GCID: 14531094, BOARD: t18…...

    2024/5/2 2:08:55
  11. JAVA 类型信息(Type Information)

    目录传统的RTTI的表现形式Class对象反射:运行时的类信息为啥java中需要有反射机制呢?《Effective Java》中第65条:接口优先于反射机制动态代理 Runtime type information (RTTI) allows you to discover and use type information while a program is running.运行时类型信息…...

    2024/5/2 10:07:21
  12. python爬虫练习(一),有挑选性的爬取网站上的美女图片

    这里和大家分享以下我练习爬虫爬取网站上美女图片的学习笔记,不要笑话,点进来的你也是小色批。提前说明:各大搜索引擎用的都是爬虫,很多权威的新闻网也都在爬取相关的新闻资料,爬虫不是贬义词(当然我们绝对不能拿他来做坏事)。 我下面列出了要爬取一个网站图片的主…...

    2024/5/2 2:56:25
  13. E2Echallenge参赛模型汇总

    类型模型名称出处论文关键信息点data drivenTUDA-ModelDE2ENLG challenge: Nerual Models vs. Templates使用所有的属性,如果当前MR没有某一属性,则将该属性的值置为PAD编码器使用Embed Lookup的方式进行词向量转化(词表是训练集中出现的数据),再加一个Relu解码器使用单向…...

    2024/4/29 14:10:46
  14. java面试文章

    文章目录一、Java 基础1.JDK 和 JRE 有什么区别?2. == 和 equals 的区别是什么?3.两个对象的 hashCode()相同,则 equals()也一定为 true,对吗?4.final 在 java 中有什么作用?5.java 中的 Math.round(-1.5) 等于多少?6.String 属于基础的数据类型吗?7.java 中操作字符串…...

    2024/4/29 14:10:42
  15. 完美模式ALOKEX已经正式上线

    Alokex交易所在 IPFS 分布式存储技术的基础上实现的数据管理和交易模块,并且系统自带强大的撮合系统和数字资产所有权认证体系,以保障用户自有数据的安全和收益。对于区块链系统特别是数字货币交易所来说,私钥的安全是一切安全的基础,一旦私钥被放置到中心化的平台,它的安…...

    2024/4/29 14:10:38
  16. 水箱自洁式消毒器

    使用水箱消毒器已经越来越普遍,这和人们对自己生活质量的要求分也分不开的,健康、环保、安全是人们对自己生活质量的低标准和要求,所以应用的广泛性也是大家都非常希望和预知得到的事情。然而水质安全消毒只是其中的一个方面。现在水的二次利用很响,所以水箱消毒器的作用也…...

    2024/4/29 14:10:34
  17. 暑期学习必备作业帮手:伴印错题打印机,一台能提分的打印机

    暑假已经过半,转眼又要开学了,今年由于疫情原因,学生真正在校时间也就不到两个月,可以说学习成果完全靠网课来支撑的。期末成绩普遍不理想。对于孩子的辅导,家长真是操碎了心,但是成果却让不尽人意。最近,有一款专为学生学习设计的打印机伴印错题打印机,感觉很不错。伴…...

    2024/4/29 14:10:30
  18. 你平时开发会关注卡顿和卡顿率吗?

    本次技术干货主要是讲解PerfDog卡顿Jank定义、原理、卡顿率(Stutter)定义及影响等,内容将分为六部分,FrameTime、FPS、流畅度、Jank(卡顿次数)、卡顿率(Stutter)、影响等。从深层次分析在性能测试工作中这六部分起到的重要作用 FrameTime 定义:两帧画面间隔耗时(也可简单认为…...

    2024/4/29 14:10:26
  19. JAVA自学怎么学效果比较好?

    第一:看视频还是看书。 根据我过来的学习经验,建议零基础入门学习Java主视频,副书籍。虽然说每个人都有适合自己的学习方法和学习方式,但是Java是一门编程语言,相比来说基础 入门的视频教程更能快速带领我们走进Java编程的世界。而且对于一门编程语言来说,书籍能诠释的东…...

    2024/4/29 14:10:21
  20. 跟着360架构师 学习Shell脚本编程--复习笔记

    2.1 变量替换和测试变量替换 ${变量名#匹配规则} 从变量开头进行规则匹配,将符合最短的数据删除 ${变量名##匹配规则} 从变量开头进行规则匹配,将符合最长的数据删除 ${变量名%匹配规则} 从变量结尾进行规则匹配,将符合最短的数据删除 ${变量名%%匹配规则} 从变量结尾…...

    2024/4/29 12:43:01

最新文章

  1. monaco-editor设置语言、值等

    我们在使用Monaco-editor时&#xff0c;如何设置语言或者值呢&#xff1f; 我的创建实例代码&#xff1a; editor.value monaco.editor.create(codeEditorRef.value, {value: props.setting.value,language: props.setting.language,theme: props.setting.theme,colorDecorat…...

    2024/5/3 5:21:26
  2. 梯度消失和梯度爆炸的一些处理方法

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

    2024/3/20 10:50:27
  3. 图像处理相关知识 —— 椒盐噪声

    椒盐噪声是一种常见的图像噪声类型&#xff0c;它会在图像中随机地添加黑色&#xff08;椒&#xff09;和白色&#xff08;盐&#xff09;的像素点&#xff0c;使图像的质量降低。这种噪声模拟了在图像传感器中可能遇到的问题&#xff0c;例如损坏的像素或传输过程中的干扰。 椒…...

    2024/5/2 17:46:29
  4. LeetCode-200. 岛屿数量【深度优先搜索 广度优先搜索 并查集 数组 矩阵】

    LeetCode-200. 岛屿数量【深度优先搜索 广度优先搜索 并查集 数组 矩阵】 题目描述&#xff1a;解题思路一&#xff1a;bfs&#xff0c;主要思想都是遇到一个没有visited过的"陆地"先result 1&#xff0c;然后用深搜或者广搜将这片"陆地"全部做上visited标…...

    2024/5/2 14:17:05
  5. 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/2 11:19:01
  6. 【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/2 16:04:58
  7. 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/2 23:55:17
  8. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

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

    2024/5/2 9:47:31
  9. VB.net WebBrowser网页元素抓取分析方法

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

    2024/5/2 9:47:31
  10. 【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/2 6:03:07
  11. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

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

    2024/5/2 9:47:30
  12. 【ES6.0】- 扩展运算符(...)

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

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

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

    2024/5/2 5:31:39
  14. Go语言常用命令详解(二)

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

    2024/5/3 1:55:15
  15. 用欧拉路径判断图同构推出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/2 9:47:28
  16. 【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/2 9:47:27
  17. 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/3 1:55:09
  18. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

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

    2024/5/2 8:37:00
  19. --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/2 9:47:26
  20. 基于深度学习的恶意软件检测

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

    2024/5/2 9:47:25
  21. JS原型对象prototype

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

    2024/5/2 23:47:16
  22. C++中只能有一个实例的单例类

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

    2024/5/2 18:46:52
  23. python django 小程序图书借阅源码

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

    2024/5/2 7:30:11
  24. 电子学会C/C++编程等级考试2022年03月(一级)真题解析

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

    2024/5/3 1:54:59
  25. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

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

    2022/11/19 21:17:18
  26. 错误使用 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
  27. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

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

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

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

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

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

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

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

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

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

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

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

    2022/11/19 21:17:10
  33. 电脑桌面一直是清理请关闭计算机,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
  34. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    2022/11/19 21:16:58
  44. 如何在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