g2o图优化库的使用

  • 1、背景知识介绍
  • 2、代码详解
    • 一、点和边的类型定义
    • 二、构建图优化实例,配置求解器
    • 三、添加点和边
    • 四、执行优化
  • 3、ax^2+bx+c实现
    • 一、程序:
    • 二、运行结果

1、背景知识介绍

优化的目的是为了通过当前已知的系统理想化的模型和实际测量的数据获取最近接真实值的系统结果。这样的定义让人很容易联想起来各种滤波方法的目的,的确滤波方法和图优化方案解决的问题都是对不可靠的测量值进行处理以获取尽可能接近真实值的结果,例如以卡尔曼滤波器为例,在进行操作之前我们需要有一个相对靠谱的预测模型用来获取先验(预测)信息,以及实时的测量数据用来矫正预测信息。g2o图优化则是将优化问题和图论相结合,最典型的作用就是将待优化问题通过测量的数据建立最小二乘并将该最小二乘问题通过图论中的边的顶点表示出来,之后调用g2o库通过求解对应的图来实现对最小二乘问题的求解以达到优化的目的。其中图优化中的点表示待优化变量,如(XYZ);边表示误差,边依赖于点的存在而存在,边可能和一个点、俩个点、多个点相连,每条边都表示与相连的点之间的误差。在slam问题中以相机位姿和观测到的路标做点,点与点之间存在的误差(重投影误差、相机位姿估计误差)做边,如下图所示。
十四讲第六章图

2、代码详解

下面主要对g2o优化库的使用步骤做简要介绍,g2o的使用步骤主要分成以下四部分:

  1. 点和边的类型定义;
  2. 构建图优化实例,配置求解器;
  3. 添加点和边,构建求解图;
  4. 执行优化。

通过以下代码展示通过建立最小二乘求解模型expax2+bx+c的参数abc:

//G2O求解最小二乘
#include <iostream>
#include <g2o/core/g2o_core_api.h>
#include <g2o/core/base_vertex.h>
#include <g2o/core/base_unary_edge.h>
#include <g2o/core/block_solver.h>
#include <g2o/core/optimization_algorithm_levenberg.h>
#include <g2o/core/optimization_algorithm_gauss_newton.h>
#include <g2o/core/optimization_algorithm_dogleg.h>
#include <g2o/solvers/dense/linear_solver_dense.h>
#include <Eigen/Core>
#include <opencv2/core/core.hpp>
#include <cmath>using namespace std;
//第一部分;定义顶点和边的类型,先定义顶点后定义边,边是依赖于顶点存在的
// 曲线模型的顶点,模板参数:优化变量维度和数据类型
class CurveFittingVertex : public g2o::BaseVertex<3, Eigen::Vector3d> {
public://类成员变量如果是固定大小对象需要加上 EIGEN_MAKE_ALIGNED_OPERATOR_NEWEIGEN_MAKE_ALIGNED_OPERATOR_NEW// 重置;override 重载 virtual void setToOriginImpl() override{_estimate << 0, 0, 0;}// 更新virtual void oplusImpl(const double *update) override{_estimate += Eigen::Vector3d(update);}// 存盘和读盘:留空,暂时不用virtual bool read(istream &in) {}virtual bool write(ostream &out) const {}
};// 误差模型 模板参数:观测值维度,类型,连接顶点类型
class CurveFittingEdge : public g2o::BaseUnaryEdge<1, double, CurveFittingVertex> {
public://类成员变量如果是固定大小对象需要加上 EIGEN_MAKE_ALIGNED_OPERATOR_NEWEIGEN_MAKE_ALIGNED_OPERATOR_NEW//构造函数初始化CurveFittingEdge(double x) : BaseUnaryEdge(), _x(x) {}// 计算曲线模型误差virtual void computeError() override{//顶点获取const CurveFittingVertex *v = static_cast<const CurveFittingVertex *> (_vertices[0]);//优化变量获取const Eigen::Vector3d abc = v->estimate();//惨差计算_error(0, 0) = _measurement - std::exp(abc(0, 0) * _x * _x + abc(1, 0) * _x + abc(2, 0));}// 计算雅可比矩阵virtual void linearizeOplus() override{//顶点获取const CurveFittingVertex *v = static_cast<const CurveFittingVertex *> (_vertices[0]);//优化变量获取const Eigen::Vector3d abc = v->estimate();//数值求导double y = exp(abc[0] * _x * _x + abc[1] * _x + abc[2]);_jacobianOplusXi[0] = -_x * _x * y;_jacobianOplusXi[1] = -_x * y;_jacobianOplusXi[2] = -y;}//读写,暂时不用,留空virtual bool read(istream &in) {}virtual bool write(ostream &out) const {}
private:double _x;  // x 值, y 值为 _measurement
};int main(int argc, char **argv)
{//进行数据准备double areal = 1.0, breal = 2.0, creal = 1.0;         // 真实参数值double aest = 2.0, best = -1.0, cest = 5.0;        // 估计参数值int PointNum = 100;                                 // 数据点double w_sigma = 1.0;                        // 噪声Sigma值double inv_sigma = 1.0 / w_sigma;cv::RNG rng;                                 // OpenCV随机数产生器// 迭代数据存储vector<double> x_data, y_data;for (int i = 0; i < PointNum; i++) {double x = i / 100.0;x_data.push_back(x);y_data.push_back(exp(areal * x * x + breal * x + creal) + rng.gaussian(w_sigma * w_sigma));}// 第二部分;配置优化器,构建图优化// 定义重载求解变量块,每个误差项优化变量维度为3,误差值维度为1typedef g2o::BlockSolver<g2o::BlockSolverTraits<3, 1>> BlockSolverType;// 定义线性求解器类型typedef g2o::LinearSolverDense<BlockSolverType::PoseMatrixType> LinearSolverType;//创建高斯牛顿求解器auto solver = new g2o::OptimizationAlgorithmGaussNewton(g2o::make_unique<BlockSolverType>(g2o::make_unique<LinearSolverType>()));// 图模型//创建稀疏优化器g2o::SparseOptimizer optimizer;// 设置求解器optimizer.setAlgorithm(solver);// 打开调试输出optimizer.setVerbose(true);// 第三部分;添加点和边// 实例化顶点,往图中增加顶点CurveFittingVertex *v = new CurveFittingVertex();//配置初始估计值v->setEstimate(Eigen::Vector3d(aest, best, cest));//设置图表中节点的id确保更改id后图表保持一致v->setId(0);//添加设置完成的顶点optimizer.addVertex(v);// 往图中增加边for (int i = 0; i < PointNum; i++){//实例化边,并传入标点值CurveFittingEdge *edge = new CurveFittingEdge(x_data[i]);//设置图表中边的id确保更改id后图表保持一致edge->setId(i);// 设置连接的顶点,1、顶点编号2、顶点实例化edge->setVertex(0, v);// 传入观测到的数值edge->setMeasurement(y_data[i]);// 设置信息矩阵:协方差矩阵之逆edge->setInformation(Eigen::Matrix<double, 1, 1>::Identity() * 1 / (w_sigma * w_sigma));//将设置完成的边加入optimizer.addEdge(edge);}// 第四部分;执行优化cout << "start optimization" << endl;//开始优化optimizer.initializeOptimization();//优化次数optimizer.optimize(10);// 输出优化值Eigen::Vector3d abc_estimate = v->estimate();cout << "真实值为: " << areal << " " << breal << " " << creal << endl;cout << "初始预测值为: " << aest << " " << best << " " << cest << endl;cout << "结果为: " << abc_estimate[0] << " " << abc_estimate[1] << " " << abc_estimate[2] << endl;return 0;
}

运行结果:
start optimization
iteration= 0 chi2= 376785.128234 time= 3.2139e-05 cumTime= 3.2139e-05 edges= 100 schur= 0
iteration= 1 chi2= 35673.566018 time= 1.8115e-05 cumTime= 5.0254e-05 edges= 100 schur= 0
iteration= 2 chi2= 2195.012304 time= 1.5005e-05 cumTime= 6.5259e-05 edges= 100 schur= 0
iteration= 3 chi2= 174.853126 time= 2.1757e-05 cumTime= 8.7016e-05 edges= 100 schur= 0
iteration= 4 chi2= 102.779695 time= 2.4055e-05 cumTime= 0.000111071 edges= 100 schur= 0
iteration= 5 chi2= 101.937194 time= 2.4749e-05 cumTime= 0.00013582 edges= 100 schur= 0
iteration= 6 chi2= 101.937020 time= 2.3813e-05 cumTime= 0.000159633 edges= 100 schur= 0
iteration= 7 chi2= 101.937020 time= 2.3953e-05 cumTime= 0.000183586 edges= 100 schur= 0
iteration= 8 chi2= 101.937020 time= 2.4606e-05 cumTime= 0.000208192 edges= 100 schur= 0
iteration= 9 chi2= 101.937020 time= 1.683e-05 cumTime= 0.000225022 edges= 100 schur= 0
真实值为: 1 2 1
初始预测值为: 2 -1 5
结果为: 0.890912 2.1719 0.943629

接下来我们将上述代码分为四部分进行详细介绍:

一、点和边的类型定义

点类型的定义

// 曲线模型的顶点,模板参数:优化变量维度和数据类型
class CurveFittingVertex : public g2o::BaseVertex<3, Eigen::Vector3d> {
public://类成员变量如果是固定大小对象需要加上 EIGEN_MAKE_ALIGNED_OPERATOR_NEWEIGEN_MAKE_ALIGNED_OPERATOR_NEW// 重置;override 重载 virtual void setToOriginImpl() override{_estimate << 0, 0, 0;}// 更新virtual void oplusImpl(const double *update) override{_estimate += Eigen::Vector3d(update);}// 存盘和读盘:留空,暂时不用virtual bool read(istream &in) {}virtual bool write(ostream &out) const {}
};

顶点类成员继承继承自BaseVertex,模板成员参数分别是1、待优化变量维度(3);2、优化变量数据类型(Vector3d)。
顶点类包含四个重要的成员函数需要重载:

  1. setToOriginImp()用于重置优化变量值。(改)
  2. oplusImpl()用于对优化变量进行更新调整,是优化变量向真实值靠近。(改)
  3. read和write分别是读盘、存盘函数,一般情况下不需要进行读/写操作的话,仅仅声明一下就可以.

边类型的定义

// 误差模型 模板参数:观测值维度,类型,连接顶点类型
class CurveFittingEdge : public g2o::BaseUnaryEdge<1, double, CurveFittingVertex> {
public://类成员变量如果是固定大小对象需要加上 EIGEN_MAKE_ALIGNED_OPERATOR_NEWEIGEN_MAKE_ALIGNED_OPERATOR_NEW//构造函数初始化CurveFittingEdge(double x) : BaseUnaryEdge(), _x(x) {}// 计算曲线模型误差virtual void computeError() override{//顶点获取const CurveFittingVertex *v = static_cast<const CurveFittingVertex *> (_vertices[0]);//优化变量获取const Eigen::Vector3d abc = v->estimate();//惨差计算_error(0, 0) = _measurement - std::exp(abc(0, 0) * _x * _x + abc(1, 0) * _x + abc(2, 0));}// 计算雅可比矩阵virtual void linearizeOplus() override{//顶点获取const CurveFittingVertex *v = static_cast<const CurveFittingVertex *> (_vertices[0]);//优化变量获取const Eigen::Vector3d abc = v->estimate();//数值求导double y = exp(abc[0] * _x * _x + abc[1] * _x + abc[2]);_jacobianOplusXi[0] = -_x * _x * y;_jacobianOplusXi[1] = -_x * y;_jacobianOplusXi[2] = -y;}//读写,暂时不用,留空virtual bool read(istream &in) {}virtual bool write(ostream &out) const {}
private:double _x;  // x 值, y 值为 _measurement
};

边类成员继承继承自BaseUnaryedge(不同类型的边有不同的基类,这里是一元边基类),模板成员参数分别是1、观测变量维度(1);2、观测变量数据类型(Vector3d);3、上述定义的顶点类型。
边类包含四个重要的成员函数需要重载:

  1. virtual void computeError();计算惨差,通过成员变量_vertices[0]和顶点编号0获取0号顶点变量;之后通过estimate()成员函数获取最近的优化变量;最后通过 _measurement中存储的观测变量与优化变量做参差计算并传给_error(0, 0)。
  2. virtual void linearizeOplus();同样获取顶点并获取待优化的变量,最后通过数值求导获取雅克比梯度,注意这里需要添加负号,利用负梯度方向迭代。
  3. read 、write留空。

二、构建图优化实例,配置求解器

 // 第二部分;配置优化器,构建图优化// 定义重载求解变量块,每个误差项优化变量维度为3,误差值维度为1typedef g2o::BlockSolver<g2o::BlockSolverTraits<3, 1>> BlockSolverType;// 定义线性求解器类型typedef g2o::LinearSolverDense<BlockSolverType::PoseMatrixType> LinearSolverType;//创建高斯牛顿求解器auto solver = new g2o::OptimizationAlgorithmGaussNewton(g2o::make_unique<BlockSolverType>(g2o::make_unique<LinearSolverType>()));// 图模型//创建稀疏优化器g2o::SparseOptimizer optimizer;// 设置求解器optimizer.setAlgorithm(solver);// 打开调试输出optimizer.setVerbose(true);
  1. 定义变量块BlockSolverType,模板参数分别表示1、优化变量维度(3)2、参差变量维度(1).
  2. 定义线性求解器LinearSolverType。
  3. 选取求解方法。
  4. 创建并配置稀疏优化器。

三、添加点和边

// 第三部分;添加点和边// 实例化顶点,往图中增加顶点CurveFittingVertex *v = new CurveFittingVertex();//配置初始估计值v->setEstimate(Eigen::Vector3d(aest, best, cest));//设置图表中节点的id确保更改id后图表保持一致v->setId(0);//添加设置完成的顶点optimizer.addVertex(v);// 往图中增加边for (int i = 0; i < PointNum; i++){//实例化边,并传入标点值CurveFittingEdge *edge = new CurveFittingEdge(x_data[i]);//设置图表中边的id确保更改id后图表保持一致edge->setId(i);// 设置连接的顶点,1、顶点编号2、顶点实例化edge->setVertex(0, v);// 传入观测到的数值edge->setMeasurement(y_data[i]);// 设置信息矩阵:协方差矩阵之逆edge->setInformation(Eigen::Matrix<double, 1, 1>::Identity() * 1 / (w_sigma * w_sigma));//将设置完成的边加入optimizer.addEdge(edge);}
  1. 实例化一个点v;传入优化变量的初始估计值;给顶点配置编号;将顶点添加至图中。
  2. 实例化边edge;给边配置编号;配置链接的顶点信息(顶点的编号,顶点的实例化);传入观测值;配置信息矩阵;将边添加至图。

四、执行优化

// 第四部分;执行优化cout << "start optimization" << endl;//开始优化optimizer.initializeOptimization();//优化次数optimizer.optimize(10);// 输出优化值Eigen::Vector3d abc_estimate = v->estimate();

优化器初始化;配置优化次数(10);获取优化变量。

3、ax^2+bx+c实现

为了加深理解实现函数ax2+bx+c函数参数abc的优化估计:

一、程序:

//G2O求解最小二乘
#include <iostream>
#include <g2o/core/g2o_core_api.h>
#include <g2o/core/base_vertex.h>
#include <g2o/core/base_unary_edge.h>
#include <g2o/core/block_solver.h>
#include <g2o/core/optimization_algorithm_levenberg.h>
#include <g2o/core/optimization_algorithm_gauss_newton.h>
#include <g2o/core/optimization_algorithm_dogleg.h>
#include <g2o/solvers/dense/linear_solver_dense.h>
#include <Eigen/Core>
#include <opencv2/core/core.hpp>
#include <cmath>using namespace std;
//第一部分;定义顶点和边的类型,先定义顶点后定义边,边是依赖于顶点存在的
// 曲线模型的顶点,模板参数:优化变量维度和数据类型
class CurveFittingVertex : public g2o::BaseVertex<3, Eigen::Vector3d> {
public://类成员变量如果是固定大小对象需要加上 EIGEN_MAKE_ALIGNED_OPERATOR_NEWEIGEN_MAKE_ALIGNED_OPERATOR_NEW// 重置;override 重载 virtual void setToOriginImpl() override{_estimate << 0, 0, 0;}// 更新virtual void oplusImpl(const double *update) override{_estimate += Eigen::Vector3d(update);}// 存盘和读盘:留空,暂时不用virtual bool read(istream &in) {}virtual bool write(ostream &out) const {}
};// 误差模型 模板参数:观测值维度,类型,连接顶点类型
class CurveFittingEdge : public g2o::BaseUnaryEdge<1, double, CurveFittingVertex> {
public://类成员变量如果是固定大小对象需要加上 EIGEN_MAKE_ALIGNED_OPERATOR_NEWEIGEN_MAKE_ALIGNED_OPERATOR_NEW//构造函数初始化CurveFittingEdge(double x) : BaseUnaryEdge(), _x(x) {}// 计算曲线模型误差virtual void computeError() override{//顶点获取const CurveFittingVertex *v = static_cast<const CurveFittingVertex *> (_vertices[0]);//优化变量获取const Eigen::Vector3d abc = v->estimate();//惨差计算_error(0, 0) = _measurement - (abc(0, 0) * _x * _x + abc(1, 0) * _x + abc(2, 0));}// 计算雅可比矩阵virtual void linearizeOplus() override{//顶点获取const CurveFittingVertex *v = static_cast<const CurveFittingVertex *> (_vertices[0]);//优化变量获取const Eigen::Vector3d abc = v->estimate();//数值求导double y = (abc[0] * _x * _x + abc[1] * _x + abc[2]);_jacobianOplusXi[0] = -_x * _x;_jacobianOplusXi[1] = -_x;_jacobianOplusXi[2] = -1;}//读写,暂时不用,留空virtual bool read(istream &in) {}virtual bool write(ostream &out) const {}private:double _x;  // x 值, y 值为 _measurement
};int main(int argc, char **argv)
{//进行数据准备double areal = 1.0, breal = 2.0, creal = 1.0;         // 真实参数值double aest = 2.0, best = -1.0, cest = 5.0;        // 估计参数值int PointNum = 100;                                 // 数据点double w_sigma = 1.0;                        // 噪声Sigma值double inv_sigma = 1.0 / w_sigma;cv::RNG rng;                                 // OpenCV随机数产生器// 迭代数据存储vector<double> x_data, y_data;for (int i = 0; i < PointNum; i++) {double x = i / 100.0;x_data.push_back(x);y_data.push_back((areal * x * x + breal * x + creal) + rng.gaussian(w_sigma * w_sigma));}// 第二部分: 构建图优化,配置求解器// 定义重载求解变量块,每个误差项优化变量维度为3,误差值维度为1typedef g2o::BlockSolver<g2o::BlockSolverTraits<3, 1>> BlockSolverType;// 定义线性求解器类型typedef g2o::LinearSolverDense<BlockSolverType::PoseMatrixType> LinearSolverType;//创建高斯牛顿求解器auto solver = new g2o::OptimizationAlgorithmGaussNewton(g2o::make_unique<BlockSolverType>(g2o::make_unique<LinearSolverType>()));// 图模型g2o::SparseOptimizer optimizer;// 设置求解器optimizer.setAlgorithm(solver);// 打开调试输出optimizer.setVerbose(true);// 第三部分: 添加点和边,构架求解图// 实例化顶点,往图中增加顶点CurveFittingVertex *v = new CurveFittingVertex();//配置初始估计值v->setEstimate(Eigen::Vector3d(aest, best, cest));//设置图表中节点的id确保更改id后图表保持一致v->setId(0);//添加设置完成的顶点optimizer.addVertex(v);// 往图中增加边for (int i = 0; i < PointNum; i++){//实例化边,并传入标点值CurveFittingEdge *edge = new CurveFittingEdge(x_data[i]);//设置图表中边的id确保更改id后图表保持一致edge->setId(i);// 设置连接的顶点,1、顶点编号2、顶点实例化edge->setVertex(0, v);// 传入观测到的数值edge->setMeasurement(y_data[i]);// 设置信息矩阵:协方差矩阵之逆edge->setInformation(Eigen::Matrix<double, 1, 1>::Identity() * 1 / (w_sigma * w_sigma));//将设置完成的边加入optimizer.addEdge(edge);}// 第四部分;执行优化cout << "start optimization" << endl;//开始优化optimizer.initializeOptimization();//优化次数optimizer.optimize(10);// 输出优化值Eigen::Vector3d abc_estimate = v->estimate();cout << "真实值为: " << areal << " " << breal << " " << creal << endl;cout << "初始预测值为: " << aest << " " << best << " " << cest << endl;cout << "结果为: " << abc_estimate[0] << " " << abc_estimate[1] << " " << abc_estimate[2] << endl;return 0;
}

二、运行结果

start optimization
真实值为: 1 2 1
初始预测值为: 2 -1 5
结果为: 1.43205 2.18296 0.838242
iteration= 0 chi2= 102.023665 time= 2.8165e-05 cumTime= 2.8165e-05 edges= 100 schur= 0
iteration= 1 chi2= 102.023665 time= 2.1604e-05 cumTime= 4.9769e-05 edges= 100 schur= 0
iteration= 2 chi2= 102.023665 time= 1.0514e-05 cumTime= 6.0283e-05 edges= 100 schur= 0
iteration= 3 chi2= 102.023665 time= 1.8689e-05 cumTime= 7.8972e-05 edges= 100 schur= 0
iteration= 4 chi2= 102.023665 time= 1.6087e-05 cumTime= 9.5059e-05 edges= 100 schur= 0
iteration= 5 chi2= 102.023665 time= 1.5163e-05 cumTime= 0.000110222 edges= 100 schur= 0
iteration= 6 chi2= 102.023665 time= 6.993e-06 cumTime= 0.000117215 edges= 100 schur= 0
iteration= 7 chi2= 102.023665 time= 6.601e-06 cumTime= 0.000123816 edges= 100 schur= 0
iteration= 8 chi2= 102.023665 time= 6.617e-06 cumTime= 0.000130433 edges= 100 schur= 0
iteration= 9 chi2= 102.023665 time= 6.228e-06 cumTime= 0.000136661 edges= 100 schur= 0

Process finished with exit code 0

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

相关文章

  1. SQL算术运算、函数

    一、计算字段1、计算字段存储在数据库表中的数据一般不是应用程序所需要的格式,下面举几个例子。(1).需要显示公司名,同时还需要显示公司的地址,但这两个信息存储在不同的表列中。(2).城市和邮政编码存储在不同的列中(应该这样),但邮件标签打印程序需要把它们作为一个…...

    2024/4/24 9:56:30
  2. 从今天开始从零学python!

    从今天开始从零学python!...

    2024/4/24 9:56:26
  3. Docker启动提示:Cannot connect to the Docker daemon...

    执行docker image导入时,提示 “Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?” 执行docker ps时,提示 CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS 没有任何进程。 此时已…...

    2024/4/24 9:56:25
  4. Oracle 删除重复数据只留一条

    DELETE FROM Property WHERE PROPERTY_ID IN (SELECT PROPERTY_ID FROM PROPERTY GROUP BY PROPERTY_ID HAVING COUNT (PROPERTY_ID) > 1) AND ROWID NOT IN ( SELECT MIN (ROWID) FROM PROPERTY GROUP BY PROPERTY_ID HAVING COUNT (PROPERTY_ID) > 1);...

    2024/4/24 9:56:25
  5. python笔记---字符串、列表、元组、字典特点总结

    1、字符串:属于序列类型、有下标(且唯一) 可以进行切片操作,不能改变值。 str1=helloworld #取前半段,左边包含右边不包含 print(str1[:5]) #取后半段 print(str1[5:]) #取倒序 print(str1[::-1])2、列表:有序序列、有下标、可以存贮任何类型的数据,内容可以进行增删改查…...

    2024/4/24 9:56:23
  6. 前端总结100点-1-flex

    flex 学习资源 阮一峰的博客 http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html http://www.ruanyifeng.com/blog/2015/07/flex-examples.html 不自己敲敲,还是不靠谱 1、容器的属性 ~~~ // 1.1 主轴方向 flex-direction:row/row-reverse/column/column-reverse;(…...

    2024/4/24 9:56:22
  7. linux 学习 个人总结笔录(六)

    上文连接:linux 学习 个人总结笔录(五) 9.RPM包管理概念RPM是RedHat Package Manager (红帽软件包管理工具)的缩写。用来为Linux 安装或卸载软件程序。查询语法查询已安装的rpm列表 rpm -qa | grep xxps: -qa 就是queryAll-q 查询软件包是否安装-qi 查询软件包信息-qf 文件…...

    2024/4/24 9:56:28
  8. 高并发中的问题

    1.问题:假设系统中有5台设备,有多个进程需要使用2个设备,假定每个进程一次只能使用一台,则至多允许多少个进程来竞争这5个资源,而不会发生死锁?答案:哲学家就餐问题。系统中有N个并发进程,若规定每个进程需要申请R个某类资源,则当系统提供K=N*X(R-1)+1个同类资源时,无…...

    2024/4/24 9:56:21
  9. java的Override和Overload

    重写Override重写是子类对父类中允许访问的方法进行重新编写,返回值和形参都不改变。(外壳不变,核心重写)重写的好处是子类能够根据需要定义自己的行为,也就是说子类能够根据需要实现父类方法。重写方法不能抛出新的检查异常,或者比被重写方法申明更加宽泛的异常。 例如:…...

    2024/4/24 9:56:23
  10. leetcode算法题

    #coding: utf-8# 给定一个整数数组 nums 和一个目标值 target # 请你在该数组中找出和为目标值的那 两个 整数 # 并返回他们的数组下标。 # 你可以假设每种输入只会对应一个答案 # 但是,数组中同一个元素不能使用两遍。class Solution(object):def TwoSum(self, nums, target)…...

    2024/4/19 14:55:17
  11. 基于XMLHttpRequest简单封装网络请求

    基于XMLHttpRequest简单封装网络请求代码使用 没有时间加以说明,而且代码也还很粗糙,暂时先直接上代码,记录着,周末有空再升级代码并说明。 代码 let leAxios = {} leAxios.httpRequest = function (paramObj, sucFun, errFun, complete) {var xmlhttp = null;/** 关于XMLH…...

    2024/4/17 10:46:35
  12. 用vue写轮子的一些心得(八)——pager分页器组件

    需求分析支持传入当前页码参数并展示;支持页数过多的部分用省略号显示,并会动态变化;支持支持点击左右方向键切换页码;支持在只有一页的时候隐藏pager;方法实现1、pager外部组件传参定义:一共可传4个参数:total,页码条数current,当前页码current.sync,点击页码的curr…...

    2024/4/16 9:08:20
  13. 使用SVG做背景做一个有个性的播放器

    给大家分享一个使用SVG做背景的个性播放器,效果如下:当滚动鼠标时,爱心会放大,播放区域也会跟着放大。以下是代码实现,欢迎大家复制粘贴和收藏。<!DOCTYPE html> <html lang="en"><head><meta charset="UTF-8"><meta name…...

    2024/4/16 9:08:25
  14. 笛卡尔积算法 防抖 节流

    var arr = [[1,2,3], [a,b,c], [x,y]]// 笛卡尔积算法 商品sku生成 function calcDescartes(arr) {if (arr.length < 2 ) return arr.join()return arr.reduce((lastItem, currentItem) => {let res = []lastItem.forEach(x => {currentItem.forEach(y => {res.pu…...

    2024/4/24 9:56:20
  15. Java语言 在运行时,运行器上出现 乱七八槽看不懂字时

    e.g: 解决方法:在输入指令的时候 在 “javac”后面+“-encoding UTF-8”。完整版:javac encoding UTF-8 文件名.java...

    2024/4/24 9:56:17
  16. 悲观锁与乐观锁

    悲观锁总是假设最坏的情况,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会阻塞直到它拿到锁(共享资源每次只给一个线程使用,其它线程阻塞,用完后再把资源转让给其它线程)。传统的关系型数据库里边就用到了很多这种锁机制…...

    2024/4/24 9:56:23
  17. Docker小记-网络

    Docker的网络Docker使用操作系统的底层特性构建了一个特殊的、可定制的虚拟网络拓扑结构。这个虚拟网络只在安装有Docker的机器上有效,并并且它由主机上的容器和主机所连接的网络之间的路由构成。 本地虚拟网络用来提供容器的隔离,Docker使用内核命名空间来创建私有的虚拟接口…...

    2024/4/24 9:56:15
  18. 6月1日

    CSS(Cascading Style Sheets) 层叠样式表,又叫级联样式表,简称样式表(HTML承担页面结构,而CSS承担页面美化) 1.用于HTML文档中元素样式的定义 实现了将内容与表现分离 提高代码的可重用性和可维护性 2.文件后缀是.css CSS与HTML之间的关系 1.HTML用于构建网页的结构 2.C…...

    2024/4/24 9:56:14
  19. 数据结构3——链表

    文章目录线性结构离散存储(链表) 线性结构 离散存储(链表)专业术语首节点:链表的第一个有效节点 尾节点:最后一个有效节点 头结点:第一个有效节点之前的节点,头结点并不存放有效数据,主要是为了方便对链表的操作(头结点的数据类型和其他节点的数据类型一致)。 头指针…...

    2024/4/24 9:56:13
  20. 人生苦短,我用Python——爬虫系列入门指南(一、安装)

    一、IDE的选择和安装软件名称 特点IDLE python自带、支持300行以下Sublime Text 专业编程、调试一般Pycharm 简单方便SPYder 专业的科学计算和数据分析二、安装 PYTHON安装 记得添加到path里面 win10-python安装 python下载地址 requests库安装 Requestsg网址 管理员权限打开c…...

    2024/4/24 9:56:12

最新文章

  1. opencv基础篇 ——(七)边缘检测和图像锐化

    锐化和边缘检测是图像处理中常用的两种技术&#xff0c;它们可以用来增强图像的特征以及检测图像中的边缘 锐化&#xff1a; 锐化是一种增强图像中细节和边缘的技术&#xff0c;它使图像中的过渡区域更加明显&#xff0c;从而提高图像的清晰度和对比度。常见的锐化方法包括拉普…...

    2024/4/26 10:31:26
  2. 梯度消失和梯度爆炸的一些处理方法

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

    2024/3/20 10:50:27
  3. axios拦截器:每次请求自动带上 token

    Step 1&#xff1a;创建Axios实例并添加拦截器 在你的Vue项目中&#xff0c;一般我们会先导入axios&#xff0c;然后创建一个axios实例。这样做是为了方便统一管理和配置。 import axios from axios; // 引入axios// 创建一个axios实例 const service axios.create();// 添加请…...

    2024/4/22 20:45:57
  4. ChatGPT 赚钱初学者指南(上)

    原文&#xff1a;The Beginner’s Guide to Earning Money Online with ChatGPT 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 第一章&#xff1a;理解基础知识 什么是 ChatGPT&#xff1f; 在人工智能与人类对话相遇的数字织锦中&#xff0c;ChatGPT 作为一个突出…...

    2024/4/24 16:31:18
  5. 【外汇早评】美通胀数据走低,美元调整

    原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...

    2024/4/25 11:51:20
  6. 【原油贵金属周评】原油多头拥挤,价格调整

    原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...

    2024/4/25 18:39:24
  7. 【外汇周评】靓丽非农不及疲软通胀影响

    原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...

    2024/4/25 18:38:39
  8. 【原油贵金属早评】库存继续增加,油价收跌

    原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...

    2024/4/25 18:39:23
  9. 【外汇早评】日本央行会议纪要不改日元强势

    原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...

    2024/4/25 18:39:22
  10. 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响

    原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...

    2024/4/25 18:39:22
  11. 【外汇早评】美欲与伊朗重谈协议

    原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...

    2024/4/25 18:39:20
  12. 【原油贵金属早评】波动率飙升,市场情绪动荡

    原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...

    2024/4/25 16:48:44
  13. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

    原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...

    2024/4/25 13:39:44
  14. 【原油贵金属早评】市场情绪继续恶化,黄金上破

    原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...

    2024/4/25 18:39:16
  15. 【外汇早评】美伊僵持,风险情绪继续升温

    原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...

    2024/4/25 18:39:16
  16. 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势

    原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...

    2024/4/25 0:00:17
  17. 氧生福地 玩美北湖(上)——为时光守候两千年

    原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...

    2024/4/25 4:19:21
  18. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

    原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...

    2024/4/25 18:39:14
  19. 氧生福地 玩美北湖(下)——奔跑吧骚年!

    原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...

    2024/4/25 18:39:12
  20. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

    原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...

    2024/4/25 2:10:52
  21. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

    原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...

    2024/4/25 18:39:00
  22. 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者

    原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...

    2024/4/25 13:19:01
  23. 广州械字号面膜生产厂家OEM/ODM4项须知!

    原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...

    2024/4/25 18:38:58
  24. 械字号医用眼膜缓解用眼过度到底有无作用?

    原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...

    2024/4/25 18:38:57
  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