JAVA垃圾收集算法与内存泄露的解决方法

JAVA垃圾收集算法与内存泄露的解决方法

对于垃圾收集算法与内存泄露的问题,下面为大家整理了关于JAVA垃圾收集算法与内存泄露解决方法,希望对你有所帮助。

1.垃圾收集算法的核心思想

Java语言建立了垃圾收集机制,用以跟踪正在使用的对象和发现并回收不再使用(引用)的对象。该机制可以有效防范动态内存分配中可能发生的两个危险:因内存垃圾过多而引发的内存耗尽,以及不恰当的内存释放所造成的内存非法引用。

垃圾收集算法的核心思想是:对虚拟机可用内存空间,即堆空间中的对象进行识别,如果对象正在被引用,那么称其为存活对象,反之,如果对象不再被引用,则为垃圾对象,可以回收其占据的空间,用于再分配。垃圾收集算法的选择和垃圾收集系统参数的合理调节直接影响着系统性能,因此需要开发人员做比较深入的了解。

2.触发主GC(Garbage Collector)的条件

JVM进行次GC的频率很高,但因为这种GC占用时间极短,所以对系统产生的影响不大。更值得关注的是主GC的触发条件,因为它对系统影响很明显。总的来说,有两个条件会触发主GC:

①当应用程序空闲时,即没有应用线程在运行时,GC会被调用。因为GC在优先级最低的线程中进行,所以当应用忙时,GC线程就不会被调用,但以下条件除外。

②Java堆内存不足时,GC会被调用。当应用线程在运行,并在运行过程中创建新对象,若这时内存空间不足,JVM就会强制地调用GC线程,以便回收内存用于新的分配。若GC一次之后仍不能满足内存分配的要求,JVM会再进行两次GC作进一步的尝试,若仍无法满足要求,则 JVM将报“out of memory”的错误,Java应用将停止。

由于是否进行主GC由JVM根据系统环境决定,而系统环境在不断的变化当中,所以主GC的运行具有不确定性,无法预计它何时必然出现,但可以确定的是对一个长期运行的应用来说,其主GC是反复进行的。

3.减少GC开销的措施

根据上述GC的机制,程序的运行会直接影响系统环境的变化,从而影响GC的触发。若不针对GC的特点进行设计和编码,就会出现内存驻留等一系列负面影响。为了避免这些影响,基本的原则就是尽可能地减少垃圾和减少GC过程中的开销。具体措施包括以下几个方面:

(1)不要显式调用System.gc()

此函数建议JVM进行主GC,虽然只是建议而非一定,但很多情况下它会触发主GC,从而增加主GC的频率,也即增加了间歇性停顿的次数。

(2)尽量减少临时对象的使用

临时对象在跳出函数调用后,会成为垃圾,少用临时变量就相当于减少了垃圾的产生,从而延长了出现上述第二个触发条件出现的时间,减少了主GC的机会。

(3)对象不用时最好显式置为Null

一般而言,为Null的对象都会被作为垃圾处理,所以将不用的对象显式地设为Null,有利于GC收集器判定垃圾,从而提高了GC的效率。

(4)尽量使用StringBuffer,而不用String来累加字符串(详见blog另一篇文章JAVA中String与StringBuffer)

由于String是固定长的字符串对象,累加String对象时,并非在一个String对象中扩增,而是重新创建新的String对象,如Str5=Str1+Str2+Str3+Str4,这条语句执行过程中会产生多个垃圾对象,因为对次作“+”操作时都必须创建新的String对象,但这些过渡对象对系统来说是没有实际意义的,只会增加更多的垃圾。避免这种情况可以改用StringBuffer来累加字符串,因StringBuffer是可变长的,它在原有基础上进行扩增,不会产生中间对象。

(5)能用基本类型如Int,Long,就不用Integer,Long对象

基本类型变量占用的内存资源比相应对象占用的少得多,如果没有必要,最好使用基本变量。

(6)尽量少用静态对象变量

静态变量属于全局变量,不会被GC回收,它们会一直占用内存。

(7)分散对象创建或删除的时间

集中在短时间内大量创建新对象,特别是大对象,会导致突然需要大量内存,JVM在面临这种情况时,只能进行主GC,以回收内存或整合内存碎片,从而增加主GC的频率。集中删除对象,道理也是一样的。它使得突然出现了大量的垃圾对象,空闲空间必然减少,从而大大增加了下一次创建新对象时强制主GC的机会。

4.gc与finalize方法

⑴gc方法请求垃圾回收

使用System.gc()可以不管JVM使用的是哪一种垃圾回收的算法,都可以请求Java的垃圾回收。需要注意的是,调用System.gc()也仅仅是一个请求。JVM接受这个消息后,并不是立即做垃圾回收,而只是对几个垃圾回收算法做了加权,使垃圾回收操作容易发生,或提早发生,或回收较多而已。

⑵finalize方法透视垃圾收集器的运行

在JVM垃圾收集器收集一个对象之前 ,一般要求程序调用适当的方法释放资源,但在没有明确释放资源的情况下,Java提供了缺省机制来终止化该对象释放资源,这个方法就是finalize()。它的原型为:

protected void finalize() throws Throwable

在finalize()方法返回之后,对象消失,垃圾收集开始执行。原型中的throws Throwable表示它可以抛出任何类型的异常。

因此,当对象即将被销毁时,有时需要做一些善后工作。可以把这些操作写在finalize()方法里。

java 代码

protected void finalize()

{

// finalization code here

}

⑶代码示例

java 代码

class Garbage{

int index;

static int count;

Garbage() {

count++;

System.out.println("object "+count+" construct");

setID(count);

}

void setID(int id) {

index=id;

}

protected void finalize() //重写finalize方法

{

System.out.println("object "+index+" is reclaimed");

}

public static void main(String[] args)

{

new Garbage();

new Garbage();

new Garbage();

new Garbage();

System.gc(); //请求运行垃圾收集器

}

}

5.Java 内存泄漏

由于采用了垃圾回收机制,任何不可达对象(对象不再被引用)都可以由垃圾收集线程回收。因此通常说的Java 内存泄漏其实是指无意识的、非故意的对象引用,或者无意识的对象保持。无意识的对象引用是指代码的开发人员本来已经对对象使用完毕,却因为编码的错误而意外地保存了对该对象的引用(这个引用的存在并不是编码人员的主观意愿),从而使得该对象一直无法被垃圾回收器回收掉,这种本来以为可以释放掉的却最终未能被释放的空间可以认为是被“泄漏了”。

考虑下面的程序,在ObjStack类中,使用push和pop方法来管理堆栈中的对象。两个方法中的索引(index)用于指示堆栈中下一个可用位置。push方法存储对新对象的引用并增加索引值,而pop方法减小索引值并返回堆栈最上面的元素。在main方法中,创建了容量为64的栈,并64次调用push方法向它添加对象,此时index的值为64,随后又32次调用pop方法,则index的值变为32,出栈意味着在堆栈中的空间应该被收集。但事实上,pop方法只是减小了索引值,堆栈仍然保持着对那些对象的引用。故32个无用对象不会被GC回收,造成了内存渗漏。

java 代码

public class ObjStack {

private Object[] stack;

private int index;

ObjStack(int indexcount) {

stack = new Object[indexcount];

index = 0;

}

public void push(Object obj) {

stack[index] = obj;

index++;

}

public Object pop() {

index--;

return stack[index];

}

}

public class Pushpop {

public static void main(String[] args) {

int i = 0;

Object tempobj;

//new一个ObjStack对象,并调用有参构造函数。分配stack Obj数组的空间大小为64,可以存64个对象,从0开始存储

ObjStack stack1 = new ObjStack(64);

while (i < 64)

{

tempobj = new Object();//循环new Obj对象,把每次循环的对象一一存放在stack Obj数组中。

stack1.push(tempobj);

i++;

System.out.println("第" + i + "次进栈" + " ");

}

while (i > 32)

{

tempobj = stack1.pop();//这里造成了空间的浪费。

//正确的pop方法可改成如下所指示,当引用被返回后,堆栈删除对他们的引用,因此垃圾收集器在以后可以回收他们。

/*

* public Object pop() {index - -;Object temp = stack [index];stack [index]=null;return temp;}

*/

i--;

System.out.println("第" + (64 - i) + "次出栈" + " ");

}

}

}

6.如何消除内存泄漏

虽然Java虚拟机(JVM)及其垃圾收集器(garbage collector,GC)负责管理大多数的内存任务,Java软件程序中还是有可能出现内存泄漏。实际上,这在大型项目中是一个常见的问题。避免内存泄漏的第一步是要弄清楚它是如何发生的.。本文介绍了编写Java代码的一些常见的内存泄漏陷阱,以及编写不泄漏代码的一些最佳实践。一旦发生了内存泄漏,要指出造成泄漏的代码是非常困难的。因此本文还介绍了一种新工具,用来诊断泄漏并指出根本原因。该工具的开销非常小,因此可以使用它来寻找处于生产中的系统的内存泄漏。

垃圾收集器的作用

虽然垃圾收集器处理了大多数内存管理问题,从而使编程人员的生活变得更轻松了,但是编程人员还是可能犯错而导致出现内存问题。简单地说,GC循环地跟踪所有来自“根”对象(堆栈对象、静态对象、JNI句柄指向的对象,诸如此类)的引用,并将所有它所能到达的对象标记为活动的。程序只可以操纵这些对象;其他的对象都被删除了。因为GC使程序不可能到达已被删除的对象,这么做就是安全的。

虽然内存管理可以说是自动化的,但是这并不能使编程人员免受思考内存管理问题之苦。例如,分配(以及释放)内存总会有开销,虽然这种开销对编程人员来说是不可见的。创建了太多对象的程序将会比完成同样的功能而创建的对象却比较少的程序更慢一些(在其他条件相同的情况下)。

而且,与本文更为密切相关的是,如果忘记“释放”先前分配的内存,就可能造成内存泄漏。如果程序保留对永远不再使用的对象的引用,这些对象将会占用并耗尽内存,这是因为自动化的垃圾收集器无法证明这些对象将不再使用。正如我们先前所说的,如果存在一个对对象的引用,对象就被定义为活动的,因此不能删除。为了确保能回收对象占用的内存,编程人员必须确保该对象不能到达。这通常是通过将对象字段设置为null或者从集合(collection)中移除对象而完成的。但是,注意,当局部变量不再使用时,没有必要将其显式地设置为null。对这些变量的引用将随着方法的退出而自动清除。

概括地说,这就是内存托管语言中的内存泄漏产生的主要原因:保留下来却永远不再使用的对象引用。

典型泄漏

既然我们知道了在Java中确实有可能发生内存泄漏,就让我们来看一些典型的内存泄漏及其原因。

全局集合

在大的应用程序中有某种全局的数据储存库是很常见的,例如一个JNDI树或一个会话表。在这些情况下,必须注意管理储存库的大小。必须有某种机制从储存库中移除不再需要的数据。

这可能有多种方法,但是最常见的一种是周期性运行的某种清除任务。该任务将验证储存库中的数据,并移除任何不再需要的数据。

另一种管理储存库的方法是使用反向链接(referrer)计数。然后集合负责统计集合中每个入口的反向链接的数目。这要求反向链接告诉集合何时会退出入口。当反向链接数目为零时,该元素就可以从集合中移除了。

缓存

缓存是一种数据结构,用于快速查找已经执行的操作的结果。因此,如果一个操作执行起来很慢,对于常用的输入数据,就可以将操作的结果缓存,并在下次调用该操作时使用缓存的数据。

缓存通常都是以动态方式实现的,其中新的结果是在执行时添加到缓存中的。典型的算法是:

检查结果是否在缓存中,如果在,就返回结果。

如果结果不在缓存中,就进行计算。

将计算出来的结果添加到缓存中,以便以后对该操作的调用可以使用。

该算法的问题(或者说是潜在的内存泄漏)出在最后一步。如果调用该操作时有相当多的不同输入,就将有相当多的结果存储在缓存中。很明显这不是正确的方法。

为了预防这种具有潜在破坏性的设计,程序必须确保对于缓存所使用的内存容量有一个上限。因此,更好的算法是:

检查结果是否在缓存中,如果在,就返回结果。

如果结果不在缓存中,就进行计算。

如果缓存所占的空间过大,就移除缓存最久的结果。

将计算出来的结果添加到缓存中,以便以后对该操作的调用可以使用。

通过始终移除缓存最久的结果,我们实际上进行了这样的假设:在将来,比起缓存最久的数据,最近输入的数据更有可能用到。这通常是一个不错的假设。

新算法将确保缓存的容量处于预定义的内存范围之内。确切的范围可能很难计算,因为缓存中的对象在不断变化,而且它们的引用包罗万象。为缓存设置正确的大小是一项非常复杂的任务,需要将所使用的内存容量与检索数据的速度加以平衡。

解决这个问题的另一种方法是使用java.lang.ref.SoftReference类跟踪缓存中的对象。这种方法保证这些引用能够被移除,如果虚拟机的内存用尽而需要更多堆的话。

ClassLoader

Java ClassLoader结构的使用为内存泄漏提供了许多可乘之机。正是该结构本身的复杂性使ClassLoader在内存泄漏方面存在如此多的问题。ClassLoader的特别之处在于它不仅涉及“常规”的对象引用,还涉及元对象引用,比如:字段、方法和类。这意味着只要有对字段、方法、类或ClassLoader的对象的引用,ClassLoader就会驻留在JVM中。因为ClassLoader本身可以关联许多类及其静态字段,所以就有许多内存被泄漏了。

确定泄漏的位置

通常发生内存泄漏的第一个迹象是:在应用程序中出现了OutOfMemoryError。这通常发生在您最不愿意它发生的生产环境中,此时几乎不能进行调试。有可能是因为测试环境运行应用程序的方式与生产系统不完全相同,因而导致泄漏只出现在生产中。在这种情况下,需要使用一些开销较低的工具来监控和查找内存泄漏。还需要能够无需重启系统或修改代码就可以将这些工具连接到正在运行的系统上。可能最重要的是,当进行分析时,需要能够断开工具而保持系统不受干扰。

虽然OutOfMemoryError通常都是内存泄漏的信号,但是也有可能应用程序确实正在使用这么多的内存;对于后者,或者必须增加JVM可用的堆的数量,或者对应用程序进行某种更改,使它使用较少的内存。但是,在许多情况下,OutOfMemoryError都是内存泄漏的信号。一种查明方法是不间断地监控GC的活动,确定内存使用量是否随着时间增加。如果确实如此,就可能发生了内存泄漏。

拓展:

java垃圾回收机制是怎样的

手动管理内存

在介绍现代版的垃圾回收之前,我们先来简单地回顾下需要手动地显式分配及释放内存的那些日子。如果你忘了去释放内存,那么这块内存就无法重用了。这块内存被占有了却没被使用。这种场景被称之为内存泄露。

下面是用C写的一个手动管理内存的简单例子:

int send_request()

{

size_t n = read_size();

int *elements = malloc(n * sizeof(int));

if(read_elements(n, elements) < n)

{ // elements not freed! return -1; } // … free(elements)

return 0;}

可以看到,你很容易就会忘了释放内存。内存泄露曾经是个非常普遍的问题。你只能通过不断地修复自己的代码来与它们进行抗争。因此,需要有一种更优雅的方式来自动释放无用内存,以便减少人为错误的可能性。这种自动化过程又被称为垃圾回收(简称GC)。

智能指针

自动垃圾回收早期的一种实现便是引用计数。你知晓每一个对象被引用了几次,当计数器归0的时候,这个对象就可以被安全地回收掉了。C++的共享指针就是一个非常著名的例子:

11int send_request() { size_t n = read_size(); stared_ptrelements = make_shared(); if(read_elements(n, elements) < n) { return -1; } return 0;}

我们使用的sharedptr会记录这个对象被引用的次数。如果你将它传递给别人则计数加一,当它离开了作用域后便会减一。一旦这个计数为0,sharedptr会自动地删除底层对应的vector。当然这只是个示例,因为也有读者指出来了,这个在现实中是不太可能出现的,但作为演示是足够了。

自动内存管理

在上面的C++代码中,我们还得显式地声明我们需要使用内存管理。那如果所有的对象都采用这个机制会怎样呢?那简直就太方便了,这样开发人员便无需 考虑清理内存的事情了。运行时会自动知晓哪些内存不再使用了,然后释放掉它。也就是说,它自动地回收了这些垃圾。第一代的垃圾回收器是1959年Lisp 引入的,这项技术迄今为止一直在不断演进。

引用计数

刚才我们用C++的共享指针所演示的想法可以应用到所有的对象上来。许多语言比如说Perl, Python以及PHP,采用的都是这种方式。这个通过一张***可以很容易说明:

绿色的云代表的是程序中仍在使用的对象。从技术层面上来说,这有点像是正在执行的某个方法里面的局部变量,亦或是静态变量之类的。不同编程语言的情况可能会不一样,因此这并不是我们关注的重点。

蓝色的圆圈代表的是内存中的对象,可以看到有多少对象引用了它们。灰色圆圈的对象是已经没有任何人引用的了。因此,它们属于垃圾对象,可以被垃圾回收器清理掉。

看起来还不错对吧?没错,不过这里存在着一个重大的缺陷。很容易会出现一些孤立的环,它们中的对象都不在任何域内,但彼此却互相引用导致引用数不为0。下面便是一个例子:

看到了吧,红色部分其实就是应用程序不再使用的垃圾对象。由于引用计数的缺陷,因此会存在内存泄露。

有几种方法可以解决这一问题,比如说使用特殊的“弱”引用,或者使用一个特殊的算法回收循环引用。之前提到的Perl,Python以及PHP等语言,都是使用类似的方法来回收循环引用的,不过这已经超出本文讲述的范围了。我们准备详细介绍下JVM所采用的方法。

标记删除

首先,JVM对于对象可达性的定义要明确一些。它可不像前面那样用绿色的云便含煳了事的,而是有着非常明确及具体的垃圾回收根对象(Garbage Collection Roots)的定义:

局部变量

活动线程

静态字段

JNI引用

其它(后面将会讨论到)

JVM通过标记删除的算法来记录所有可达(存活)对象,同时确保不可达对象的那些内存能够被重用。这包含两个步骤:

标记是指遍历所有可达对象,然后在本地内存中记录这些对象的信息

删除会确保不可达对象的内存地址可以在下一次内存分配中使用。

JVM中的不同GC算法,比如说Parallel Scavenge,Parallel Mark+Copy, CMS都是这一算法的不同实现,只是各阶段略有不同而已,从概念上来讲仍然是对应着上面所说的那两个步骤。

这种实现最重要的就是不会再出现泄露的对象环了:

缺点就是应用程序的线程需要被暂停才能完成回收,如果引用一直在变的话你是无法进行计数的。这个应用程序被暂停以便JVM可以收拾家务的情况又被称为Stop The World pause(STW)。这种暂停被触发的可能性有很多,不过垃圾回收应该是最常见的一种。

JAVA垃圾收集算法与内存泄露的解决方法

转载请注明出处我优求知网 » JAVA垃圾收集算法与内存泄露的解决方法

学习

关于蛇的吉祥成语

阅读(57)

本文为您介绍关于蛇的吉祥成语,内容包括关于蛇的吉祥成语大全,两条蛇一个七成语。成语是中国传统文化的一大特色,有固定的结构形式和固定的说法,表示一定的意义,在语句中是作为一个整体来应用的,承担主语、宾语、定语等成分。成语有很大一部

学习

组织生活会组织委员发言材料

阅读(422)

本文为您介绍组织生活会组织委员发言材料,内容包括组织生活会组织委员发言,组织委员民主生活会发言材料。通过学习与工作,对自身存在的问题和不足有了更深的了解,结合自我的思想状况、工作实际进行自我反思和批评是很重要的。下面是收集整

学习

不辣火锅底料的做法

阅读(68)

本文为您介绍不辣火锅底料的做法,内容包括不辣火锅底料的做法家常,不辣的火锅底料哪个牌子好。不喜欢吃辣的朋友当然也不能做辣的火锅底料了,下面就为你介绍一下不辣火锅底料的做法吧!

学习

关于蛇的谜语及谜底

阅读(53)

本文为您介绍关于蛇的谜语及谜底,内容包括关于蛇的谜语和答案,青青蛇儿满地爬谜语答案。谜面是灯谜的主要部分,是猜谜时以隐语的形式表达描绘形象、性质、功能等特征,供人们猜射的说明文字。下面是收集整理的关于蛇的谜语及谜底,希望对您有

学习

包工不包料建房合同范本

阅读(43)

本文为您介绍包工不包料建房合同范本,内容包括建房合同包工包料范本,建房包工不包料合同书怎样写。随着法律法规不断完善,人们越发重视合同,能够利用到合同的场合越来越多,签订合同也是最有效的法律依据之一。你所见过的合同是什么样的呢?下

学习

谜底是蓝球的谜语

阅读(35)

本文为您介绍谜底是蓝球的谜语,内容包括双色球蓝球谜语最新,打篮球的谜语有什么。谜语主要指暗射事物或文字等供人猜测的隐语,也可引申为蕴含奥秘的事物。下面是收集整理的谜底是蓝球的谜语,仅供参考,大家一起来看看吧。

学习

学校的组织意见

阅读(34)

本文为您介绍学校的组织意见,内容包括学校的组织意见怎么写,学校组织意见100字。对于学校的组织意见,一般是怎么写?下面是整理提供的学校组织意见,欢迎阅读参考!希望大家采纳!

学习

《暖暖》歌词

阅读(35)

本文为您介绍《暖暖》歌词,内容包括暖暖歌词完整版,暖暖歌词文字。《暖暖》是梁静茹演唱的歌曲,由李焯雄作词,人工卫星谱曲,收录于2006年10月6日梁静茹发行的第8张专辑《亲亲》中,是梁静茹甜蜜情歌的代表作之一,是《周末父母》电视剧片头曲。

学习

萧乾《吆喝》阅读理解及答案

阅读(56)

本文为您介绍萧乾《吆喝》阅读理解及答案,内容包括吆喝萧乾读书笔记,萧乾的吆喝ppt。语文阅读在平时测试、期末考试中都占有很大的比重,所以,多做一些阅读练习,不仅能熟能生巧,轻松应对考试,最重要的,对于语文学习能力的提高非常有帮助。下面

学习

关于GDP思考论文参考文献

阅读(62)

本文为您介绍关于GDP思考论文参考文献,内容包括关于gdp数据分析的论文摘要,有关gdp论文的文献综述。在个人成长的多个环节中,大家总少不了接触论文吧,借助论文可以有效提高我们的写作水平。相信写论文是一个让许多人都头痛的问题,下面是帮

学习

买社保有什么好处

阅读(49)

本文为您介绍买社保有什么好处,内容包括买社保有什么好处和哪些坏处,买社保有什么好处有退休金吗。社会保险的主要项目包括养老保险、医疗保险、失业保险、工伤保险、生育保险。接下来为大家整理出买社保有什么好处,希望能够帮助到大家!

学习

读萧相国世家有感

阅读(297)

本文为您介绍读萧相国世家有感,内容包括萧相国世家翻译,读史记萧相国世家有感。当看完一本著作后,相信大家都增长了不少见闻,需要回过头来写一写读后感了。是不是无从下笔、没有头绪?以下是帮大家整理的读萧相国世家有感,欢迎大家分享。

学习

个人所得税税率表

阅读(187)

本文为您介绍个人所得税税率表,内容包括个人所得税税率表2023,个人所得税税率表及速算扣除数。个人所得税率是个人所得税税额与应纳税所得额之间的比例。个人所得税率是由国家相应的法律法规规定的,根据个人的收入计算。缴纳个人所得税是

学习

萧湖公园作文

阅读(31)

本文为您介绍萧湖公园作文,内容包括萧湖公园作文如何写,萧湖公园作文100字。在学习、工作乃至生活中,大家都接触过作文吧,借助作文人们可以反映客观事物、表达思想感情、传递知识信息。那要怎么写好作文呢?以下是收集整理的萧湖公园作文,仅

学习

疏通皮肤毛孔的方法

阅读(65)

毛孔对于美眉们是至关重要的东西,即使毛孔看上去很小,不足以对我们构成威胁,但是毛孔的威力却是无穷大的,它是我们皮肤呼吸的重要器官,一旦毛孔堵塞,我们的皮肤就会长斑、长痘痘、出油,下面是整理的疏通皮肤毛孔的方法,希望对你有帮助!

学习

人力资源的预测方法

阅读(41)

本文为您介绍人力资源的预测方法,内容包括人力资源的预测方法有哪些,人力资源供给预测方法。不同的管理的预测可能有偏差,但可以通过多人综合预测或查阅历史记录等方法提高预测的准确率。要注意的是经验预测法只适合于一定时期的企业的发

学习

长篇小说的写作方法攻略

阅读(102)

本文为您介绍长篇小说的写作方法攻略,内容包括长篇小说写作技巧,怎么用手机写作长篇小说。在现实学习生活中,大家最不陌生的就是知识点吧!知识点有时候特指教科书上或考试的知识。相信很多人都在为知识点发愁,以下是收集整理的长篇小说的写

学习

平板电脑黑屏的解决方法

阅读(253)

本文为您介绍平板电脑黑屏的解决方法,内容包括平板电脑黑屏但是有声音,平板电脑黑屏开不了机解决方法。电脑黑屏是比较容易出现的现象,尤其在一些较老的电脑或组装电脑中。电脑黑屏的故障原因有多种,如显示器损坏、主板损坏、显卡损坏、显

学习

天猫魔盒链接电视的方法

阅读(60)

本文为您介绍天猫魔盒链接电视的方法,内容包括天猫魔盒安装电视家3.0,天猫魔盒怎样投屏到电视。魔盒头部采用双色注塑工艺,环保全进口材料;正面采用亚光喷涂表面处理,色彩鲜艳持久,富有质感;背面采用专业的ABS汽车工程塑料,厚实,增加众多加强筋

学习

去除纹身常用的三种方法

阅读(87)

本文为您介绍去除纹身常用的三种方法,内容包括去除纹身激光得花多少钱,a级b级去除纹身怎么用。很多朋友纹身之后,碍于很多原因又想去除纹身,有哪些方法可以去除纹身呢?下面为大家整理了去除纹身常用的三种方法,希望能帮到大家!

学习

熬夜的弥补方法

阅读(88)

本文为您介绍熬夜的弥补方法,内容包括经常熬夜怎么弥补,熬夜有什么弥补的方法吗。熬夜是一种现代生活经常听到或者做到的一种现象,是一种危害人的身体的不良习惯,可导致一些疾病,降低效率。熬夜是不良习惯的一种,容易缺乏内源氧。以下是为大

学习

学好物理的方法与技巧

阅读(60)

本文为您介绍学好物理的方法与技巧,内容包括初中生学好物理的方法和技巧,如何学好物理的方法和技巧。在日常生活或是工作,学习中,大家一定都或多或少地接触过一些物理知识,下面是为大家收集的有关学好物理的方法与技巧相关内容,仅供参考,希望