PrepRequestProcessor

1.从待处理请求队列取出一个请求
2.如果是requestOfDeath退出
3.置空请求对象的事务头,事务体。
4.请求未被过滤下,执行pRequestHelper
5.将请求交给下一级处理

pRequestHelper

对写请求设置
对请求进行合法性检查
按请求内容预先更新节点状态信息
为请求对象设置事务头,事务体,事务摘要

对请求处理中遭遇错误的,采用抛出异常方式
对错误的写请求,其事务头,事务体包含错误及错误信息,
对错误的请求,请求本身包含抛出异常信息。

如果请求类型为OpCode.createContainer/OpCode.create/OpCode.create2
动态创建CreateRequest对象
//基于原始请求对象,
//对请求进行合法性检查,
//预先对按请求进行节点更新&数据访问,
//设置好请求对象的事务头,事务体,事务摘要
pRequest2Txn(request.type, zks.getNextZxid(), request, create2Request, true);
如果请求类型为OpCode.createTTLCreateTTLRequest createTtlRequest = new CreateTTLRequest();pRequest2Txn(request.type, zks.getNextZxid(), request, createTtlRequest, true);
如果请求类型为OpCode.deleteContainer/OpCode.deleteDeleteRequest deleteRequest = new DeleteRequest();pRequest2Txn(request.type, zks.getNextZxid(), request, deleteRequest, true);
如果请求类型为OpCode.setDataSetDataRequest setDataRequest = new SetDataRequest();pRequest2Txn(request.type, zks.getNextZxid(), request, setDataRequest, true);
如果请求类型为OpCode.reconfigReconfigRequest reconfigRequest = new ReconfigRequest();ByteBufferInputStream.byteBuffer2Record(request.request, reconfigRequest);pRequest2Txn(request.type, zks.getNextZxid(), request, reconfigRequest, true);
如果请求类型为OpCode.setACLSetACLRequest setAclRequest = new SetACLRequest();pRequest2Txn(request.type, zks.getNextZxid(), request, setAclRequest, true);
如果请求类型为OpCode.checkCheckVersionRequest checkRequest = new CheckVersionRequest();pRequest2Txn(request.type, zks.getNextZxid(), request, checkRequest, true);
如果请求类型为OpCode.multi// 动态构造多操作请求,请求实体MultiOperationRecord multiRequest = new MultiOperationRecord();// 反向序列化得到数据实体try {ByteBufferInputStream.byteBuffer2Record(request.request, multiRequest);} catch (IOException e) {// 抛出异常时,仍然设置事务头request.setHdr(new TxnHeader(request.sessionId, request.cxid, zks.getNextZxid(), Time.currentWallTime(), OpCode.multi));// 再次抛出throw e;}// 事务容器List<Txn> txns = new ArrayList<Txn>();// 获取下一zxidlong zxid = zks.getNextZxid();KeeperException ke = null;// 获取每个子操作&最新状态信息,子操作父节点&最新状态信息Map<String, ChangeRecord> pendingChanges = getPendingChanges(multiRequest);// 设置请求的事务头request.setHdr(new TxnHeader(request.sessionId, request.cxid, zxid, Time.currentWallTime(), request.type));// 对每个子操作逐个处理for (Op op : multiRequest) {// 子操作的,请求实体Record subrequest = op.toRequestRecord();int type;Record txn;// 表示之前某个子操作遭遇异常if (ke != null) {// 设置类别type = OpCode.error;// 设置事务体txn = new ErrorTxn(Code.RUNTIMEINCONSISTENCY.intValue());} else {try {//基于原始请求对象,//对请求进行合法性检查,//预先对按请求进行节点更新&数据访问,//设置好请求对象的事务头,事务体,事务摘要pRequest2Txn(op.getType(), zxid, request, subrequest, false);// 子操作类别type = op.getType();// 获得事务体txn = request.getTxn();} // 如果子操作在于异常catch (KeeperException e) {// 异常记录ke = e;// 类别记录type = OpCode.error;// 用于记录失败的事务体txn = new ErrorTxn(e.code().intValue());if (e.code().intValue() > Code.APIERROR.intValue()) {LOG.info("Got user-level KeeperException when processing {} aborting" + " remaining multi ops. Error Path:{} Error:{}", + request.toString(), e.getPath(), e.getMessage());}// 将异常信息设置到请求对象request.setException(e);// 一旦一个子操作遭遇异常,执行回滚// 回滚需要保证复合操作每个子操作对ChangeRecord的影响撤销。// 把ChangeRecord恢复到执行复合操作前rollbackPendingChanges(zxid, pendingChanges);}}try (ByteArrayOutputStream baos = new ByteArrayOutputStream()) {BinaryOutputArchive boa = BinaryOutputArchive.getArchive(baos);// 事务体对象序列化txn.serialize(boa, "request");ByteBuffer bb = ByteBuffer.wrap(baos.toByteArray());// 存储到Txn对象集合txns.add(new Txn(type, bb.array()));}}// 复合请求的事务体,也包含多个Txn分别对应每个子操作request.setTxn(new MultiTxn(txns));if (digestEnabled) {// 设置事务摘要 setTxnDigest(request);}}
如果请求类型为OpCode.createSession/OpCode.closeSession// 本地会话不需追踪?if (!request.isLocalSession()) {pRequest2Txn(request.type, zks.getNextZxid(), request, null, true);}
如果请求类型为OpCode.sync/OpCode.exists/OpCode.getData/OpCode.getACLOpCode.getChildren/OpCode.getAllChildrenNumber/OpCode.getChildren2/OpCode.pingOpCode.setWatches/OpCode.setWatches2/OpCode.checkWatches/OpCode.removeWatchesOpCode.getEphemerals/OpCode.multiRead/OpCode.addWatch/OpCode.addWatch// 会话检查// 只读请求不需要zks.sessionTracker.checkSession(request.sessionId, request.getOwner());				

pRequest2TxnCreate(type, request, record, deserialize);

// 做新建节点前的合法性,权限,配额检查
// 一切合法下,更新父节点,新建节点状态信息。
// 设置好本请求对象的事务头,事务体,事务摘要信息

if (deserialize) 
{// 从字节流得到数据对象ByteBufferInputStream.byteBuffer2Record(request.request, record);
}// 从数据对象提取信息
if (type == OpCode.createTTL) 
{CreateTTLRequest createTtlRequest = (CreateTTLRequest) record;flags = createTtlRequest.getFlags();path = createTtlRequest.getPath();acl = createTtlRequest.getAcl();data = createTtlRequest.getData();ttl = createTtlRequest.getTtl();
} 
else 
{CreateRequest createRequest = (CreateRequest) record;flags = createRequest.getFlags();path = createRequest.getPath();acl = createRequest.getAcl();data = createRequest.getData();ttl = -1;
}CreateMode createMode = CreateMode.fromFlag(flags);
// 合法性验证,不合法通过抛出特定类型包含特定信息异常来层层回退
validateCreateRequest(path, createMode, request, ttl);
// 父路径
String parentPath = validatePathForCreate(path, request.sessionId);
// 权限
List<ACL> listACL = fixupACL(path, request.authInfo, acl);
// 父亲路径最新状态
ChangeRecord parentRecord = getRecordForPath(parentPath);
// 权限检查
zks.checkACL(request.cnxn, parentRecord.acl, ZooDefs.Perms.CREATE, request.authInfo, path, listACL);
// 父亲路径下遭遇改变次数
int parentCVersion = parentRecord.stat.getCversion();
// 新节点完整路径
if (createMode.isSequential()) 
{path = path + String.format(Locale.ENGLISH, "%010d", parentCVersion);
}// 验证路径合法性
validatePath(path, request.sessionId);
try 
{// 如果要创建的路径已经存在了if (getRecordForPath(path) != null) {// 抛出特定类型,包含特定信息的异常throw new KeeperException.NodeExistsException(path);}
} 
catch (KeeperException.NoNodeException e) 
{
}boolean ephemeralParent = EphemeralType.get(parentRecord.stat.getEphemeralOwner()) == EphemeralType.NORMAL;
// 这类父路径不可包含子节点 
if (ephemeralParent) 
{throw new KeeperException.NoChildrenForEphemeralsException(path);
}// 更新父节点遭遇变化次数
int newCversion = parentRecord.stat.getCversion() + 1;
// 检查配额限制,配额限制超出时,通过抛出特定类型,包含特定信息的异常来层层退出
zks.checkQuota(path, null, data, OpCode.create);
// 设置事务体
if (type == OpCode.createContainer) 
{request.setTxn(new CreateContainerTxn(path, data, listACL, newCversion));
} 
else if (type == OpCode.createTTL) 
{request.setTxn(new CreateTTLTxn(path, data, listACL, newCversion, ttl));
} 
else 
{request.setTxn(new CreateTxn(path, data, listACL, createMode.isEphemeral(), newCversion));
}TxnHeader hdr = request.getHdr();
long ephemeralOwner = 0;
// 创建模式--创建容器节点
if (createMode.isContainer()) 
{ephemeralOwner = EphemeralType.CONTAINER_EPHEMERAL_OWNER;
} 
// 创建模式--创建自带生命期节点
else if (createMode.isTTL()) 
{ephemeralOwner = EphemeralType.TTL.toEphemeralOwner(ttl);
} 
// 创建模式--创建临时节点【会话关闭,会话所属临时节点自动销毁】
else if (createMode.isEphemeral()) 
{ephemeralOwner = request.sessionId;
}// 创建节点状态
StatPersisted s = DataTree.createStat(hdr.getZxid(), hdr.getTime(), ephemeralOwner);
// 基于原有父节点的parentRecord得到新的
parentRecord = parentRecord.duplicate(request.getHdr().getZxid());
parentRecord.childCount++;
// 记录了此节点下孩子累计新增孩子数量-变化为节点孩子变化
parentRecord.stat.setCversion(newCversion);
// 记录了最后修改此节点状态的事务id
parentRecord.stat.setPzxid(request.getHdr().getZxid());
// 更新整体和节点自身摘要信息
parentRecord.precalculatedDigest = precalculateDigest(DigestOpCode.UPDATE, parentPath, parentRecord.data, parentRecord.stat);
addChangeRecord(parentRecord);
// 一个节点可能包含多个关联项
zks.outstandingChanges.add(c);
// 一个节点,只有一个路径,也就只记录一个关联项,反映此节点最新状态
zks.outstandingChangesForPath.put(c.path, c);
// 反映新建节点
ChangeRecord nodeRecord = new ChangeRecord(request.getHdr().getZxid(), path, s, 0, listACL);
nodeRecord.data = data;
nodeRecord.precalculatedDigest = precalculateDigest(DigestOpCode.ADD, path, nodeRecord.data, s);
setTxnDigest(request, nodeRecord.precalculatedDigest);
request.setTxnDigest(new TxnDigest(digestCalculator.getDigestVersion(), preCalculatedDigest.treeDigest));
addChangeRecord(nodeRecord);

pRequest2Txn(request.type, zks.getNextZxid(), request, create2Request, true);

基于原始请求对象,
对请求进行合法性检查,
预先对按请求进行节点更新&数据访问,
设置好请求对象的事务头,事务体,事务摘要

如果请求对象事务头为nullrequest.setHdr(new TxnHeader(request.sessionId, request.cxid, zxid, Time.currentWallTime(), type));如果类别为OpCode.create/OpCode.create2/OpCode.createTTL/OpCode.createContainer// 做新建节点前的合法性,权限,配额检查// 一切合法下,更新父节点,新建节点状态信息。// 设置好本请求对象的事务头,事务体,事务摘要信息pRequest2TxnCreate(type, request, record, deserialize);如果类别为OpCode.deleteContainerString path = new String(request.request.array(), UTF_8);// 获取父路径,及验证路径String parentPath = getParentPathAndValidate(path);// 获取删除路径最新信息ChangeRecord nodeRecord = getRecordForPath(path);// 如果删除节点包含子节点,不可删除if (nodeRecord.childCount > 0) {throw new KeeperException.NotEmptyException(path);}// 要删除节点类别非法if (EphemeralType.get(nodeRecord.stat.getEphemeralOwner()) == EphemeralType.NORMAL) {throw new KeeperException.BadVersionException(path);}// 获取父节点最新状态ChangeRecord parentRecord = getRecordForPath(parentPath);// 设置改请求的事务体request.setTxn(new DeleteTxn(path));// 基于parentRecord得到新的parentRecord = parentRecord.duplicate(request.getHdr().getZxid());parentRecord.childCount--;parentRecord.stat.setPzxid(request.getHdr().getZxid());parentRecord.precalculatedDigest = precalculateDigest(DigestOpCode.UPDATE, parentPath, parentRecord.data, parentRecord.stat);// 完成对父节点最新状态的更新addChangeRecord(parentRecord);// 对删除节点,设置改节点ChangeRecord// 通过改ChangeRecord可辨别节点已被删除nodeRecord = new ChangeRecord(request.getHdr().getZxid(), path, null, -1, null);// 更新摘要信息nodeRecord.precalculatedDigest = precalculateDigest(DigestOpCode.REMOVE, path);// 设置事务摘要setTxnDigest(request, nodeRecord.precalculatedDigest);// 完成对删除节点的状态更新addChangeRecord(nodeRecord);如果类别为OpCode.delete// 会话检查zks.sessionTracker.checkSession(request.sessionId, request.getOwner());DeleteRequest deleteRequest = (DeleteRequest) record;// 反向序列化得到数据实体if (deserialize) {ByteBufferInputStream.byteBuffer2Record(request.request, deleteRequest);}// 要删除路径String path = deleteRequest.getPath();// 要删除路径父路径String parentPath = getParentPathAndValidate(path);// 父路径最新状态ChangeRecord parentRecord = getRecordForPath(parentPath);// 权限检查zks.checkACL(request.cnxn, parentRecord.acl, ZooDefs.Perms.DELETE, request.authInfo, path, null);// 要删除路径自身// 路径不存在时,通过设置异常类型,异常信息,层层退出ChangeRecord nodeRecord = getRecordForPath(path);// 版本检查checkAndIncVersion(nodeRecord.stat.getVersion(), deleteRequest.getVersion(), path);// 有孩子的节点不可被删除if (nodeRecord.childCount > 0) {throw new KeeperException.NotEmptyException(path);}// 设置事务体request.setTxn(new DeleteTxn(path));// 基于parentRecord得到新的parentRecord = parentRecord.duplicate(request.getHdr().getZxid());// 更新父节点最新状态信息// 状态--孩子数量parentRecord.childCount--;// 状态--最后对其修改的事务的idparentRecord.stat.setPzxid(request.getHdr().getZxid());// 更新摘要parentRecord.precalculatedDigest = precalculateDigest(DigestOpCode.UPDATE, parentPath, parentRecord.data, parentRecord.stat);addChangeRecord(parentRecord);// 为要删除节点,动态构造ChangeRecordnodeRecord = new ChangeRecord(request.getHdr().getZxid(), path, null, -1, null);// 更新摘要nodeRecord.precalculatedDigest = precalculateDigest(DigestOpCode.REMOVE, path);// 设置事务摘要setTxnDigest(request, nodeRecord.precalculatedDigest);addChangeRecord(nodeRecord);如果类别为OpCode.setData// 检查会话zks.sessionTracker.checkSession(request.sessionId, request.getOwner());// 事务体SetDataRequest setDataRequest = (SetDataRequest) record;// 反向序列化得到数据对象if (deserialize) {ByteBufferInputStream.byteBuffer2Record(request.request, setDataRequest);}// 路径path = setDataRequest.getPath();// 验证路径合法性validatePath(path, request.sessionId);// 获取此路径最新信息nodeRecord = getRecordForPath(path);// 权限检查zks.checkACL(request.cnxn, nodeRecord.acl, ZooDefs.Perms.WRITE, request.authInfo, path, null);// 配额检查zks.checkQuota(path, nodeRecord.data, setDataRequest.getData(), OpCode.setData);// 版本检查int newVersion = checkAndIncVersion(nodeRecord.stat.getVersion(), setDataRequest.getVersion(), path);// 设置事务体request.setTxn(new SetDataTxn(path, setDataRequest.getData(), newVersion));// 基于nodeRecode得到新的nodeRecord = nodeRecord.duplicate(request.getHdr().getZxid());// 新的相比旧的,版本变了nodeRecord.stat.setVersion(newVersion);// 修改时间变了nodeRecord.stat.setMtime(request.getHdr().getTime());// 最后修改的事务id变了nodeRecord.stat.setMzxid(zxid);// 节点数据内容变了nodeRecord.data = setDataRequest.getData();// 更新摘要nodeRecord.precalculatedDigest = precalculateDigest(DigestOpCode.UPDATE, path, nodeRecord.data, nodeRecord.stat);// 设置事务摘要setTxnDigest(request, nodeRecord.precalculatedDigest);addChangeRecord(nodeRecord);如果类别为OpCode.setACL// 检查会话zks.sessionTracker.checkSession(request.sessionId, request.getOwner());// 事务体SetACLRequest setAclRequest = (SetACLRequest) record;// 反向序列化得到数据对象if (deserialize) {ByteBufferInputStream.byteBuffer2Record(request.request, setAclRequest);}// 路径path = setAclRequest.getPath();// 验证路径validatePath(path, request.sessionId);// 权限列表List<ACL> listACL = fixupACL(path, request.authInfo, setAclRequest.getAcl());// 路径最新状态nodeRecord = getRecordForPath(path);// 权限检查zks.checkACL(request.cnxn, nodeRecord.acl, ZooDefs.Perms.ADMIN, request.authInfo, path, listACL);// 版本检查newVersion = checkAndIncVersion(nodeRecord.stat.getAversion(), setAclRequest.getVersion(), path);// 设置事务体request.setTxn(new SetACLTxn(path, listACL, newVersion));// 基于nodeRecord得到新的nodeRecord = nodeRecord.duplicate(request.getHdr().getZxid());// 设置新的版本nodeRecord.stat.setAversion(newVersion);// 更新摘要信息nodeRecord.precalculatedDigest = precalculateDigest(DigestOpCode.UPDATE, path, nodeRecord.data, nodeRecord.stat);// 设置事务摘要setTxnDigest(request, nodeRecord.precalculatedDigest);addChangeRecord(nodeRecord);如果类型为OpCode.createSessionrequest.request.rewind();// 获取超时时间?int to = request.request.getInt();// 设置事务体request.setTxn(new CreateSessionTxn(to));request.request.rewind();// 会话追踪zks.sessionTracker.trackSession(request.sessionId, to);// 会话拥有者,为请求拥有者zks.setOwner(request.sessionId, request.getOwner());如果类型为OpCode.closeSession// 当前时间long startTime = Time.currentElapsedTime();synchronized (zks.outstandingChanges) {// 获取属于此会话的所有临时节点Set<String> es = zks.getZKDatabase().getEphemerals(request.sessionId);// 对所有排队中ChangeRecordfor (ChangeRecord c : zks.outstandingChanges) {// 表示待实施请求中,已经包含删除某路径请求if (c.stat == null) {// 将此会话下已经规划为删除的路径从这里的临时节点中去掉,避免重复删除es.remove(c.path);} // 表示待实施请求中,包含某个路径属于此临时会话else if (c.stat.getEphemeralOwner() == request.sessionId) {// 将改路径加入这里的临时节点。放置漏掉属于此会话的待实施的临时节点。es.add(c.path);}}// 对此会话的每个临时节点,对其父节点进行更新for (String path2Delete : es) {if (digestEnabled) {// 获取删除节点,父节点&验证parentPath = getParentPathAndValidate(path2Delete);// 获取父节点最新状态parentRecord = getRecordForPath(parentPath);// 基于parentRecord得到新的parentRecord = parentRecord.duplicate(request.getHdr().getZxid());// 更新修改父节点孩子的事务idparentRecord.stat.setPzxid(request.getHdr().getZxid());// 更新摘要parentRecord.precalculatedDigest = precalculateDigest(DigestOpCode.UPDATE, parentPath, parentRecord.data, parentRecord.stat);addChangeRecord(parentRecord);}// 动态构造要删除节点的nodeRecordnodeRecord = new ChangeRecord(request.getHdr().getZxid(), path2Delete, null, 0, null);// 更新摘要nodeRecord.precalculatedDigest = precalculateDigest(DigestOpCode.REMOVE, path2Delete);addChangeRecord(nodeRecord);}if (ZooKeeperServer.isCloseSessionTxnEnabled()) {// 设置事务体request.setTxn(new CloseSessionTxn(new ArrayList<String>(es)));}// 设置会话状态为关闭中zks.sessionTracker.setSessionClosing(request.sessionId);}ServerMetrics.getMetrics().CLOSE_SESSION_PREP_TIME.add(Time.currentElapsedTime() - startTime);如果类型为OpCode.check// 会话检查zks.sessionTracker.checkSession(request.sessionId, request.getOwner());CheckVersionRequest checkVersionRequest = (CheckVersionRequest) record;// 反向序列化得到数据实体if (deserialize) {ByteBufferInputStream.byteBuffer2Record(request.request, checkVersionRequest);}// 获取路径path = checkVersionRequest.getPath();// 验证路径validatePath(path, request.sessionId);// 获取路径最新信息nodeRecord = getRecordForPath(path);// 权限检查zks.checkACL(request.cnxn, nodeRecord.acl, ZooDefs.Perms.READ, request.authInfo, path, null);// 设置事务体request.setTxn(new CheckVersionTxn(path, checkAndIncVersion(nodeRecord.stat.getVersion(), checkVersionRequest.getVersion(), null));
查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. HTML标签:框架

    框架&#xff0c;可以在同一个浏览器窗口中显示不止一个页面。 <!DOCType html> <html><head> <meta charset"utf-8"><title>框架</title> </head><body> <iframe src"test1.html" name"…...

    2024/4/28 11:48:22
  2. pytorch进阶学习(每日一更)day05--循环神经网络的实现

    Recurrent Neural Network 一个简单的RNN的实现 架构&#xff1a; 主要有3层;详见代码 class ConvNet(nn.Module):def __init__(self,num_classes):super(ConvNet,self).__init__()#定义层结构(3大层)#layer1self.layer1nn.Sequential(#kernel_size就是卷积核大小这里的5代…...

    2024/4/28 2:00:17
  3. 操作系统实验报告 实验1 VMware虚拟机配置与linux基本命令(答案全)

    实验1 VMware虚拟机配置与linux基本命令&#xff08;1&#xff09; 实验目的&#xff08;2&#xff09; 实验要求&#xff1a;&#xff08;3&#xff09; 实验步骤1.1 Linux Ubuntu的安装、创建新的虚拟机VMWare实验1.2 linux系统基本命令&#xff08;1&#xff09; 实验目的 …...

    2024/4/28 13:15:24
  4. linux 安装android studio之后没有快捷方式

    通过studio.sh 打开AS 进入项目&#xff0c;点击tools 之后点击 create desktop entry...

    2024/4/15 14:26:09
  5. Leetcode.0143 | 重排链表

    题目 给定一个单链表 L 的头节点 head &#xff0c;单链表 L 表示为&#xff1a; L0 → L1 → … → Ln - 1 → Ln 请将其重新排列后变为&#xff1a; L0 → Ln → L1 → Ln - 1 → L2 → Ln - 2 → … 不能只是单纯的改变节点内部的值&#xff0c;而是需要实际的进行节点交换…...

    2024/4/28 2:39:38
  6. 如果要将整钱换成零钱, 那么元钱可兑换成1角、 两角或五角, 问有多少种兑换方案

    #include<stdio.h> int main() { int i, j, k, cnt 0; for (i 0; i < 10; i ) for (j 0; j < 10; j 2) for (k 0; k < 10; k 5) if (i j k 10) cnt ; printf("%d\n", cnt); return 0; }...

    2024/4/28 5:21:12
  7. LeetCode——2029.石子游戏

    大佬&#xff0c;牛&#xff01;&#xff01;&#xff01; 题目&#xff1a;字符串只有a、b两个字母构成&#xff0c;每次删除操作可以从这里面删除一个回文子序列。直到全部删除&#xff0c;问需要最少删除多少次。思路&#xff0c;我本以为这个子序列必须是连续的&#xff0…...

    2024/4/28 4:34:18
  8. Spring学习笔记——Spring集成junit

    一、Spring集成Junit步骤 导入Spring集成Junit的坐标 <dependency><groupId>org.springframework</groupId><artifactId>spring-test</artifactId><version>5.0.5.RELEASE</version></dependency>注意事项&#xff1a;spring…...

    2024/4/7 15:50:22
  9. 键盘输入一个整数(int),将整数在内存中的存放形式(32位二进制)循环右移n位

    首先要知道整型数据在内存中是以32位二进制补码形式存放的 &#xff0c;这种编程题的思想就是先将这个整数的后面的n个bit位取出来&#xff0c;然后补到前面去。 从键盘获取一个整数num int num,n; printf("请输入num和n的值&#xff1a;"); scanf("%d%d",…...

    2024/4/14 8:56:17
  10. 一键解决端口号占用 Address/Port already in use

    存在问题: 在软件测试, 运行过程中难免碰到端口号被占用的情况, 我们需要查看占用端口的进程, 并进行相应处理 Address already in use Port already in use 解决方法: 1.查找当前使用该端口号的进程 netstat -ano | findstr 8080 # -a 显示所有连接和侦听端口 # -n 以数…...

    2024/4/19 14:03:51
  11. jvm垃圾回收器详解

    【Java虚拟机】七大垃圾回收器详解&#xff08;优缺点&#xff0c;适用场景...

    2024/4/5 4:34:00
  12. 寒假翻译五

    题目五 E. Black and White Tree 原题链接&#xff1a;https://codeforces.com/problemset/problem/1626/E 题目翻译&#xff1a; 你会得到一棵树由n个顶点数组成。一些顶点&#xff08;至少两个&#xff09;是黑色的&#xff0c;其他都是白色的。你在树的其中一个顶点上放…...

    2024/4/13 22:38:25
  13. OpenCV基础2.0(C++)

    图像基本操作&#xff08;2&#xff09; 读取像素 // 读取一个GRAY像素点的像素值&#xff08; CV_8UC1&#xff09;Scalar intensity img.at<ychar>(y,x);// 读取一个RGB像素点的像素值Vec3f intensity img.at<Vec3f>(y,x); float blue intensity.val[0]; fl…...

    2024/4/28 1:29:29
  14. 和为S的序列

    题目描述 输入一个正整数 target &#xff0c;输出所有和为 target 的连续正整数序列&#xff08;至少含有两个数&#xff09;。 序列内的数字由小到大排列&#xff0c;不同序列按照首个数字从小到大排列。 示例 1&#xff1a; 输入&#xff1a;target 9 输出&#xff1a;[[…...

    2024/4/14 8:55:47
  15. 指针和数组笔试题解析(一)(超详解)

    目录 1.一维数组 2.字符数组 (1)以{ }初始化的字符数组 2.以“ ”初始化的字符数组 3.用字符指针进行初始化 2.二维数组 写在最后&#xff1a; 上节回顾&#xff1a; 1.sizeof(数组名)&#xff0c;这里的数组名表示整个数组&#xff0c;计算的是整个数组的大小。 2.&数组…...

    2024/4/28 10:30:18
  16. 实例050最大公约数和最小公倍数

    #include<stdio.h> main() { int a,b,i,t,k; printf("输入两个数a>1,b>1\n"); scanf("%d %d",&a,&b); if(a>b) { ta;ab;bt; } for(i1;i<a;i) if(a%i0&&b%i0) ki; printf("%d",k); }...

    2024/4/18 9:36:52
  17. 【蓝桥杯python组】【2021年第十二届省赛填空题】【2】

    文章目录货物摆放最短路径问题回路计数货物摆放 1、小蓝有一个超大的仓库&#xff0c;可以摆放很多货物。现在&#xff0c;小蓝有 nn 箱货物要摆放在仓库&#xff0c;每箱货物都是规则的正方体。小蓝规定了长、宽、高三个互相垂直的方向&#xff0c;每箱货物的边都必须严格平行…...

    2024/4/27 20:43:52
  18. 小程序常用api

    1、获取系统信息 wx.getSystemInfo(Object object) 参考链接&#xff1a;https://developers.weixin.qq.com/miniprogram/dev/api/base/system/wx.getSystemInfo.html 2、获取微信APP授权设置 Object wx.getAppAuthorizeSetting() 参考链接&#xff1a;https://developers.weix…...

    2024/4/14 8:55:57
  19. 统计各种字符个数

    ...

    2024/4/28 6:19:15
  20. spark处理hudi增量数据并进行聚合操作———附带详细思路和代码

    文章目录1 背景2 方法3 代码3.1 法13.2 法23.3 法31 背景 因为如果每次都对全量数据进行聚合操作&#xff0c;将是非常耗费时间的一件事&#xff0c;但是如果我们只处理与增量数据相关的数据&#xff0c;那处理的数据量将大大减少&#xff0c;程序运行的处理时间将会大大缩短。…...

    2024/4/28 4:01:02

最新文章

  1. 41. 【Android教程】Android 手势处理

    作为忠实的 Android 系统用户&#xff0c;你应该会经常用到各种手势&#xff1a;点击、长按、双击、缩放、滑动、拖拽、返回等等&#xff0c;可以说丰富的手势可以让用户更加简洁方便的使用 App&#xff0c;甚至直接影响到 App 的使用体验。这些手势都是系统为我们提供的操作方…...

    2024/4/28 14:25:56
  2. 梯度消失和梯度爆炸的一些处理方法

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

    2024/3/20 10:50:27
  3. Linux mount用法

    在Linux系统中&#xff0c;系统自动挂载了以下挂载点&#xff1a; /: xfs文件系统&#xff0c;根文件系统, 所有其他文件系统的挂载点。 /sys: sysfs文件系统&#xff0c;提供内核对象的信息和接口。 /proc: proc文件系统&#xff0c;提供进程和系统信息。 /dev: devtmpfs文件系…...

    2024/4/24 0:39:01
  4. c++类的继承方式

    在 C 中&#xff0c;类的继承方式有三种&#xff1a;公有继承&#xff08;public inheritance&#xff09;、保护继承&#xff08;protected inheritance&#xff09;和私有继承&#xff08;private inheritance&#xff09;。这些继承方式决定了派生类对基类成员的访问权限。 …...

    2024/4/28 2:41:43
  5. 【外汇早评】美通胀数据走低,美元调整

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

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

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

    2024/4/28 3:28:32
  7. 【外汇周评】靓丽非农不及疲软通胀影响

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

    2024/4/26 23:05:52
  8. 【原油贵金属早评】库存继续增加,油价收跌

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

    2024/4/28 13:51:37
  9. 【外汇早评】日本央行会议纪要不改日元强势

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

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

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

    2024/4/27 14:22:49
  11. 【外汇早评】美欲与伊朗重谈协议

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

    2024/4/28 1:28:33
  12. 【原油贵金属早评】波动率飙升,市场情绪动荡

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

    2024/4/27 9:01:45
  13. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

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

    2024/4/27 17:59:30
  14. 【原油贵金属早评】市场情绪继续恶化,黄金上破

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

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

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

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

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

    2024/4/26 19:03:37
  17. 氧生福地 玩美北湖(上)——为时光守候两千年

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

    2024/4/28 1:22:35
  18. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

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

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

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

    2024/4/26 23:04:58
  20. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

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

    2024/4/27 23:24:42
  21. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

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

    2024/4/28 5:48:52
  22. 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者

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

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

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

    2024/4/27 11:43:08
  24. 械字号医用眼膜缓解用眼过度到底有无作用?

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

    2024/4/27 8:32:30
  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