Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/219.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
疯狂的Android Studio内存使用_Android_Android Studio - Fatal编程技术网

疯狂的Android Studio内存使用

疯狂的Android Studio内存使用,android,android-studio,Android,Android Studio,这是我最后的选择——非常希望有人能提供线索 我创建了以下自定义车载指南视图。当我将它添加到要显示的布局中时,计算机(Mac或Windows)开始叫喊,内存到达顶部,Android Studio(3.6.1版)冻结,好像有一些递归元素在某处阻塞IDE 我试着一段一段地注释代码,直到所有内容都被注释。不过,当我启动Android Studio(不做任何其他事情)时,“派对”开始了,一分钟后就冻结了 如果已知Android Studio占用内存,那么它就是从IntelliJ IDE继承下来的一种特性。

这是我最后的选择——非常希望有人能提供线索

我创建了以下自定义
车载指南视图
。当我将它添加到要显示的布局中时,计算机(Mac或Windows)开始叫喊,内存到达顶部,Android Studio(3.6.1版)冻结,好像有一些递归元素在某处阻塞IDE

我试着一段一段地注释代码,直到所有内容都被注释。不过,当我启动Android Studio(不做任何其他事情)时,“派对”开始了,一分钟后就冻结了


如果已知Android Studio占用内存,那么它就是从IntelliJ IDE继承下来的一种特性。您可以在屏幕右下角看到正在使用和可用的内存量:

(这可能不会一直显示,如果未显示,则可以在应用程序设置中打开该设置)

首先,你可以通过点击这个读数来判断AS是否清除了它没有使用的内存

其次,因为冻结通常表明它需要比分配的多一点。幸运的是,你可以自己增加限额,您可以编辑studio的VM选项:

转到
帮助>编辑自定义虚拟机选项
并编辑以下两个属性:

Xmx
:默认值为
1280m
,PAD建议将其更改为
4096m

XX:MaxPermSize
:默认值为
350m
,PAD建议将其更改为
1024m


有关这些(和其他)值是什么的详细信息,.

在这个问题在Windows之外持续存在并在Mac和Linux上重现之后,我的一位同事抓住机会深入研究,他提出了以下建议:

init {
    LayoutInflater.from(context).inflate(R.layout.view_onboarding_guide, this, true)
    if (!isInEditMode) // <- this :-(
        setAttributes(attrs)
}
init{
LayoutFlater.from(上下文)。充气(R.layout.view\u onboarding\u guide,this,true)

if(!isInEditMode)//谢谢你的建议,但我已经完成了调整堆大小等步骤。问题仍然存在。啊,好吧。我将把答案留给找到你的问题的其他人,但我希望有人对你的具体情况有更好的答案!
import android.content.Context
import android.text.Html
import android.util.AttributeSet
import android.view.LayoutInflater
import android.widget.FrameLayout
import android.widget.LinearLayout
import android.widget.TextView
import dk.firm.oldapp.R
import kotlinx.android.synthetic.main.view_onboarding_guide.view.*

class OnboardingGuideView(context: Context, attrs: AttributeSet?, defStyleAttr: Int) : FrameLayout(context, attrs, defStyleAttr) {

    private var itemCount = 0
    private var titlePrefix = ""
    private var descriptionPrefix = ""
    private var imagePrefix = ""

    init {
        LayoutInflater.from(context)
                .inflate(R.layout.view_onboarding_guide, this, true)
        setAttributes(attrs)
    }

    private fun setAttributes(attrs: AttributeSet?) {
        attrs?.let { a ->
            val typedArray = context.obtainStyledAttributes(a,
                    R.styleable.OnboardingGuideView, 0, 0)
            titlePrefix = typedArray.getString(R.styleable.OnboardingGuideView_titlePrefix).toString()
            descriptionPrefix = typedArray.getString(R.styleable.OnboardingGuideView_descriptionPrefix).toString()
            imagePrefix = typedArray.getString(R.styleable.OnboardingGuideView_imagePrefix).toString()

            typedArray.recycle()
        }

        setup()
    }

    private fun setup() {
        itemCount = countResources(titlePrefix, "string")
        val adapter = OnboardingGuideAdapter(context, itemCount, titlePrefix, descriptionPrefix, imagePrefix)
        itemPager.adapter = adapter

        addDotsIndicator()
    }

    private fun countResources(prefix: String, type: String): Int {
        var id: Long = -1
        var count = -1

        while (id != 0L) {
            count++
            id = context.resources.getIdentifier(String.format("%s_%s", prefix, (count + 1)),
                    type, context.packageName).toLong()
        }

        return count
    }

    private fun addDotsIndicator() {
        indicatorView.removeAllViews()

        for (i in 0 until itemCount) {
            val dot = TextView(context)
            dot.text = Html.fromHtml("&#8226;")
            dot.textSize = 35F
            dot.setTextColor(resources.getColor(R.color.appColorBlueLight))

            indicatorView.addView(dot)
        }
    }
}
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical">

    <androidx.viewpager.widget.ViewPager
        android:id="@+id/itemPager"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />

    <LinearLayout
        android:id="@+id/indicatorView"
        android:layout_width="match_parent"
        android:layout_height="50dp"
        android:background="@color/status_text_color_red"
        android:orientation="horizontal" />
</LinearLayout>
import android.content.Context
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import android.widget.ImageView
import android.widget.LinearLayout
import android.widget.TextView
import androidx.viewpager.widget.PagerAdapter
import dk.firm.oldapp.R
import dk.firm.selfapp.util.Utils

class OnboardingGuideAdapter(
        val context: Context,
        private val itemCount: Int,
        private val titlePrefix: String,
        private val descriptionPrefix: String,
        private val imagePrefix: String) : PagerAdapter() {

    override fun getCount(): Int {
        return itemCount
    }

    override fun isViewFromObject(view: View, o: Any): Boolean {
        return view == o as LinearLayout
    }

    override fun instantiateItem(container: ViewGroup, position: Int): Any {
        val view = LayoutInflater.from(context).inflate(R.layout.view_onboarding_guide_item, container, false)
        val ordinal = position + 1

        // Instantiate views
        val titleView = view.findViewById<TextView>(R.id.onBoardingItemTitle)
        val descriptionView = view.findViewById<TextView>(R.id.onBoardingItemDescription)
        val imageView = view.findViewById<ImageView>(R.id.onBoardingItemImage)

        // Create resource names
        val title = String.format("%s_%s", titlePrefix, ordinal)
        val description = String.format("%s_%s", descriptionPrefix, ordinal)
        val image = String.format("%s_%s", imagePrefix, ordinal)

        // Populate views
        titleView.text = Utils.getStringFromResId(context.resources.getIdentifier(title, "string", context.packageName))
        descriptionView.text = Utils.getStringFromResId(context.resources.getIdentifier(description, "string", context.packageName))
        imageView.setImageResource(context.resources.getIdentifier(image, "drawable", context.packageName))

        container.addView(view)

        return view
    }

    override fun destroyItem(container: ViewGroup, position: Int, o: Any) {
        container.removeView(o as LinearLayout)
    }
}
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical">

    <androidx.appcompat.widget.AppCompatTextView
        android:id="@+id/onBoardingItemTitle"
        style="@style/TextAppearance.Subtitle1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />

    <androidx.appcompat.widget.AppCompatTextView
        android:id="@+id/onBoardingItemDescription"
        style="@style/TextAppearance.Body1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="16dp" />

    <androidx.appcompat.widget.AppCompatImageView
        android:id="@+id/onBoardingItemImage"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />
</LinearLayout>
init {
    LayoutInflater.from(context).inflate(R.layout.view_onboarding_guide, this, true)
    if (!isInEditMode) // <- this :-(
        setAttributes(attrs)
}