使用协程withContext 获取返回值时泄露
// 最近开发遇到一个泄露
// 在一个异步 val result = async(){}.await 的时候,编译器会提示使用 result = withContext(){}
// 如:
lifecycleScope.launch{
val result = withContext(){
ServerCenter.doServe()
}
...
}
但是这样写的情况下页面关闭会造成泄露,具体原因暂未可知
堆栈从消息队列开始:
2020-12-19 10:53:23.274 8382-8382/。。。 D/LeakCanary: │ GC Root: System class
2020-12-19 10:53:23.274 8382-8382/。。。 D/LeakCanary: │
2020-12-19 10:53:23.274 8382-8382/。。。 D/LeakCanary: ├─ android.app.ActivityThread class
2020-12-19 10:53:23.274 8382-8382/。。。 D/LeakCanary: │ Leaking: NO (MessageQueue↓ is not leaking and a class is never leaking)
2020-12-19 10:53:23.274 8382-8382/。。。 D/LeakCanary: │ ↓ static ActivityThread.sMainThreadHandler
2020-12-19 10:53:23.274 8382-8382/。。。 D/LeakCanary: ├─ android.app.ActivityThread$H instance
2020-12-19 10:53:23.274 8382-8382/。。。 D/LeakCanary: │ Leaking: NO (MessageQueue↓ is not leaking)
2020-12-19 10:53:23.274 8382-8382/。。。 D/LeakCanary: │ ↓ ActivityThread$H.mQueue
2020-12-19 10:53:23.274 8382-8382/。。。 D/LeakCanary: ├─ android.os.MessageQueue instance
2020-12-19 10:53:23.274 8382-8382/。。。 D/LeakCanary: │ Leaking: NO (MessageQueue#mQuitting is false)
2020-12-19 10:53:23.274 8382-8382/。。。 D/LeakCanary: │ HandlerThread: "main"
2020-12-19 10:53:23.274 8382-8382/。。。 D/LeakCanary: │ ↓ MessageQueue.mMessages
2020-12-19 10:53:23.274 8382-8382/。。。 D/LeakCanary: │ ~~~~~~~~~
感觉像是协程通过handler 切换,但是因为一些原因
切换相关的消息,发到handler 了,但是没有执行(这里很奇怪,不是要么执行要么取消么?)
最近使用paging3 alpha08,并且通过flow insertSeparators 添加不同类型的item,结果莫名崩溃
含泪查了多天,终于找到
解决:
https://stackoverflow.com/questions/64861346/paging-3-illegalargumentexception-additional-prepend-event-after-prepend-stat
是该库自身的bug,更新即可
1、TranslateAnimation和RotateAnimation同时使用时,rotate的依据自身旋转的设置无效。
解决:
先设置Rotate动画,再设置Translate…
AnimationSet animationSet = new AnimationSet(true);
TranslateAnimation translateAnimation = new TranslateAnimation(0, ScreenUtil.dip2px(96), ScreenUtil.dip2px(56), ScreenUtil.getHeight()-ScreenUtil.dip2px(56));
RotateAnimation rotateAnimation = new RotateAnimation(0, 360, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f);
translateAnimation.setDuration(mShortAnimationDuration);
//如果反过来的话,会看到一个乱舞的动画。。
animationSet.addAnimation(rotateAnimation);
animationSet.addAnimation(translateAnimation);
2、textView设置包含空格的字符串时,显示不正确
3、coordinatorLayout中的第一项有时候会滑动到界面外
伪布局如下
<CoordinatorLayout
<AppBarLayout
<!--<View id = "optional"/>-->
<View marginBottom = "10dp"/>
<!--<Space height = "10dp"/>-->
<TextView />
/>
<RecyclerView behavior="..."/>
/>
这里如果View上面还有View(optional),那么表现是正常的
而如果View作为AppBarLayout的第一项,那么会出现View有一部分滑到界面外的情况
经过排查,发现是marginBottom造成的。再尝试一下,发现TextView添加marginTop或者两者中间使用Space都会有这个问题
猜测是计算的时候出现的问题,也不准备去精确查找哪里出错
解决:
可以使用View来替代Space
模拟器网络请求报EOFException
Android Studio自带模拟器(测试了Pixel 4.2和Pixel2 9.0),请求网络(retrofit 2.2.0, okhttp 3.11.0),直接抛EOFException
但是用charles抓取是请求成功,也有数据的,真机正常获取。
初步怀疑是返回头里有Transfer-Encoding: chunked
HTTP/1.1 200
Server nginx
Date Wed, 07 Nov 2018 12:09:07 GMT
Content-Type application/json;charset=UTF-8
Transfer-Encoding chunked
Vary Accept-Encoding
X-Application-Context application:config:8080
Content-Encoding gzip
Connection keep-alive
属性动画使用方式
if (on) {
mFgAnimator = ValueAnimator.ofInt(mAnimHeight, 0);
} else {
mFgAnimator = ValueAnimator.ofInt(mAnimHeight, getMeasuredHeight());
}
mFgAnimator.setDuration(500);
mFgAnimator.setRepeatCount(0);
mFgAnimator.setEvaluator(new TypeEvaluator() {
@Override
public Object evaluate(float fraction, Object startValue, Object endValue) {
int start = (int) startValue;
int end = (int) endValue;
Log.d("TSB", "startValue : " + startValue + " --- endValue : " + endValue + "--- fraction : " + fraction);
if (start > end) {
return start - (start - end) * fraction;
} else {
return start + (end - start) * fraction;
}
}
});
RecyclerView头margin无效
oppo手机,如果添加header,使用margin,会无效。改成padding