11.1 泛型和安全的容器

可以把ArrayList当做“可以自动扩充自身尺寸的数组”来看待。使用ArrayList相当简单。创建一个实例,用add()来插入对象,然后用get()
来访问这些对象,此时需要使用索引,就像数组一样,需要方括号。ArrayList还有一个size()方法,使你可以知道有多少元素添加了进来。

//: holding/ApplesAndOrangesWithGenerics.java
import java.util.*;public class ApplesAndOrangesWithGenerics {public static void main(String[] args) {ArrayList<Apple> apples = new ArrayList<Apple>();for(int i = 0; i < 3; i++)apples.add(new Apple());// Compile-time error:// apples.add(new Orange());for(int i = 0; i < apples.size(); i++)System.out.println(apples.get(i).id());// Using foreach:for(Apple c : apples)System.out.println(c.id());}
} /* Output:
0
1
2
0
1
2
*///:~

当ArrayList没有添加任何参数时,你可以添加任意对象进入其中,而不会报错,但是取出对象时,你得到的只是Object对象,必须将其转型为Apple,通过使用泛型,就可以在编译期防止将错误的类型的对象错误的放到容器中。

11.2 基本概念

1)Collection 。一个独立元素的序列。List必须按照插入的顺序保存元素,而Set不能有重复的元素。Queue按照排队的顺序来确定对象产生的顺序(通常与他被插入的对象的顺序相同)
2)Map 一组成对的“键值对”对象,允许你使用键来查找值,ArrayList允许你使用数字来查找值,因此在某种意义上来讲,它将数字与对象关联在了一起,你可以使用键对象来查找对象,就像在字典中使用单词来定义一样,Map是强大的编程工具。

//: holding/SimpleCollection.java
import java.util.*;public class SimpleCollection {public static void main(String[] args) {Collection<Integer> c = new ArrayList<Integer>();for(int i = 0; i < 10; i++)c.add(i); // Autoboxingfor(Integer i : c)System.out.print(i + ", ");}
} /* Output:
0, 1, 2, 3, 4, 5, 6, 7, 8, 9,
*///:~

11.3 添加一组元素

ArrayList()方法接受一个数组或四一个用逗号分隔·的元素列表(使用可变参数),并将其转换为一个List对象,Collection.addAll()接受一个Collection对象,以及一个数组活用逗号分隔的列表,并将元素添加到Collection中,下面的事例展示了这两个方法,以及更加传统的addAll方法。

//: holding/AddingGroups.java
// Adding groups of elements to Collection objects.
import java.util.*;public class AddingGroups {public static void main(String[] args) {Collection<Integer> collection =new ArrayList<Integer>(Arrays.asList(1, 2, 3, 4, 5));Integer[] moreInts = { 6, 7, 8, 9, 10 };collection.addAll(Arrays.asList(moreInts));// Runs significantly faster, but you can't// construct a Collection this way:Collections.addAll(collection, 11, 12, 13, 14, 15);Collections.addAll(collection, moreInts);// Produces a list "backed by" an array:List<Integer> list = Arrays.asList(16, 17, 18, 19, 20);list.set(1, 99); // OK -- modify an element// list.add(21); // Runtime error because the// underlying array cannot be resized.}
} ///:~

调用Collection.addAll这种方式很方便,因此它是首选方式。

11.4 容器的打印

必须使用ArrayList.toString()来产生数组的课打印表示。

//: holding/PrintingContainers.java
// Containers print themselves automatically.
import java.util.*;
import static net.mindview.util.Print.*;public class PrintingContainers {static Collection fill(Collection<String> collection) {collection.add("rat");collection.add("cat");collection.add("dog");collection.add("dog");return collection;}static Map fill(Map<String,String> map) {map.put("rat", "Fuzzy");map.put("cat", "Rags");map.put("dog", "Bosco");map.put("dog", "Spot");return map;}	public static void main(String[] args) {print(fill(new ArrayList<String>()));print(fill(new LinkedList<String>()));print(fill(new HashSet<String>()));print(fill(new TreeSet<String>()));print(fill(new LinkedHashSet<String>()));print(fill(new HashMap<String,String>()));print(fill(new TreeMap<String,String>()));print(fill(new LinkedHashMap<String,String>()));}
} /* Output:
[rat, cat, dog, dog]
[rat, cat, dog, dog]
[dog, cat, rat]
[cat, dog, rat]
[rat, cat, dog]
{dog=Spot, cat=Rags, rat=Fuzzy}
{cat=Rags, dog=Spot, rat=Fuzzy}
{rat=Fuzzy, cat=Rags, dog=Spot}
*///:~

ArrayList和LinkedList都是List类型,他们都按照顺序来保存对象,两者不同之处不仅在于执行某些类型操作时的性能,而且LinkedList包含的操作要多于ArrayList。
HashSet,TreeSet,LinkedHashSet都是Set类型,HashSet是最快的获取元素的方式,如果顺序很重要,使用TreeSet,他使用的按照比较结果的升序保存对象,LinkedHashSet按照添加的顺序来保存对象。

11.5 List

下面的例子介绍了一些List的操作。

//: holding/ListFeatures.java
import typeinfo.pets.*;
import java.util.*;
import static net.mindview.util.Print.*;public class ListFeatures {public static void main(String[] args) {Random rand = new Random(47);List<Pet> pets = Pets.arrayList(7);print("1: " + pets);Hamster h = new Hamster();pets.add(h); // Automatically resizesprint("2: " + pets);print("3: " + pets.contains(h));pets.remove(h); // Remove by objectPet p = pets.get(2);print("4: " +  p + " " + pets.indexOf(p));Pet cymric = new Cymric();print("5: " + pets.indexOf(cymric));print("6: " + pets.remove(cymric));// Must be the exact object:print("7: " + pets.remove(p));print("8: " + pets);pets.add(3, new Mouse()); // Insert at an indexprint("9: " + pets);List<Pet> sub = pets.subList(1, 4);print("subList: " + sub);print("10: " + pets.containsAll(sub));Collections.sort(sub); // In-place sortprint("sorted subList: " + sub);// Order is not important in containsAll():print("11: " + pets.containsAll(sub));Collections.shuffle(sub, rand); // Mix it upprint("shuffled subList: " + sub);print("12: " + pets.containsAll(sub));List<Pet> copy = new ArrayList<Pet>(pets);sub = Arrays.asList(pets.get(1), pets.get(4));print("sub: " + sub);copy.retainAll(sub);print("13: " + copy);copy = new ArrayList<Pet>(pets); // Get a fresh copycopy.remove(2); // Remove by indexprint("14: " + copy);copy.removeAll(sub); // Only removes exact objectsprint("15: " + copy);copy.set(1, new Mouse()); // Replace an elementprint("16: " + copy);copy.addAll(2, sub); // Insert a list in the middleprint("17: " + copy);print("18: " + pets.isEmpty());pets.clear(); // Remove all elementsprint("19: " + pets);print("20: " + pets.isEmpty());pets.addAll(Pets.arrayList(4));print("21: " + pets);Object[] o = pets.toArray();print("22: " + o[3]);Pet[] pa = pets.toArray(new Pet[0]);print("23: " + pa[3].id());}
} /* Output:
1: [Rat, Manx, Cymric, Mutt, Pug, Cymric, Pug]
2: [Rat, Manx, Cymric, Mutt, Pug, Cymric, Pug, Hamster]
3: true
4: Cymric 2
5: -1
6: false
7: true
8: [Rat, Manx, Mutt, Pug, Cymric, Pug]
9: [Rat, Manx, Mutt, Mouse, Pug, Cymric, Pug]
subList: [Manx, Mutt, Mouse]
10: true
sorted subList: [Manx, Mouse, Mutt]
11: true
shuffled subList: [Mouse, Manx, Mutt]
12: true
sub: [Mouse, Pug]
13: [Mouse, Pug]
14: [Rat, Mouse, Mutt, Pug, Cymric, Pug]
15: [Rat, Mutt, Cymric, Pug]
16: [Rat, Mouse, Cymric, Pug]
17: [Rat, Mouse, Mouse, Pug, Cymric, Pug]
18: false
19: []
20: true
21: [Manx, Cymric, Rat, EgyptianMau]
22: EgyptianMau
23: 14
*///:~

你可以用contains()方法来确定某个对象是否在列表中,如果你想移除一个对象,则可以将这个对象的引用传递给remove()方法。 同样如果你有一个对象的引用,则可以使用indexOf()来发现该对象在List中所处位置的索引编号。
subList()方法允许你很容易的从较大的列表中创建出一个片段,而将这个结果传递个较大的列表的containsAll(),很自然的会得到true。
retainAll()是一种有效的交集操作,他保留了同时在copy中与sub中的元素。
可以使用toArray()方法将任意的Collection转换为一个数组,如果参数数组太小,存放不下List中的所有元素,toArray()将创建一个具有合适尺寸的数组。

11.6 迭代器

迭代器是一个对象,它的工作是遍历并选择序列中的对象。而客户端程序员不必关心该序列的底层结构,创建迭代器的代价很小,因此它也被称为轻量级对象,java的Iterator只能单向移动,这个Iterator只能用来。
1)使用方法Iterator()要求容器返回一个Iterator。Iterator将准备好返回第一个元素。
2)使用next()获得序列中的下一个对象。
3)使用hasNext()检查序列中是否还有元素。
4)使用remove()将迭代器新返回的元素删除。

//: holding/SimpleIteration.java
import typeinfo.pets.*;
import java.util.*;public class SimpleIteration {public static void main(String[] args) {List<Pet> pets = Pets.arrayList(12);Iterator<Pet> it = pets.iterator();while(it.hasNext()) {Pet p = it.next();System.out.print(p.id() + ":" + p + " ");}System.out.println();// A simpler approach, when possible:for(Pet p : pets)System.out.print(p.id() + ":" + p + " ");System.out.println();	// An Iterator can also remove elements:it = pets.iterator();for(int i = 0; i < 6; i++) {it.next();it.remove();}System.out.println(pets);}
} /* Output:
0:Rat 1:Manx 2:Cymric 3:Mutt 4:Pug 5:Cymric 6:Pug 7:Manx 8:Cymric 9:Rat 10:EgyptianMau 11:Hamster
0:Rat 1:Manx 2:Cymric 3:Mutt 4:Pug 5:Cymric 6:Pug 7:Manx 8:Cymric 9:Rat 10:EgyptianMau 11:Hamster
[Pug, Manx, Cymric, Rat, EgyptianMau, Hamster]
*///:~

迭代器能够将遍历序列的操作与序列底层的结构分离,正由如此,我有时会说:迭代器统一了对容器的访问的方式。

//: holding/CrossContainerIteration.java
import typeinfo.pets.*;
import java.util.*;public class CrossContainerIteration {public static void display(Iterator<Pet> it) {while(it.hasNext()) {Pet p = it.next();System.out.print(p.id() + ":" + p + " ");}System.out.println();}	public static void main(String[] args) {ArrayList<Pet> pets = Pets.arrayList(8);LinkedList<Pet> petsLL = new LinkedList<Pet>(pets);HashSet<Pet> petsHS = new HashSet<Pet>(pets);TreeSet<Pet> petsTS = new TreeSet<Pet>(pets);display(pets.iterator());display(petsLL.iterator());display(petsHS.iterator());display(petsTS.iterator());}
} /* Output:
0:Rat 1:Manx 2:Cymric 3:Mutt 4:Pug 5:Cymric 6:Pug 7:Manx
0:Rat 1:Manx 2:Cymric 3:Mutt 4:Pug 5:Cymric 6:Pug 7:Manx
4:Pug 6:Pug 3:Mutt 1:Manx 5:Cymric 7:Manx 2:Cymric 0:Rat
5:Cymric 2:Cymric 7:Manx 1:Manx 3:Mutt 6:Pug 4:Pug 0:Rat
*///:~

11.6.1 ListIterator
ListIterator是一个更加强大的Iterator的子类型,它只能用于各种List类的访问,但是ListIterator可以双向移动,你可以使用ListIterator(n)创建一个一开始索引为n的元素出的ListIterator。n指的是第几个元素,而不是元素的地址。
你也可以用迭代器来进行add(),set(),remove()等操作

//: holding/ListIteration.java
import typeinfo.pets.*;
import java.util.*;public class ListIteration {public static void main(String[] args) {List<Pet> pets = Pets.arrayList(8);ListIterator<Pet> it = pets.listIterator();while(it.hasNext())System.out.print(it.next() + ", " + it.nextIndex() +", " + it.previousIndex() + "; ");System.out.println();// Backwards:while(it.hasPrevious())System.out.print(it.previous().id() + " ");System.out.println();System.out.println(pets);	it = pets.listIterator(3);while(it.hasNext()) {it.next();it.set(Pets.randomPet());}System.out.println(pets);}
} /* Output:
Rat, 1, 0; Manx, 2, 1; Cymric, 3, 2; Mutt, 4, 3; Pug, 5, 4; Cymric, 6, 5; Pug, 7, 6; Manx, 8, 7;
7 6 5 4 3 2 1 0
[Rat, Manx, Cymric, Mutt, Pug, Cymric, Pug, Manx]
[Rat, Manx, Cymric, Cymric, Rat, EgyptianMau, Hamster, EgyptianMau]
*///:~

11.7 LinkedList

getFirst()和element()完全一样,他们都返回列表的头部,而不移除他,如果List为空,则抛出NoSuchElementException错误。peek()方法与这两个方式只是稍有差异,返回一个null。
remove()与removeFirst()也是完全一样的,他们移除这个表的头,而在表为空的时候,则抛出NoSuchElementException错误,poll()在列表为空的时候返回null。
addFirst()与add()和addLast()相同,都是在表中插入元素。
removeLast()移除并返回列表的最后一个元素。

//: holding/LinkedListFeatures.java
import typeinfo.pets.*;
import java.util.*;
import static net.mindview.util.Print.*;public class LinkedListFeatures {public static void main(String[] args) {LinkedList<Pet> pets =new LinkedList<Pet>(Pets.arrayList(5));print(pets);// Identical:print("pets.getFirst(): " + pets.getFirst());print("pets.element(): " + pets.element());// Only differs in empty-list behavior:print("pets.peek(): " + pets.peek());// Identical; remove and return the first element:print("pets.remove(): " + pets.remove());print("pets.removeFirst(): " + pets.removeFirst());// Only differs in empty-list behavior:print("pets.poll(): " + pets.poll());print(pets);pets.addFirst(new Rat());print("After addFirst(): " + pets);pets.offer(Pets.randomPet());print("After offer(): " + pets);pets.add(Pets.randomPet());print("After add(): " + pets);pets.addLast(new Hamster());print("After addLast(): " + pets);print("pets.removeLast(): " + pets.removeLast());}
} /* Output:
[Rat, Manx, Cymric, Mutt, Pug]
pets.getFirst(): Rat
pets.element(): Rat
pets.peek(): Rat
pets.remove(): Rat
pets.removeFirst(): Manx
pets.poll(): Cymric
[Mutt, Pug]
After addFirst(): [Rat, Mutt, Pug]
After offer(): [Rat, Mutt, Pug, Cymric]
After add(): [Rat, Mutt, Pug, Cymric, Pug]
After addLast(): [Rat, Mutt, Pug, Cymric, Pug, Hamster]
pets.removeLast(): Hamster
*///:~

11.9 Set

Set具有与Collection完全一样的接口,因此没有任何额外的功能,不像前面两个不同的Set,实际上Set就是Collection,只是行为不同。
Set不保存重复的元素,Set中最常用的是测试归属性,你可以很容易的查询到某个对象是否在某个Set中,因此,查找就成了Set中最重要的操作,所以通常都会选择一个HashSet的实现,它专门对快速查找进行了优化。

//: holding/SetOfInteger.java
import java.util.*;public class SetOfInteger {public static void main(String[] args) {Random rand = new Random(47);Set<Integer> intset = new HashSet<Integer>();for(int i = 0; i < 10000; i++)intset.add(rand.nextInt(30));System.out.println(intset);}
} /* Output:
[15, 8, 23, 16, 7, 22, 9, 21, 6, 1, 29, 14, 24, 4, 19, 26, 11, 18, 3, 12, 27, 17, 2, 13, 28, 20, 25, 10, 5, 0]
*///:~

你可以注意到,输出的顺序没有任何规律可言,HashSet所维护的顺序与TreeSet或LinkedHashSet都不同,因为他们的实现具有不同的元素存储方式。如果想要对结果进行排序,一种方式是用TreeSet来代替HashSet:

//: holding/SortedSetOfInteger.java
import java.util.*;public class SortedSetOfInteger {public static void main(String[] args) {Random rand = new Random(47);SortedSet<Integer> intset = new TreeSet<Integer>();for(int i = 0; i < 10000; i++)intset.add(rand.nextInt(30));System.out.println(intset);}
} /* Output:
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29]
*///:~

11.10 Map

将对象映射到其他对象的能力是一种解决编程问题的杀手锏,例如要计算Random产生的各种不同范围的数字进行计数,Map可以很容易的解决问题。在本例中,键是由Random产生的数字,而值是该数字出现的次数;

//: holding/Statistics.java
// Simple demonstration of HashMap.
import java.util.*;public class Statistics {public static void main(String[] args) {Random rand = new Random(47);Map<Integer,Integer> m =new HashMap<Integer,Integer>();for(int i = 0; i < 10000; i++) {// Produce a number between 0 and 20:int r = rand.nextInt(20);Integer freq = m.get(r);m.put(r, freq == null ? 1 : freq + 1);}System.out.println(m);}
} /* Output:
{15=497, 4=481, 19=464, 8=468, 11=531, 16=533, 18=478, 3=508, 7=471, 12=521, 17=509, 2=489, 13=506, 9=549, 6=519, 1=502, 14=477, 10=513, 5=503, 0=481}
*///:~

下面的事例允许你使用一个String描述来查找Pet,它还展示了你可以使用怎样的方法使用containsKey(),和containValue()来测试一个Map(),以便查看他是否包含某个键或者某个类。

//: holding/PetMap.java
import typeinfo.pets.*;
import java.util.*;
import static net.mindview.util.Print.*;public class PetMap {public static void main(String[] args) {Map<String,Pet> petMap = new HashMap<String,Pet>();petMap.put("My Cat", new Cat("Molly"));petMap.put("My Dog", new Dog("Ginger"));petMap.put("My Hamster", new Hamster("Bosco"));print(petMap);Pet dog = petMap.get("My Dog");print(dog);print(petMap.containsKey("My Dog"));print(petMap.containsValue(dog));}
} /* Output:
{My Cat=Cat Molly, My Hamster=Hamster Bosco, My Dog=Dog Ginger}
Dog Ginger
true
true
*///:~

Map和其他Collection一样,可以扩展,Map的值可以是其他容器,使得我们可以很轻松生成强大的数据结构。
例如: Map<Person , List>;

11.11 Queue

LinkList提供了方法以支持队列的对象,并且它实现了Queue接口,因此LinkList可以作为Queue的一种实现,通过将LinkList向上转型为Queue。

//: holding/QueueDemo.java
// Upcasting to a Queue from a LinkedList.
import java.util.*;public class QueueDemo {public static void printQ(Queue queue) {while(queue.peek() != null)System.out.print(queue.remove() + " ");System.out.println();}public static void main(String[] args) {Queue<Integer> queue = new LinkedList<Integer>();Random rand = new Random(47);for(int i = 0; i < 10; i++)queue.offer(rand.nextInt(i + 10));printQ(queue);Queue<Character> qc = new LinkedList<Character>();for(char c : "Brontosaurus".toCharArray())qc.offer(c);printQ(qc);}
} /* Output:
8 1 1 1 5 14 3 1 0 1
B r o n t o s a u r u s
*///:~

offer()方法是与Queue相关的方法之一,它在允许的情况下将一个元素插入队尾,或者返回false,peek()和element()都将在不移除的情况下返回队头,但是peek()在队列为空的时候返回null,而element()会抛出NoSuchElementException异常。poll()和remove()方法将移除并返回队头,但是poll()在队列为空时候返回null,而remove()会抛出NoSuchElementException()异常
Queue接口窄化了对LinkList的方法的访问权限,以使得只有恰当的方法才可以使用,因此,你能够访问的LinkList方法会变少。
11.11.1 PriorityQueue
当你在PriorityQueue上调用一个offer来插入一个对象是,这个对象会在队列中被排序,默认的排序将使用对象在队列中的自然顺序,但是你可以使用Comparator来修改这个顺序,PriorityQueue可以确保你在调用peek()poll()remove()方法时,获取的元素将是队列中优先级最高的元素。

//: holding/PriorityQueueDemo.java
import java.util.*;public class PriorityQueueDemo {public static void main(String[] args) {PriorityQueue<Integer> priorityQueue =new PriorityQueue<Integer>();Random rand = new Random(47);for(int i = 0; i < 10; i++)priorityQueue.offer(rand.nextInt(i + 10));QueueDemo.printQ(priorityQueue);List<Integer> ints = Arrays.asList(25, 22, 20,18, 14, 9, 3, 1, 1, 2, 3, 9, 14, 18, 21, 23, 25);priorityQueue = new PriorityQueue<Integer>(ints);QueueDemo.printQ(priorityQueue);priorityQueue = new PriorityQueue<Integer>(Collections.reverseOrder());priorityQueue.addAll(ints);QueueDemo.printQ(priorityQueue);String fact = "EDUCATION SHOULD ESCHEW OBFUSCATION";List<String> strings = Arrays.asList(fact.split(""));PriorityQueue<String> stringPQ =new PriorityQueue<String>(strings);QueueDemo.printQ(stringPQ);stringPQ = new PriorityQueue<String>(strings.size(), Collections.reverseOrder());stringPQ.addAll(strings);QueueDemo.printQ(stringPQ);Set<Character> charSet = new HashSet<Character>();for(char c : fact.toCharArray())charSet.add(c); // AutoboxingPriorityQueue<Character> characterPQ =new PriorityQueue<Character>(charSet);QueueDemo.printQ(characterPQ);}
} /* Output:
0 1 1 1 1 1 3 5 8 14
1 1 2 3 3 9 9 14 14 18 18 20 21 22 23 25 25
25 25 23 22 21 20 18 18 14 14 9 9 3 3 2 1 1A A B C C C D D E E E F H H I I L N N O O O O S S S T T U U U W
W U U U T T S S S O O O O N N L I I H H F E E E D D C C C B A AA B C D E F H I L N O S T U W
*///:~

11.13 Foreach与迭代器

能够与Foreach工作是所有Collection对象的特性。之所以能够工作,是因为java SE5中加入了新的被称为Iterator的接口,该接口包含了一个能够产生Iterator的iterator()的方法,并且Iterator接口被Foreach用来在序列中移动,因此如果你创建了任何实现ITerator的类,都可以将它用于Foreach语句中:

//: holding/IterableClass.java
// Anything Iterable works with foreach.
import java.util.*;public class IterableClass implements Iterable<String> {protected String[] words = ("And that is how " +"we know the Earth to be banana-shaped.").split(" ");public Iterator<String> iterator() {return new Iterator<String>() {private int index = 0;public boolean hasNext() {return index < words.length;}public String next() { return words[index++]; }public void remove() { // Not implementedthrow new UnsupportedOperationException();}};}	public static void main(String[] args) {for(String s : new IterableClass())System.out.print(s + " ");}
} /* Output:
And that is how we know the Earth to be banana-shaped.
*///:~
查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. 只有1年经验的Java程序员,面试16K的外派支付宝,已拿offer

    他的情况介绍,双非一本&#xff0c;19年毕业&#xff0c;计算机专业&#xff0c;只过四级&#xff0c;刚刚一年经验&#xff0c;他把他的支付宝外派面试经验分享出来了&#xff0c;还有他的一些学习资料&#xff0c;也都整理出来发给我了&#xff0c;需要的朋友看文末 一面是软…...

    2024/4/25 22:50:04
  2. 产业区块链落地提速 加快推动数字经济转型升级

    9月11日&#xff0c;在2020腾讯全球数字生态大会产业区块链专场上&#xff0c;龙华区政府联合腾讯云发布全国首个“产业区块链应用示范清单”&#xff0c;涵盖城市建设、社会治理、产业发展等方面的12个落地场景。会上&#xff0c;腾讯云同时发布区块链底层引擎、区块链可信计算…...

    2024/5/5 20:10:37
  3. 知识点摘要记忆

    目录java基础修饰符反射异常四种引用NIO的工作流程简单的理解JAVA代理的原理JVM相关0.) 类的生命周期多线程相关0.) 多线程的生命周期1.) 创建线程的方式2. ) 四种线程池3.) Synchronized 同步锁4.) 分级锁5&#xff09; 谈谈 synchronized 和 ReentrantLock 的区别6&#xff0…...

    2024/4/28 0:03:52
  4. STM32学习——入门小项目

    博客地址&#xff1a;https://infinite-zh.com/archives/298 这个小项目是来自参加电设时&#xff0c;老师发的STM32入门&#xff08;进阶&#xff09;任务&#xff0c;具体的要求如下&#xff1a; 软件设计要求 编写简单I/O程序&#xff0c;能用板上的4个基本按键控制10个LED…...

    2024/4/17 13:43:32
  5. 天池比赛(-贷款违约预测)2--数据探索性分析

    读取数据 data_train pd.read_csv(’./train.csv’) data_test_a pd.read_csv(’./testA.csv’) 生成数据分析报告&#xff1a; import pandas_profiling pfr pandas_profiling.ProfileReport(data_train) pfr.to_file("./example.html")...

    2024/4/19 18:25:34
  6. 打造自己的F-16战斗机(非线性Simulink模型)

    https://pan.baidu.com/s/1yNS5qcKSka3G5xNAzHmbTQ 提取码: h8sg F-16是一款轻型战斗机&#xff0c;具有单发动机、单垂尾等结构布局&#xff0c;在NASA的多次飞行试验和实际作战中&#xff0c;都表现出良好的气动特性和机动性能。需要说明的是&#xff0c;研究选择的F-16战斗…...

    2024/4/28 10:20:26
  7. [论文笔记|VIO]ROVINS: Robust Omnidirectional Visual Inertial Navigation System

    I. 摘要 视觉里程计的视觉传感器在快速运动或光照突变时很容易受到影响。在视觉感知变得不稳定时保持短期运动&#xff0c;惯性信息可以提高估计运动的质量。基于之前的工作-ROVO&#xff0c;本文介绍了一种能够将惯性信息无缝集成到全向视觉里程计算法中的全局视觉惯性里程计…...

    2024/4/24 15:57:34
  8. 零基础入门金融风控-贷款违约预测_Task2

    贷款违约预测_Task2数据读取处理python包导入数据读取与基本信息查看数据基本处理模型建模与训练lightGBM模型初始化模型训练模型预测与结果导出模型预测导出预测结果本文结合数据分析&#xff0c;给出了本次比赛的基线方案&#xff0c;该基线方案线上评测得分为0.7391。 数据读…...

    2024/4/7 11:29:20
  9. 吃豆人

    本文基于Java实现的吃豆人小游戏&#xff0c;水平不高。如有问题欢迎在评论区批评指正。一、综合训练任务二、分析与设计2.1 需求分析2.2 静态分析三、游戏页面四、代码一、综合训练任务 完成程序设计并撰写比较规范的设计报告。将程序尽可能的完善&#xff0c;界面尽可能规范…...

    2024/4/21 20:43:32
  10. 知物由学 | 广告欺诈:如何应对数字广告里分羹者?

    本文由 网易云 发布。 “知物由学”是网易云易盾打造的一个品牌栏目&#xff0c;词语出自汉王充《论衡实知》。人&#xff0c;能力有高下之分&#xff0c;学习才知道事物的道理&#xff0c;而后才有智慧&#xff0c;不去求问就不会知道。“知物由学”希望通过一篇篇技术干货、…...

    2024/5/4 19:28:46
  11. 【AO笔记】有关使用AO基于shp文件创建网络数据集的一个细节

    前些日子&#xff0c;和群友交流时提及shp文件创建单一网络数据集的创建问题。 由于项目需求&#xff0c;用shp文件创建网络合适&#xff0c;所以不得不去找一些古老的代码资料... 以前的研究中&#xff0c;创建网络数据集是根据IDatasetContainer2.CreateDataset()方法创建的…...

    2024/4/27 2:05:26
  12. Java也可以做Python的事:设计一个Java的神经网络

    Java也可以做Python的事&#xff1a;设计一个Java的神经网络 人工神经网络&#xff08;ANN&#xff09;或连接系统是受生物神经网络启发构成生物大脑的计算系统。这样的系统通过考虑例子来学习&#xff08;逐步提高性能&#xff09;来完成任务&#xff0c;通常没有任务特定的编…...

    2024/4/27 23:10:21
  13. 拓展篇

    1、String能被继承吗&#xff1f;为什么&#xff1f; 不可以&#xff0c;因为String类有final修饰符&#xff0c;而final修饰的类是不能被继承的&#xff0c;实现细节不允许改变。 2、String str“abc”和String strnew String(“abc”); 产生几个对象&#xff1f; 前者1或0…...

    2024/4/18 20:09:18
  14. NIO框架

    NIO 1.概述&#xff1a;NIO全称java non-blocking IO &#xff0c;是指JDK1.4开始&#xff0c;java提供了一系列改进的输入/输出的新特性&#xff0c;被统称为NIO(即New IO )。新增了许多用于处理输入输出的类&#xff0c;这些类都被放在java.nio包及子包下&#xff0c;并且对…...

    2024/4/13 6:13:06
  15. Py学习——批量操作Word文件

    博客地址&#xff1a;https://infinite-zh.com/archives/62 这几天为了帮助我姐批量修改Word的表格&#xff0c;让我想到了朋友圈常有的广告&#xff08;路人&#xff1a;你咋这么快就做好了呀&#xff0c;主角&#xff1a;因为我用了Python呀&#xff0c;Python经典课程&…...

    2024/4/20 23:58:22
  16. Ubuntu14.04.6虚拟机从零安装配置NS2 2.35

    建议参考&#xff1a; 安装镜像后&#xff08;语言包下载比较慢&#xff0c;可以skip&#xff09;&#xff0c;中文输入法可能会有异常&#xff0c;检查是否是全拼并且安装VMware tools方便操作。安装VMware Tools可参考VMware Tools &#xff08;ubuntu系统&#xff09;安装详…...

    2024/4/29 4:48:50
  17. 申论文章观点的打造技巧

    关注 所谓“亮点”&#xff0c;即在原有的基础上写得更好、更出彩。有些同学对大作文的了解不深&#xff0c;在找到一些观点后不知如何下笔&#xff0c;下面由小粉笔来带领大家学一下如何准确全面的打造观点。 ▎知识点 一、学会从文章中提炼观点、从材料中“抄”。在找到观点…...

    2024/4/21 1:17:17
  18. 来看大牛们是如何全解析45种设计模式与六大原则的(附详解文档)

    设计模式(Design Pattern)是一套被反复使用、多数人知晓的、经过分类的、代码设计经验的总结。 使用设计模式的目的:为了代码可重用性、让代码更容易被他人理解、保证代码可靠性。 设计模式使代码编写真正工程化;设计模式是软件工程的基石脉络&#xff0c;如同大厦的结构一样。…...

    2024/4/24 5:42:49
  19. Redis主从复制与哨兵模式

    Redis主从复制 概念 主从复制&#xff0c;是指将一台Redis服务器的数据&#xff0c;复制到其他Redis服务器&#xff0c;前者称为主节点&#xff08;master/leader&#xff09;&#xff0c;后者称为从节点&#xff08;slave/follower&#xff09;&#xff1a;数据的复制是单向…...

    2024/4/7 11:29:13
  20. Kafka的生产者原理及重要参数说明

    写在前面&#xff1a;2020年面试必备的Java后端进阶面试题总结了一份复习指南在Github上&#xff0c;内容详细&#xff0c;图文并茂&#xff0c;有需要学习的朋友可以Star一下&#xff01; GitHub地址&#xff1a;https://github.com/abel-max/Java-Study-Note/tree/master Ka…...

    2024/4/7 11:29:12

最新文章

  1. 长期找 AI 专家,邀请参加线上聊天直播

    诚邀 AI 专家参加线上聊天&#xff0c;成为嘉宾。 分享前沿观点、探讨科技和生活 除节假日外&#xff0c;每周举办在线聊天直播 根据话题和自愿形式结合&#xff0c;每期 2~3 位嘉宾 成为嘉宾&#xff0c;见下&#xff1a;...

    2024/5/6 0:22:11
  2. 梯度消失和梯度爆炸的一些处理方法

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

    2024/3/20 10:50:27
  3. Vue ts 如何给 props 中的变量指定特定类型,比如 Interface 类的

    Vue ts 如何给 props 中的变量指定特定类型&#xff0c;比如 Interface 类的 我有一个这样的变量值类型 一、在没用 ts 之前的 props 类型指定方式 我们都知道之前在没用 ts 之前的 props 变量值类型指定方式&#xff1a; 如下图&#xff0c;billFood 定义方式是这样的&…...

    2024/5/4 17:46:51
  4. 3d representation的一些基本概念

    顶点&#xff08;Vertex&#xff09;&#xff1a;三维空间中的一个点&#xff0c;可以有多个属性&#xff0c;如位置坐标、颜色、纹理坐标和法线向量。它是构建三维几何形状的基本单元。 边&#xff08;Edge&#xff09;&#xff1a;连接两个顶点形成的直线段&#xff0c;它定…...

    2024/5/5 9:27:51
  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/5 18:19:03
  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/5 12:22:20
  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/5 19:59:54
  8. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

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

    2024/5/4 23:54:44
  9. VB.net WebBrowser网页元素抓取分析方法

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

    2024/5/5 15:25:47
  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/4 23:54:49
  11. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

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

    2024/5/4 23:54:44
  12. 【ES6.0】- 扩展运算符(...)

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

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

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

    2024/5/5 18:50:00
  14. Go语言常用命令详解(二)

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

    2024/5/4 14:46:11
  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/5 2:25:33
  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/4 21:24:42
  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/5 13:14:22
  18. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

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

    2024/5/4 13:16:06
  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/5 17:03:52
  20. 基于深度学习的恶意软件检测

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

    2024/5/5 21:10:50
  21. JS原型对象prototype

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

    2024/5/5 3:37:58
  22. C++中只能有一个实例的单例类

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

    2024/5/4 23:54:30
  23. python django 小程序图书借阅源码

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

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

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

    2024/5/5 15:25:31
  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