The connection to adb is down, and a severe error has occure

 更新时间:2016年11月11日 16:16  点击:1940
下面我们来看一篇关于安卓开发时碰到的The connection to adb is down, and a severe error has occure问题解决办法.

如果开发的时候遇到Eclipse冒出这句,怎?办呢?
 
很简单,请先按照以下的步骤做:
 
    如果Eclipse正打开著,请先关闭Eclipse
    [开始]>[执行],输入"cmd"
    切换目录到Android SDK中的platform-tools的目录下
    (以我个人?槔?ndroid SDK安装在C:\Program Files\Android\android-sdk,所以输入"cd C:\Program Files\Android\android-sdk\platform-tools",按下Enter即可)
    输入"adb kill-server"
    接著输入"adb start-server"
    如果你没有看到任何错误讯息,且看到server成功的?⒍??蔷?K了
    现在,就可以将Eclipse重新打开来试试看萝
 
例外处理:
 
    如果在adb start-server无法顺利?⒍?db server,可以?袢∫韵路椒?br />     a. ?⒍?indows工作管理员,并切换到处理程序
    b. 找到所有adb.exe,并且强制结束
    c. 回到以上步骤5,再试试看是否可以顺利?⒍?db server
 
    P.S. 如果是在Unix or Linux,请输入ps -A|grep "adb",找到adb的PID,然后输入kill 即可
    如果adb server已经重起成功,但是还是无法连接,可尝试将手机重新开机,也可以解决此状况

下面我们来看一篇关于Android内存泄露常见问题总结,希望这篇文章能够帮助到各位朋友,有兴趣的朋友可以进来看看吧.

 在介绍内存泄漏之前很有必要提及一下Android系统的垃圾回收机制。Java GC(Garbage Collection,垃圾收集,垃圾回收)机制,是Java与C++/C的主要区别之一,作为Java开发者,不需要专门编写内存回收和垃圾清理代码,对内存泄露和溢出的问题,也不需要像C程序员那样战战兢兢。这是因为在Java虚拟机中,存在自动内存管理和垃圾清扫机制。概括地说,该机制对虚拟机中的内存进行标记,并确定哪些内存需要回收,根据一定的回收策略,自动的回收内存,永不停息(Nerver Stop)的保证虚拟机中的内存空间,防止出现内存泄露和溢出问题。Android系统的垃圾回收是基于可达性分析算法(根搜索算法)的。从GC Roots(每种具体实现对GC Roots有不同的定义)作为起点,向下搜索它们引用的对象,可以生成一棵引用树,树的节点视为可达对象,反之视为不可达,不可达对象会被回收。
    举个例子,我们在开发中经常使用单例模式,单例的静态特性导致其生命周期同应用一样长。有时创建单例时如果我们需要Context对象,如果传入的是Application的Context那么不会有问题。如果传入的是Activity的Context对象,那么当Activity生命周期结束时,该Activity的引用依然被单例持有,所以不会被回收,而单例的生命周期又是跟应用一样长,这个情况就叫做内存泄露(Memory Leak)。它指的是当你不再需要某个实例后,但是这个对象却仍然被引用,防止被垃圾回收(Prevent from being bargage collected)。
public class Util {
    private Context mContext;
    private static Util sInstance;
    private Util(Context context) {
        this.mContext = context;
    }
    public static Util getInstance(Context context) {
        if (sInstance == null) {
            sInstance = new Util(context);
        }
        return sInstance;
    }
}
本杰明 富兰克林曾说:A small leak will sink a great ship(小漏不补沉大船)。基于Android系统的设备一般来说内存就不大,特别是早期的Android设备,内存泄漏是很致命的,内存泄漏积攒到一定程度会引发内存溢出(OOM),如果处理不当直接导致程序崩溃退出。
常见的内存泄漏
一般来说在开发中我们经常会犯下下面几个错误,导致内存泄漏。这几个都是前人踩坑总结出来的,非常有参考价值,至少我在排查解决内存泄漏的时候是这样的。
一. 单例造成的内存泄漏

Android的单例模式非常受开发者的喜爱,不过使用的不恰当的话也会造成内存泄漏。因为单例的静态特性使得单例的生命周期和应用的生命周期一样长,这就说明了如果一个对象已经不需要使用了,而单例对象还持有该对象的引用,那么这个对象将不能被正常回收,这就导致了内存泄漏。例子见上面那段代码。
二、非静态内部类创建静态实例造成的内存泄漏

有的时候我们可能会在启动频繁的Activity中,为了避免重复创建相同的数据资源,在Activity内部创建了一个非静态内部类的单例,每次启动Activity时都会使用该单例的数据,这样虽然避免了资源的重复创建,不过这种写法却会造成内存泄漏,因为非静态内部类默认会持有外部类的引用,而又使用了该非静态内部类创建了一个静态的实例,该实例的生命周期和应用的一样长,这就导致了该静态实例一直会持有该Activity的引用,导致Activity的内存资源不能正常回收。例子如下
public class MainActivity extends AppCompatActivity {

    private static TestResource mResource = null;

    @Override
    protected void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        setContentView(R.layout.activity_main);

        if (mResource == null) {

            mResource = new TestResource();

        }

        //......

    }

    class TestResource {

        //......

    }

}
三、Handler造成的内存泄漏

Handler的使用造成的内存泄漏问题应该说最为常见了,平时在处理网络任务或者封装一些请求回调等api都应该会借助Handler来处理,我们经常在Activity里面这样定义一个私有的Handler对象并初始化,这种创建Handler的方式会造成内存泄漏,由于mHandler是Handler的非静态匿名内部类的实例,所以它持有外部类Activity的引用,我们知道消息队列是在一个Looper线程中不断轮询处理消息,那么当这个Activity退出时消息队列中还有未处理的消息或者正在处理消息,而消息队列中的Message持有mHandler实例的引用,mHandler又持有Activity的引用,所以导致该Activity的内存资源无法及时回收,引发内存泄漏。
private Handler mHandler = new Handler() {

    @Override
    public void handleMessage(Message msg) {

        //.....

    }
};
四、资源未关闭造成的内存泄漏

对于使用了BraodcastReceiver,ContentObserver,File,Cursor,Stream,Bitmap等资源的使用,应该在Activity销毁时及时关闭或者注销,否则这些资源将不会被回收,造成内存泄漏。
检测内存泄漏的常见工具
LeakCanary是Square开源了一个内存泄露自动探测神器 。对应的github仓库地址:https://github.com/square/leakcanary  。使用非常简单,在build.gradle中引入包依赖:
debugCompile 'com.squareup.leakcanary:leakcanary-
android:1.5'
releaseCompile 'com.squareup.leakcanary:leakcanary-
android-no-op:1.5'
testCompile 'com.squareup.leakcanary:leakcanary-
android-no-op:1.5'
在Application中的onCreate方法中增加初始化代码:

if (LeakCanary.isInAnalyzerProcess(this)) {
    // This process is dedicated to LeakCanary for
    // heap analysis.
    // You should not init your app in this process.
    return;
}
LeakCanary.install(this);
集成后什么都不用做,按照正常测试,当有内存泄漏发生后,应用会通过系统通知栏发出通知,点击通知就可以进入查看内存泄漏的具体信息。其实无论是MAT工具的内存分析,还是AndroidStudio中自带的分析工具亦或是LeakCanary,原理都是一样的,都是dump java heap出来进行分析,找到泄漏的问题,只是LeakCanary帮我们把分析的工作做了。

Android应用程序启动时出现白色背景问题要如何来解决呢,我们下面就一起来看一篇关于启动时的一些小问题,具体的如下文介绍.

Android应用程序开发过程中,为了使应用程序有更好的用户体验,常常在启动应用程序时添加启动页,但是在添加启动页的时候,我们会发现,在启动该应用时会出现白色背景,然后才进入我们设定的启动页背景。

解决方法如下:

在style中创建一个启动activity的style,my_welcome_background即是你需要显示的启动页背景图,然后将下面的style添加到manifest文件中的启动页activity中的Theme属性中。

<style name="WelcomeTheme" parent="Theme.AppCompat.Light.NoActionBar">
  <item name="windowActionBar">false</item>
  <item name="windowNoTitle">true</item>
  <item  name="android:windowBackground">@drawable/my_welcome_background</item>
</style>

manifest文件修改如下:

<activity
            android:name=".views.WelcomeActivity"
            android:label="@string/app_name"
            android:launchMode="singleTask"
            android:theme="@style/WelcomeTheme">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
</activity>

下面我们来看一篇关于ListView移动到指定位置的例子吧,希望文章能够给各位朋友带来帮助,具体的如下介绍.

关于ListView移动到指定位置有两种方法

listview.setSelection(position);
 
listview.smoothScrollToPosition(position);

第一种方法没有滚动效果,直接跳到指定位置,第二种方法是有滚动效果的。

但是,在是用的时候,你会发现第二种方法没有效果,甚至都没有移动,其实这个问题很好解决,只要在新线程里是用就可以了


listview.post(new Runnable() {
    @Override
    public void run() {
        listview.smoothScrollToPosition(position);
    }
});
 

[!--infotagslink--]

相关文章