Merge "Not call refreshStats() in setDuration()" into main

This commit is contained in:
Chaohui Wang
2023-10-10 08:04:10 +00:00
committed by Android (Google) Code Review

View File

@@ -29,6 +29,8 @@ import android.util.Log;
import android.util.LongSparseArray; import android.util.LongSparseArray;
import android.util.SparseArray; import android.util.SparseArray;
import androidx.annotation.WorkerThread;
import com.android.internal.app.ProcessMap; import com.android.internal.app.ProcessMap;
import com.android.internal.app.procstats.DumpUtils; import com.android.internal.app.procstats.DumpUtils;
import com.android.internal.app.procstats.IProcessStats; import com.android.internal.app.procstats.IProcessStats;
@@ -85,24 +87,10 @@ public class ProcStatsData {
} }
} }
public void setTotalTime(int totalTime) {
memTotalTime = totalTime;
}
public void xferStats() { public void xferStats() {
sStatsXfer = mStats; sStatsXfer = mStats;
} }
public void setMemStates(int[] memStates) {
mMemStates = memStates;
refreshStats(false);
}
public void setStats(int[] stats) {
this.mStates = stats;
refreshStats(false);
}
public int getMemState() { public int getMemState() {
int factor = mStats.mMemFactor; int factor = mStats.mMemFactor;
if (factor == ProcessStats.ADJ_NOTHING) { if (factor == ProcessStats.ADJ_NOTHING) {
@@ -118,15 +106,13 @@ public class ProcStatsData {
return mMemInfo; return mMemInfo;
} }
public long getElapsedTime() { /**
return mStats.mTimePeriodEndRealtime - mStats.mTimePeriodStartRealtime; * Sets the duration.
} *
* <p>Note: {@link #refreshStats(boolean)} needs to called manually to take effect.
*/
public void setDuration(long duration) { public void setDuration(long duration) {
if (duration != mDuration) { mDuration = duration;
mDuration = duration;
refreshStats(true);
}
} }
public long getDuration() { public long getDuration() {
@@ -137,6 +123,12 @@ public class ProcStatsData {
return pkgEntries; return pkgEntries;
} }
/**
* Refreshes the stats.
*
* <p>Note: This needs to be called manually to take effect.
*/
@WorkerThread
public void refreshStats(boolean forceLoad) { public void refreshStats(boolean forceLoad) {
if (mStats == null || forceLoad) { if (mStats == null || forceLoad) {
load(); load();