开了手机哪些权限不能开也一样,怎么办

离上一篇文章的发布也快一个月叻想想已经快一个月没写东西了,其中可能有期末考试、课程设计和驾照考试但这都不是借口!

一到冬天就懒的不行,望广大掘友督促我 ????

协议完成的。其主要功能包括:配置维护、分布式同步、集群管理、分布式事务等

简单来说, ZooKeeper 是一个 分布式协调服务框架 分布式?协调服务这啥玩意?

其实解释到分布式这个概念的时候我发现有些同学并不是能把 **分布式和集群 **这两个概念很好的理解透。前段时间有同学和我探讨起分布式的东西他说分布式不就是加机器吗?一台机器不够用再加一台抗压呗当然加机器这种说法也无鈳厚非,你一个分布式系统必定涉及到多个机器但是你别忘了,计算机学科中还有一个相似的概念—— Cluster 集群不也是加机器吗?但是 集群 和 分布式 其实就是两个完全不同的概念

比如,我现在有一个秒杀服务并发量太大单机系统承受不住,那我加几台服务器也 一样 提供秒杀服务这个时候就是  Cluster 集群

但是我现在换一种方式,我将一个秒杀服务 拆分成多个子服务 比如创建订单服务,增加积分服务扣優惠券服务等等, 然后我将这些子服务都部署在不同的服务器上 这个时候就是 Distributed 分布式

而我为什么反驳同学所说的分布式就是加机器呢因为我认为加机器更加适用于构建集群,因为它真是只有加机器而对于分布式来说,你首先需要将业务进行拆分然后再加机器(不僅仅是加机器那么简单),同时你还要去解决分布式带来的一系列问题

比如各个分布式组件如何协调起来,如何减少各个系统之间的耦匼度分布式事务的处理,如何去配置整个分布式系统等等 ZooKeeper 主要就是解决这些问题的。

设计一个分布式系统必定会遇到一个问题—— 因為分区容忍性(partition tolerance)的存在就必定要求我们需要在系统可用性(availability)和数据一致性(consistency)中做出权衡 。这就是著名的 CAP 定理

理解起来其实很简單,比如说把一个班级作为整个系统而学生是系统中的一个个独立的子系统。这个时候班里的小红小明偷偷谈恋爱被班里的大嘴巴小花發现了小花欣喜若狂告诉了周围的人,然后小红小明谈恋爱的消息在班级里传播起来了当在消息的传播(散布)过程中,你抓到一个哃学问他们的情况如果回答你不知道,那么说明整个班级系统出现了数据不一致的问题(因为小花已经知道这个消息了)而如果他直接不回答你,因为整个班级有消息在进行传播(为了保证一致性需要所有人都知道才可提供服务),这个时候就出现了系统的可用性问題

而上述前者就是 Eureka 的处理方式,它保证了AP(可用性)后者就是我们今天所要将的 ZooKeeper 的处理方式,它保证了CP(数据一致性)

而为了解决數据一致性问题,在科学家和程序员的不断探索中就出现了很多的一致性协议和算法。比如 2PC(两阶段提交)3PC(三阶段提交),Paxos算法等等

这时候请你思考一个问题,同学之间如果采用传纸条的方式去传播消息那么就会出现一个问题——我咋知道我的小纸条有没有传到峩想要传递的那个人手中呢?万一被哪个小家伙给劫持篡改了呢对吧?

这个时候就引申出一个概念—— 拜占庭将军问题 它意指 在不可靠信道上试图通过消息传递的方式达到一致性是不可能的 , 所以所有的一致性算法的 必要前提 就是安全可靠的消息通道

而为什么要去解決数据一致性的问题?你想想如果一个秒杀系统将服务拆分成了下订单和加积分服务,这两个服务部署在不同的机器上了万一在消息嘚传播过程中积分系统宕机了,总不能你这边下了订单却没加积分吧你总得保证两边的数据需要一致吧?

两阶段提交是一种保证分布式系统数据一致性的协议现在很多数据库都是采用的两阶段提交协议来完成 分布式事务 的处理。

在介绍2PC之前我们先来想想分布式事务到底有什么问题呢?

还拿秒杀系统的下订单和加积分两个系统来举例吧(我想你们可能都吐了 )我们此时下完订单会发个消息给积分系统告诉它下面该增加积分了。如果我们仅仅是发送一个消息也不收回复那么我们的订单系统怎么能知道积分系统的收到消息的情况呢?如果我们增加一个收回复的过程那么当积分系统收到消息后返回给订单系统一个 Response ,但在中间出现了网络波动那个回复消息没有发送成功,订单系统是不是以为积分系统消息接收失败了它是不是会回滚事务?但此时积分系统是成功收到消息的它就会去处理消息然后给用戶增加积分,这个时候就会出现积分加了但是订单没下成功

所以我们所需要解决的是在分布式系统中,整个调用链中我们所有服务的數据处理要么都成功要么都失败,即所有服务的 原子性问题

在两阶段提交中,主要涉及到两个角色分别是协调者和参与者。

第一阶段:当要执行一个分布式事务的时候事务发起者首先向协调者发起事务请求,然后协调者会给所有参与者发送 prepare 请求(其中包括事务内容)告诉参与者你们需要执行事务了如果能执行我发的事务内容那么就先执行但不提交,执行后请给我回复然后参与者收到 prepare 消息后,他们會开始执行事务(但不提交)并将 Undo 和 Redo 信息记入事务日志中,之后参与者就向协调者反馈是否准备好了

第二阶段:第二阶段主要是协调鍺根据参与者反馈的情况来决定接下来是否可以进行事务的提交操作,即提交事务或者回滚事务

比如这个时候 所有的参与者 都返回了准備好了的消息,这个时候就进行事务的提交协调者此时会给所有的参与者发送  Commit 请求 ,当参与者收到 Commit 请求的时候会执行前面执行的事务的 提交操作 提交完毕之后将给协调者发送提交成功的响应。

而如果在第一阶段并不是所有参与者都返回了准备好了的消息那么此时协调鍺将会给所有参与者发送 回滚事务的 rollback 请求 ,参与者收到之后将会 回滚它在第一阶段所做的事务处理 然后再将处理情况返回给协调者,最終协调者收到响应后便给事务发起者返回处理失败的结果

个人觉得 2PC 实现得还是比较鸡肋的,因为事实上它只解决了各个事务的原子性问題随之也带来了很多的问题。

  • 单点故障问题如果协调者挂了那么整个系统都处于不可用的状态了。

  • 阻塞问题 即当协调者发送 
    prepare 请求,參与者收到之后如果能处理那么它将会进行事务的处理但并不提交这个时候会一直占用着资源不释放,如果此时协调者挂了那么这些資源都不会再释放了,这会极大影响性能

  • 数据不一致问题 ,比如当第二阶段协调者只发送了一部分的 
    commit 请求就挂了,那么也就意味着收到消息的参与者会进行事务的提交,而后面没收到的则不会进行事务提交那么这时候就会产生数据不一致性问题。

因为2PC存在的一系列問题比如单点,容错机制缺陷等等从而产生了 3PC(三阶段提交) 。那么这三阶段又分别是什么呢

千万不要吧PC理解成个人电脑了,其实怹们是 phase-commit 的缩写即阶段提交。

  1. CanCommit 请求参与者收到请求后会根据自身情况查看是否能执行事务,如果可以则返回 YES 响应并进入预备状态否则返回 NO 。

  2. PreCommit阶段 :协调者根据参与者返回的响应来决定是否可以进行下面的 
    PreCommit 操作如果上面参与者返回的都是 YES,那么协调者将向所有参与者发送 
    参与者收到预提交请求后会进行事务的执行操作,并将 Undo 和 Redo 信息写入事务日志中 最后如果参与者顺利执行了事务则给协调者返回成功嘚响应。如果在第一阶段协调者收到了 
    在一定时间内 并没有收到全部的参与者的响应那么就会中断事务,它会向所有参与者发送中断请求(abort)参与者收到中断请求之后会立即中断事务,或者在一定时间内没有收到协调者的请求它也会中断事务。

  3. 2PC 的第二阶段差不多如果协调者收到了所有参与者在 
    参与者收到 DoCommit 请求后则会进行事务的提交工作 ,完成后则会给协调者返回响应协调者收到所有参与者返回的倳务提交成功的响应之后则完成事务。若协调者在 
    收到了任何一个 NO 或者在一定时间内没有收到所有参与者的响应 那么就会进行中断请求嘚发送,参与者收到中断请求后则会 
    通过上面记录的回滚日志 来进行事务的回滚操作并向协调者反馈回滚状况,协调者收到参与者返回嘚消息后中断事务。

这里是 3PC 在成功的环境下的流程图你可以看到 3PC 在很多地方进行了超时中断的处理,比如协调者在指定时间内为收到铨部的确认消息则进行事务中断的处理这样能 减少同步阻塞的时间 。还有需要注意的是 3PC 在 DoCommit 阶段参与者如未收到协调者发送的提交事务嘚请求,它会在一定时间内进行事务的提交 为什么这么做呢?是因为这个时候我们肯定 保证了在第一阶段所有的协调者全部返回了可以執行事务的响应 这个时候我们有理由 相信其他系统都能进行事务的执行和提交 ,所以 不管 协调者有没有发消息给参与者进入第三阶段參与者都会进行事务的提交操作。

总之 3PC 通过一系列的超时机制很好的缓解了阻塞问题,但是最重要的一致性并没有得到根本的解决比洳在 PreCommit 阶段,当一个参与者收到了请求之后其他参与者和协调者挂了或者出现了网络分区这个时候收到消息的参与者都会进行事务提交,這就会出现数据不一致性问题

Paxos 算法是基于 消息传递且具有高度容错特性的一致性算法 ,是目前公认的解决分布式一致性问题最有效的算法之一 其解决的问题就是在分布式系统中如何就某个值(决议)达成一致

  • proposal 每个提案者在提出提案时都会首先获取到一个 
    具有全局唯┅性的、递增的提案编号N ,即在整个集群中是唯一的编号 N然后将该编号赋予其要提出的提案,在
    第一阶段是只将提案编号发送给所有的表决者

  • accept 某提案后,会将该提案编号N记录在本地这样每个表决者中保存的已经被 accept 的提案中会存在一个
    编号最大的提案 ,其编号假设为 
    maxN 的提案在批准提案时表决者会将以前接受过的最大编号的提案作为响应反馈给 

下面是 prepare 阶段的流程图,你可以对照着参考一下

会给所有的 Acceptor 發送真正的提案(你可以理解为第一阶段为试探),这个时候 Proposer 就会发送提案的内容和提案编号

表决者收到提案请求后会再次比较本身已經批准过的最大提案编号和该提案编号,如果该提案编号 大于等于 已经批准过的最大提案编号那么就 accept 该提案(此时执行提案内容但不提茭),随后将情况返回给 Proposer 如果不满足则不回应或者返回 NO 。

Proposer 收到超过半数的 accept 那么它这个时候会向所有的 acceptor 发送提案的提交请求。需要注意的是因为上述仅仅是超过半数的 acceptor 批准执行了该提案内容,其他没有批准的并没有执行该提案内容所以这个时候需要 向未批准的 acceptor 发送提案内容和提案编号并让它无条件执行和提交 ,而对于前面已经批准过该提案的 acceptor 来说 仅仅需要发送该提案的编号 让 acceptor 执行提交就行了。

对於 Learner 来说如何去学习 Acceptor 批准的提案内容这有很多方式,读者可以自己去了解一下这里不做过多解释。

paxos 算法的死循环问题

其实就有点类似于兩个人吵架小明说我是对的,小红说我才是对的两个人据理力争的谁也不让谁 。

比如说此时提案者 P1 提出一个方案 M1,完成了 Prepare 阶段的工莋这个时候 acceptor 则批准了 M1,但是此时提案者 P2 同时也提出了一个方案 M2它也完成了 Prepare 阶段的工作。然后 P1

就这样无休无止的永远提案下去这就是 paxos 算法的死循环问题。

那么如何解决呢很简单,人多了容易吵架我现在 就允许一个能提案 就行了。

原子广播协议该协议能够很好地支歭 崩溃恢复

  • 唯一的写请求处理者 能够发起投票(投票也是为了进行写请求)。

  • Follower :能够接收客户端的请求如果是读请求则可以自己处悝,
    如果是写请求则要转发给 Leader 在选举过程中会参与投票,
    有选举权和被选举权

ZAB 协议中对 zkServer (即上面我们说的三个角色的总称) 还有两种模式的定义,分别是 消息广播 和 崩溃恢复

呢?总不能数据只在 Leader 中更新了其他角色都没有得到更新吧?

不就是 在整个集群中保持数据的一致性 嘛如果是你,你会怎么做呢

。何为顺序性比如我现在有一个写请求A,此时 Leader 将请求A广播出去因为只需要半数同意就行,所以可能这个时候有一个 Follower F1因为网络原因没有收到而 Leader 又广播了一个请求B,因为网络原因F1竟然先收到了请求B然后才收到了请求A,这个时候请求处悝的顺序不同就会导致数据的不同从而 产生数据不一致问题

所以在 Leader 这端它为每个其他的 zkServer 准备了一个 队列 ,采用先进先出的方式发送消息由于协议是 **通过 TCP **来进行网络通信的,保证了消息的发送顺序性接受顺序性也得到了保证。

出现问题的时候我们势必需要重新选举 Leader

Leader 选举可以分为两个不同的阶段,第一个是我们提到的 Leader 宕机需要重新选举第二则是当 Zookeeper 启动时需要进行系统的 Leader 初始化选举。下面我先来介紹一下 ZAB 是如何进行初始化选举的

假设我们集群中有3台机器,那也就意味着我们需要两台以上同意(超过半数)比如这个时候我们启动叻 server1 ,它会首先 投票给自己 投票内容为服务器的 myid 和 ZXID ,因为初始化所以 ZXID

接着 server2 启动了它首先也会将投票选给自己(2,0),并将投票信息广播出去( server1 吔会只是它那时没有其他的服务器了), server1 在收到 server2 的投票信息后会将投票信息与自己的作比较 server1 发现 server2 更适合做 Leader ,它就会将自己的投票信息哽改为(2,0)然后再广播出去之后 server2 收到之后发现和自己的一样无需做更改,并且自己的 投票已经超过半数 则  。整个服务器就从 Looking 变为了正常状態

还是前面三个 server 的例子,如果在整个集群运行的过程中 server2 挂了那么整个集群会如何重新选举 Leader 呢?其实和初始化选举差不多

会向初始化投票一样首先给自己投票(这不过这里的 zxid 可能不是0了,这里为了方便随便取个数字)

此时会收到彼此的投票信息,和一开始选举一样怹们也会比较自己的投票和收到的投票( zxid 大的优先,如果相同那么就 myid 大的优先)这个时候 server1 收到了 server3 的投票发现没自己的合适故不变,

请注意 ZooKeeper 为什么要设置奇数个结点比如这里我们是三个,挂了一个我们还能正常工作挂了两个我们就不能正常工作了(已经没有超过半数的節点数了,所以无法进行投票等操作了)而假设我们现在有四个,挂了一个也能工作 但是挂了两个也不能正常工作了 ,这是和三个一樣的而三个比四个还少一个,带来的效益是一样的所以 Zookeeper 推荐奇数个 server

那么说完了 ZAB 中的 Leader 选举方式之后我们再来了解一下 崩溃恢复 是什么玩意

其实主要就是 当集群中有机器挂了,我们整个集群如何保证数据一致性

如果只是 Follower 挂了,而且挂的没超过半数的时候因为我们一開始讲了在 Leader 中会维护队列,所以不用担心后面的数据没接收到导致数据不一致性

如果 Leader 挂了那就麻烦了,我们肯定需要先暂停服务变为 Looking 状態然后进行 Leader 的重新选举(上面我讲过了)但这个就要分为两种情况了,分别是 确保已经被Leader提交的提案最终能够被所有的Follower提交 和 跳过那些巳经被丢弃的提案

确保已经被Leader提交的提案最终能够被所有的Follower提交是什么意思呢?

那么跳过那些已经被丢弃的提案又是什么意思呢

不可能再提交这个提案N1了,这样就会出现数据不一致性问题了所以 该提案N1最终需要被抛弃掉

了解了 ZAB 协议还不够它仅仅是 Zookeeper 内部实现的一种方式,而我们如何通过 Zookeeper 去做一些典型的应用场景呢比如说集群管理,分布式锁 Master 选举等等。

zookeeper 数据存储结构与标准的 Unix 文件系统非常相似嘟是在根节点下挂很多子节点(树型)。但是 zookeeper 中没有文件系统中目录与文件的概念而是  使用了 znode 作为数据节点znode 是 zookeeper 中的最小数据单元每个 znode 上嘟可以保存数据,同时还可以挂载子节点形成一个树形化命名空间。

其中节点类型可以分为 持久节点持久顺序节点临时节点 和 临时順序节点

  • 持久节点:一旦创建就一直存在,直到将其删除

  • 持久顺序节点:一个父节点可以为其子节点 维护一个创建的先后顺序 ,这个順序体现在 节点名称 上是节点名称后自动添加一个由 10 位数字组成的数字串,从 0 开始计数

  • 临时节点:临时节点的生命周期是与 客户端会話 绑定的, 会话消失则节点消失 临时节点 只能做叶子节点 ,不能创建子节点

  • 临时顺序节点:父节点可以创建一个维持了顺序的临时节點(和前面的持久顺序性节点一样)。

节点状态中包含了很多节点的属性比如 czxidmzxid 等等在 zookeeper 中是使用 Stat 这个类来维护的。下面我列举一些属性解释

  • numChildre :该节点的子节点个数,如果为临时节点为0

  • pzxid :该节点子节点列表最后一次被修改时的事务ID,注意是子节点的 

我想这个对于后端开发的萠友肯定不陌生不就是 session 吗?只不过 zk 客户端和服务端是通过  TCP 长连接 维持的会话机制其实对于会话来说你可以理解为 保持连接状态

  • CREATE :创建子节点的手机哪些权限不能开

  • READ :获取节点数据和子节点列表的手机哪些权限不能开。

  • WRITE :更新节点数据的手机哪些权限不能开

  • DELETE :删除孓节点的手机哪些权限不能开。

Watcher 为事件监听器是 zk 非常重要的一个特性,很多功能都依赖于它它有点类似于订阅的方式,即客户端向服務端 注册 指定的 watcher 当服务端符合了 watcher 的某些事件或要求则会 向客户端发送事件通知 ,客户端收到通知后找到自己定义的 Watcher 然后 执行相应的回调方法

前面说了这么多的理论知识,你可能听得一头雾水这些玩意有啥用?能干啥事别急,听我慢慢道来

还记得上面我们的所说的臨时节点吗?因为 Zookeeper 的强一致性能够很好地在保证 在高并发的情况下保证节点创建的全局唯一性 (即无法重复创建同样的节点)。

利用这个特性我们可以 让多个客户端创建一个指定的节点 ,创建成功的就是 master

但是,如果这个 master 挂了怎么办?

你想想为什么我们要创建临时节点?还记得临时节点的生命周期吗 master 挂了是不是代表会话断了?会话断了是不是意味着这个节点没了还记得 watcher 吗?我们是不是可以  让其他不昰 master 的节点监听节点的状态 比如说我们监听这个临时节点的父节点,如果子节点个数变了就代表 master 挂了这个时候我们 触发回调函数进行重噺选举 ,或者我们直接监听节点的状态我们可以通过节点是否已经失去连接来判断 master 是否挂了等等。

总的来说我们可以完全 利用 临时节點、节点状态 和 watcher 来实现选主的功能 ,临时节点主要用来选举节点状态和 watcher 可以用来判断 master 的活性和进行重新选举。

分布式锁的实现方式有很哆种比如 Redis 、数据库 、 zookeeper 等。个人认为 zookeeper 在实现分布式锁这方面是非常非常简单的

上面我们已经提到过了 zk在高并发的情况下保证节点创建的铨局唯一性 ,这玩意一看就知道能干啥了实现互斥锁呗,又因为能在分布式的情况下所以能实现分布式锁呗。

如何实现呢这玩意其實跟选主基本一样,我们也可以利用临时节点的创建来实现

首先肯定是如何获取锁,因为创建节点的唯一性我们可以让多个客户端同時创建一个临时节点, 创建成功的就说明获取到了锁 然后没有获取到锁的客户端也像上面选主的非主节点创建一个 watcher 进行节点状态的监听,如果这个互斥锁被释放了(可能获取锁的客户端宕机了或者那个客户端主动释放了锁)可以调用回调函数重新获得锁。

zk 中不需要向 redis 那樣考虑锁得不到释放的问题了因为当客户端挂了,节点也挂了锁也释放了。是不是很简答

那能不能使用 zookeeper 同时实现 共享锁和独占锁 呢?答案是可以的不过稍微有点复杂而已。

还记得 有序的节点

这个时候我规定所有创建节点必须有序,当你是读请求(要获取共享锁)的话如果 没有比自己更小的节点,或比自己小的节点都是读请求 则可以获取到读锁,然后就可以开始读了 若比自己小的节点中有寫请求 ,则当前客户端无法获取到读锁只能等待前面的写请求完成。

如果你是写请求(获取独占锁)若 没有比自己更小的节点 ,则表礻当前客户端可以直接获取到写锁对数据进行修改。若发现 有比自己更小的节点无论是读操作还是写操作,当前客户端都无法获取到寫锁 等待所有前面的操作完成。

这就很好地同时实现了共享锁和独占锁当然还有优化的地方,比如当一个锁得到释放它会通知所有等待的客户端从而造成 羊群效应 此时你可以通过让等待的节点只监听他们前面的节点。

具体怎么做呢其实也很简单,你可以让 读请求监聽比自己小的最后一个写请求节点写请求只监听比自己小的最后一个节点 ,感兴趣的小伙伴可以自己去研究一下

如何给一个对象设置ID,大家可能都会想到 UUID 但是 UUID 最大的问题就在于它太长了。。(太长不一定是好事嘿嘿嘿)。那么在条件允许的情况下我们能不能使用 zookeeper 来實现呢?

我们之前提到过 zookeeper 是通过 树形结构 来存储数据节点的那也就是说,对于每个节点的 全路径 它必定是唯一的,我们可以使用节点嘚全路径作为命名方式了而且更重要的是,路径是我们可以自己定义的这对于我们对有些有语意的对象的ID设置可以更加便于理解。

看箌这里是不是觉得 zookeeper 实在是太强大了它怎么能这么能干!

别急,它能干的事情还很多呢可能我们会有这样的需求,我们需要了解整个集群中有多少机器在工作我们想对及群众的每台机器的运行时状态进行数据采集,对集群中机器进行上下线操作等等

zookeeper 天然支持的 watcher 和 临時节点能很好的实现这些需求。我们可以为每条机器创建临时节点并监控其父节点,如果子节点列表有变动(我们可能创建删除了临时節点)那么我们可以使用在其父节点绑定的 watcher 进行状态监控和回调。

至于注册中心也很简单我们同样也是让 服务提供者 在 zookeeper 中创建一个临時节点并且将自己的 ip、port、调用方式 写入节点,当 服务消费者 需要进行调用的时候会 通过注册中心找到相应的服务的地址列表(IP端口什么的) 並缓存到本地(方便以后调用),当消费者调用服务时不会再去请求注册中心,而是直接通过负载均衡算法从地址列表中取一个服务提供者嘚服务器调用服务

当服务提供者的某台服务器宕机或下线时,相应的地址会从服务提供者地址列表中移除同时,注册中心会将新的服務地址列表发送给服务消费者的机器并缓存在消费者本机(当然你可以让消费者进行节点监听我记得 Eureka 会先试错,然后再更新)

看到这裏的同学实在是太有耐心了:+1::+1::+1:,如果觉得我写得不错的话点个赞哈

不知道大家是否还记得我讲了什么:unamused:。

这篇文章中我带大家入门了 zookeeper 这个强夶的分布式协调框架现在我们来简单梳理一下整篇文章的内容。

  • zookeeper 专门的一致性算法 ZAB 原子广播协议的内容( Leader 选举、崩溃恢复、消息广播)

  • zookeeper 的典型应用场景,比如选主注册中心等等。

    如果忘了可以回去看看再次理解一下如果有疑问和建议欢迎提出 。

没次打开都是说手机哪些权限不能开没打开... 没次打开都是说手机哪些权限不能开没打开

若以下回答无法解决问题邀请你更新回答

若是指vivo手机微信摄像头无法打开,可以嘗试以下方法操作:

一、将手机关机重启看能否恢复

二、将微信版本升级至最新版本查看。

三、卸载软件重新安装查看

四、打开相机戓者其它软件查看是否是正常,若正常不同系统开启软件手机哪些权限不能开方法不一样,可根据个人系统版本来操作:

Funtouch  OS  3.0以上机型:可鉯进入手机中的设置--更多设置--手机哪些权限不能开管理--手机哪些权限不能开中开启摄像头手机哪些权限不能开看看

1、在手机桌面找到设置

2、进入设置找到更多设置

3、进入更多设置找到手机哪些权限不能开管理

4、找到相机手机哪些权限不能开开启试试

1、在手机桌面找到i管家進入

2、进入i管家找到软件管理

3、进入软件管理找到软件手机哪些权限不能开管理

4、进入软件手机哪些权限不能开管理找到摄像头开启微信掱机哪些权限不能开即可

你对这个回答的评价是?

下载百度知道APP抢鲜体验

使用百度知道APP,立即抢鲜体验你的手机镜头里或许有别人想知道的答案。

支付宝银行卡和淘宝银行卡不一樣我想删除淘宝那个银行卡什么删
全部
  • 说的应该是实名认证使用的银行卡跟在付款时候使用快捷支付的吧不管淘宝还是支付宝,只要其Φ一个绑了任意一张本人的卡结果是两个都会一起绑上的这边说的绑,一般就是快捷支付使用的卡要解绑的话进支付宝-账户通-我的银荇卡-管理-删除,一步一步操作就行了
    全部

我要回帖

更多关于 手机哪些权限不能开 的文章

 

随机推荐