安卓手机把程序安装在SD卡上的同时会安装一部分容量到内存卡里吗?
楼主你好
大部分是不会的
但是有一部分软件在注册使用的过程中会在手机内存
安装临时文件 占用一部分内存的
希望我的回答可以帮到你
谢谢采纳
怎么把SD卡里面的安装程序安装在SD卡里?先安装程序,安装好后,在卸载程序的界面点这个程序就会出现该程序的信息,会有一个移至USB存储设备的按钮,这个就是把程序移动到SD卡。
安卓237应用程序安装在SD卡里不显示 移到内存里就可以显示是什么程序?我帮朋友的HTC的G12装一些软件,也是这样,后来才发现,主要是一些桌面插件类的程序,装SD卡上的话,就不能在桌面添加插件。必须装在手机内。因为一旦连接电脑后,手机会暂时无法读取SD卡,会导致插件出错的。
游戏啊,或者非插件类软件,是可以装在SD卡的。
插件类软件主要如第三方桌面、墨迹天气、万年历、电量显示等等。
中兴n600手机怎么把程序安装在内存卡上你把下下来的apk文件(安装文件)直接放在内存卡里,点安装文件手机就会问你安不安装,安装以后就在内存卡上了。
怎样可以把程序安装在SD卡上而不占手机本身内存!设置------应用程序------首选安装位置必须是刷过机的22版本,和1716版本上月我入手的新机是固件21,软件1635版本
安装时,程序是安装在手机内存还是内存卡上?
尊敬的电信用户,您好!根据您所问的问题
,安装的软件默认是在手机内存上的,可以根据您的需要,可以移动到内存卡里。
希望我的回答对您有所帮助,如有疑问,欢迎登陆广东电信手机商城百度知道企业平台,向客服提问,或搜索百度广东电信手机商城登陆了解最优惠机型!
一般大点的软件最好是安装在内存卡上面,如果安装在手机内存里面,可能会影响手机的运行速度
您好,程序可以安装在手机内存上或内存卡上。谢谢您对电信产品的关注,祝您生活愉快。 如果以上信息没有解决您的问题,也可登录广东电信手机商城(:mgd189),向在线客服求助,7X24小时在线喔!
Android代码优化技术
1Java内存控制 对于字符串 *** 作而言如果需要连加这样的 *** 作建议使用StringBuilder,经过调试不难发现如果字符串每次连加,使用String需要的内存开销会远大于StringBuilder,然后Android手机常规的运行内存大约在128MB左右,对于运行多任务就需要考虑了,Android开发网提示因为Java有GC不需要手动释放那么分配的时候就要格外的小心,频繁的GC *** 作仍然是很影响性能的,在调试时可以通过logcat查看内存释放情况。
2循环使用 平时在访问一个属性的时候效率远比一个固定变量低,如果循环估计次数常常大于5,假设xxxGetLength()方法的值一般大于5,推荐这样写,比如 for(int i=0;i<xxxGetLength();i++) 这里xxxGetLength在每次循环都要调用,必然会影响程序效率,在游戏开发中显得更为明显,改进的方法应该为 int j=xxxGetLength() for(int i=0;i<j;i++)
3的优化 在Android平台中2维图像处理库BitmapFactory做的比较智能,为了减少文件体积和效率,常常不用很多资源文件,而把很多小放在一个中,有切片的方式来完成,在J2ME中这样是为了将少文件头而解决MIDP这些设备的问题,而Android中虽然机型硬件配置都比较高,有关Android G1硬件配置可以参考G1手机参数以及评测,但是当资源多时这样的运行效率还是令人满意的,至少Dalvik优化的还不是很够。
(Memory Leak,内存泄漏)
当一个对象已经不需要再使用本该被回收时,另外一个正在使用的对象持有它的引用从而导致它不能被回收,这导致本该被回收的对象不能被回收而停留在堆内存中,这就产生了内存泄漏。
内存泄漏是造成应用程序OOM的主要原因之一。我们知道Android系统为每个应用程序分配的内存是有限的,而当一个应用中产生的内存泄漏比较多时,这就难免会导致应用所需要的内存超过系统分配的内存限额,这就造成了内存溢出从而导致应用Crash。
因为内存泄漏是在堆内存中,所以对我们来说并不是可见的。通常我们可以借助MAT、LeakCanary等工具来检测应用程序是否存在内存泄漏。
1、MAT是一款强大的内存分析工具,功能繁多而复杂。
2、LeakCanary则是由Square开源的一款轻量级的第三方内存泄漏检测工具,当检测到程序中产生内存泄漏时,它将以最直观的方式告诉我们哪里产生了内存泄漏和导致谁泄漏了而不能被回收。
由于单例的静态特性使得其生命周期和应用的生命周期一样长,如果一个对象已经不再需要使用了,而单例对象还持有该对象的引用,就会使得该对象不能被正常回收,从而导致了内存泄漏。
示例:防止单例导致内存泄漏的实例
这样不管传入什么Context最终将使用Application的Context,而单例的生命周期和应用的一样长,这样就防止了内存泄漏。???
例如,有时候我们可能会在启动频繁的Activity中,为了避免重复创建相同的数据资源,可能会出现如下写法:
这样在Activity内部创建了一个非静态内部类的单例,每次启动Activity时都会使用该单例的数据。虽然这样避免了资源的重复创建,但是这种写法却会造成内存泄漏。因为非静态内部类默认会持有外部类的引用,而该非静态内部类又创建了一个静态的实例,该实例的生命周期和应用的一样长,这就导致了该静态实例一直会持有该Activity的引用,从而导致Activity的内存资源不能被正常回收。
解决方法 :将该内部类设为静态内部类或将该内部类抽取出来封装成一个单例,如果需要使用Context,就使用Application的Context。
示例:创建匿名内部类的静态对象
1、从Android的角度
当Android应用程序启动时,该应用程序的主线程会自动创建一个Looper对象和与之关联的MessageQueue。当主线程中实例化一个Handler对象后,它就会自动与主线程Looper的MessageQueue关联起来。所有发送到MessageQueue的Messag都会持有Handler的引用,所以Looper会据此回调Handle的handleMessage()方法来处理消息。只要MessageQueue中有未处理的Message,Looper就会不断的从中取出并交给Handler处理。另外,主线程的Looper对象会伴随该应用程序的整个生命周期。
2、 Java角度
在Java中,非静态内部类和匿名类内部类都会潜在持有它们所属的外部类的引用,但是静态内部类却不会。
对上述的示例进行分析,当MainActivity结束时,未处理的消息持有handler的引用,而handler又持有它所属的外部类也就是MainActivity的引用。这条引用关系会一直保持直到消息得到处理,这样阻止了MainActivity被垃圾回收器回收,从而造成了内存泄漏。
解决方法 :将Handler类独立出来或者使用静态内部类,这样便可以避免内存泄漏。
示例:AsyncTask和Runnable
AsyncTask和Runnable都使用了匿名内部类,那么它们将持有其所在Activity的隐式引用。如果任务在Activity销毁之前还未完成,那么将导致Activity的内存资源无法被回收,从而造成内存泄漏。
解决方法 :将AsyncTask和Runnable类独立出来或者使用静态内部类,这样便可以避免内存泄漏。
对于使用了BraodcastReceiver,ContentObserver,File,Cursor,Stream,Bitmap等资源,应该在Activity销毁时及时关闭或者注销,否则这些资源将不会被回收,从而造成内存泄漏。
1)比如在Activity中register了一个BraodcastReceiver,但在Activity结束后没有unregister该BraodcastReceiver。
2)资源性对象比如Cursor,Stream、File文件等往往都用了一些缓冲,我们在不使用的时候,应该及时关闭它们,以便它们的缓冲及时回收内存。它们的缓冲不仅存在于 java虚拟机内,还存在于java虚拟机外。如果我们仅仅是把它的引用设置为null,而不关闭它们,往往会造成内存泄漏。
3)对于资源性对象在不使用的时候,应该调用它的close()函数将其关闭掉,然后再设置为null。在我们的程序退出时一定要确保我们的资源性对象已经关闭。
4)Bitmap对象不在使用时调用recycle()释放内存。23以后的bitmap应该是不需要手动recycle了,内存已经在java层了。
初始时ListView会从BaseAdapter中根据当前的屏幕布局实例化一定数量的View对象,同时ListView会将这些View对象缓存起来。当向上滚动ListView时,原先位于最上面的Item的View对象会被回收,然后被用来构造新出现在下面的Item。这个构造过程就是由getView()方法完成的,getView()的第二个形参convertView就是被缓存起来的Item的View对象(初始化时缓存中没有View对象则convertView是null)。
构造Adapter时,没有使用缓存的convertView。
解决方法 :在构造Adapter时,使用缓存的convertView。
我们通常把一些对象的引用加入到了集合容器(比如ArrayList)中,当我们不需要该对象时,并没有把它的引用从集合中清理掉,这样这个集合就会越来越大。如果这个集合是static的话,那情况就更严重了。
解决方法 :在退出程序之前,将集合里的东西clear,然后置为null,再退出程序。
当我们不要使用WebView对象时,应该调用它的destory()函数来销毁它,并释放其占用的内存,否则其长期占用的内存也不能被回收,从而造成内存泄露。
解决方法 :为WebView另外开启一个进程,通过AIDL与主线程进行通信,WebView所在的进程可以根据业务的需要选择合适的时机进行销毁,从而达到内存的完整释放。
1、在涉及使用Context时,对于生命周期比Activity长的对象应该使用Application的Context。凡是使用Context优先考虑Application的Context,当然它并不是万能的,对于有些地方则必须使用Activity的Context。对于Application,Service,Activity三者的Context的应用场景如下:
其中,NO1表示Application和Service可以启动一个Activity,不过需要创建一个新的task任务队列。而对于Dialog而言,只有在Activity中才能创建。除此之外三者都可以使用。
2、对于需要在静态内部类中使用非静态外部成员变量(如:Context、View ),可以在静态内部类中使用弱引用来引用外部类的变量来避免内存泄漏。
3、对于不再需要使用的对象,显示的将其赋值为null,比如使用完Bitmap后先调用recycle(),再赋为null。
4、保持对对象生命周期的敏感,特别注意单例、静态对象、全局性集合等的生命周期。
5、对于生命周期比Activity长的内部类对象,并且内部类中使用了外部类的成员变量,可以这样做避免内存泄漏:
1)将内部类改为静态内部类
2)静态内部类中使用弱引用来引用外部类的成员变量
Android内存泄漏总结
解决办法:
1 修改dalvik/vm/Initc:
static void setCommandLineDefaults()
TODO: base these on a system or application-specific default
/
gDvmheapSizeStart = 2 1024 1024; // Spec says 16MB; too big for us
- gDvmheapSizeMax = 16 1024 1024; // Spec says 75% physical mem
+ gDvmheapSizeMax = 32 1024 1024; // Spec says 75% physical mem
gDvmstackSize = kDefaultStackSize;
2 修改frameworks/base/core/jni/AndroidRuntimecpp:
int AndroidRuntime::startVm(JavaVM pJavaVM, JNIEnv pEnv)
//options[curOpt++]optionString = "-verbose:class";
strcpy(heapsizeOptsBuf, "-Xmx");
- property_get("dalvikvmheapsize", heapsizeOptsBuf+4, "16m");
+ property_get("dalvikvmheapsize", heapsizeOptsBuf+4, "32m");
//LOGI("Heap size: %s", heapsizeOptsBuf);
optoptionString = heapsizeOptsBuf;
mOptionsadd(opt);
以上就是关于安卓手机把程序安装在SD卡上的同时会安装一部分容量到内存卡里吗全部的内容,包括:安卓手机把程序安装在SD卡上的同时会安装一部分容量到内存卡里吗、在Android开发中,有哪些好的内存优化方式、常见的内存泄漏原因及解决方法等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)