android手机端视频播放框架一般用哪种可以达到加载快不转圈?

android手机端视频播放框架一般用哪种可以达到加载快不转圈?
我用google自带的视频播放MediaPlay框架,加载阿里云网络视频需要等10秒以上,
我改用JZVD播放器,效果稍好一些,同样服务器环境,加载阿里云网络视频需要等3秒以上,请问各位大神,你们都用的是什么播放器?
微信,微博,头条,抖音,快手等App播放网络视频,似乎不需要等待加载,体验超好,
他们是怎么做的?

1个回答

不同的框架,prefetch 策略不一样,一些是缓冲多一些,换来播放的过程中少卡顿,一些是断断续续,但是加载快一些
都是换汤不换药,改进网络才是王道。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
android 最新的图片加载框架
现在我的工程老报 OOM 想找一个最新的图片加载框架,最好是少报OOM 我原来用的是 universal-image-loader-1.9.2-SNAPSHOT-with-sources.jar 这个 求各位大神给一个图片加载的框架
android框架picasso加载图片有几率出现图片变绿的情况
android框架picasso加载图片有几率出现图片变绿的情况,求解
Android 求qq动态加载框架、支付宝动态加载框架或者一个比较稳定的动态加载sdk,有没有呢?
准备用动态加载框架技术搭建项目,看了些资料,比较迷茫,自己还不会写,希望能 有一个稳定的框架能够使用,。
Android Glide框架加载占位图和error图时有问题
glideRequest = Glide.with(context); glideRequest.load(picUrl).transform(new GlideCircleTransform(mContext)).into(holder.hot_iv); 这样正常加载图片弄成圆形的没问题 glideRequest.load(picUrl).placeholder(R.drawable.ticai_zhanwei).error(R.drawable.ticai_zhanwei).transform(new GlideCircleTransform(mContext)).into(holder.hot_iv) 但是 添加上placeholder或者error 占位图 后面的设置圆形方法就失效了, 就变成图片本来的方的样子 这是为什么?有什么解决办法
Android ButterKnife框架怎么绑定动态加载的布局
我在自定义的FlameLayout类里定义了一个成员变量 ``` @BindView(R.id.radio_group) RadioGroup radioGroup ``` 但是这个RadioGroup不在FlameLayout布局里,而是通过FlameLayout的一个点击事件生成的PopupWindow里面的控件。我又不想用findViewById. 我在inflate PopupWindow的contentView后再次调用了ButterKnife.bind(contentView);但是没有什么卵用。怎样才能用ButterKnife绑定。
Android常用的开源网络请求框架,码农们分享使用心得?
* 1. compile 'com.loopj.android:android-async-http:1.4.9' * 2. compile 'org.xutils:xutils:3.5.0' * 3. okgo * 4. NoHttp * 5. Volley网络通信框架 * 6. Universal-Image-Loader图片加载框架 *
使用fresco框架加载图片时,一次性加载70多张就会出现OOM,该如何解决
I/art: Starting a blocking GC Alloc 02-08 15:40:00.307 15871-15871/android.ye.fashioncircle I/art: Clamp target GC heap from 207MB to 192MB 02-08 15:40:00.307 15871-15871/android.ye.fashioncircle I/art: Alloc concurrent mark sweep GC freed 3(96B) AllocSpace objects, 0(0B) LOS objects, 0% free, 191MB/192MB, paused 773us total 41.748ms 02-08 15:40:00.308 15871-15871/android.ye.fashioncircle I/art: Forcing collection of SoftReferences for 1406KB allocation 02-08 15:40:00.308 15871-15871/android.ye.fashioncircle I/art: Starting a blocking GC Alloc 02-08 15:40:00.349 15871-15871/android.ye.fashioncircle I/art: Clamp target GC heap from 207MB to 192MB 02-08 15:40:00.349 15871-15871/android.ye.fashioncircle I/art: Alloc concurrent mark sweep GC freed 3(96B) AllocSpace objects, 0(0B) LOS objects, 0% free, 191MB/192MB, paused 789us total 40.572ms 02-08 15:40:00.351 15871-15871/android.ye.fashioncircle W/art: Throwing OutOfMemoryError "Failed to allocate a 1440012 byte allocation with 200488 free bytes and 195KB until OOM" 02-08 15:40:00.351 15871-15871/android.ye.fashioncircle D/skia: --- allocation failed for scaled bitmap 02-08 15:40:00.352 15871-15871/android.ye.fashioncircle D/AndroidRuntime: Shutting down VM 02-08 15:40:00.355 15871-15871/android.ye.fashioncircle I/art: Waiting for a blocking GC Alloc 02-08 15:40:00.361 15871-15871/android.ye.fashioncircle I/art: WaitForGcToComplete blocked for 5.461ms for cause Alloc 02-08 15:40:00.361 15871-15871/android.ye.fashioncircle I/art: Starting a blocking GC Alloc 02-08 15:40:00.673 7773-7780/android.ye.fashioncircle A/art: art/runtime/barrier.cc:90] Check failed: count_ == 0 (count_=-1, 0=0) Attempted to destroy barrier with non zero count 02-08 15:40:00.673 7773-7780/android.ye.fashioncircle A/art: art/runtime/runtime.cc:366] Runtime aborting --- recursively, so no thread-specific detail! 02-08 15:40:00.673 7773-7780/android.ye.fashioncircle A/art: art/runtime/runtime.cc:366] 这样的时候界面出现卡顿,然后就OOM闪退了 该如何解决。。。 页面是一个scrollview嵌套recyclerview使得分页加载失效,一次性加载了所有的图片 换成Glide和ImageLoader也是OOM
Android 使用下拉刷新框架(SmartRefreshLayout),报错Error inflating class
我是一名小白,在学习安卓,刚接触到导入外部的框架,看到github上的项目SmartRefreshLayout,就想试用一下,但配置好后一直闪退,报错日志:Unable to start activity ComponentInfo{com.zhang.hp.muke_test/com.zhang.hp.muke_test.MainActivity}: android.view.InflateException: Binary XML file line #9: Binary XML file line #9: Error inflating class com.scwang.smartrefresh.layout.SmartRefreshLayout, xml文件写法: ``` <?xml version="1.0" encoding="utf-8"?> <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".MainActivity"> <com.scwang.smartrefresh.layout.SmartRefreshLayout android:id="@+id/pull" android:layout_width="match_parent" android:layout_height="match_parent" > <TextView android:id="@+id/text" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Hello World!" app:layout_constraintBottom_toBottomOf="parent" app:layout_constraintLeft_toLeftOf="parent" app:layout_constraintRight_toRightOf="parent" app:layout_constraintTop_toTopOf="parent" /> </com.scwang.smartrefresh.layout.SmartRefreshLayout> </androidx.constraintlayout.widget.ConstraintLayout> ``` MainActivity写法: ``` tv = findViewById(R.id.text); myrefresh = findViewById(R.id.pull); myrefresh.setOnRefreshListener(new OnRefreshListener() { //激活下拉刷新的时候调用的函数 @Override public void onRefresh(RefreshLayout refreshLayout) { tv.setText("下拉刷新了"); myrefresh.finishRefresh(); } }); myrefresh.setOnLoadMoreListener(new OnLoadMoreListener() { @Override public void onLoadMore(RefreshLayout refreshLayout) { tv.setText("上拉加载了"); myrefresh.finishLoadMore(); } }); myrefresh.setEnableLoadMore(true); myrefresh.autoRefresh(); ``` 不知道哪里出错了,希望各位大神能指导一下,谢谢了!
求一个好用的上拉加载下拉刷新框架
求推荐一个好用的上拉加载下拉刷新框架(PullTorefresh除外)。
请问安卓商城的服务端如何部署(使用的structs2+hibernate框架)
最近从网上下载了一个android应用的源码,源码有2个工程,客户端和服务端,服务端是用struts2+hibernate框架搭建的。想自己运行一下试试,在android模拟器里应用可以成功加载上但打开只有只有一个layout的框架,没有内容,应该是没有连接到服务端读不出数据库内容所致。在客户端里改了connectWeb类里的请求url,在服务端里我在myeclipse添加了tomcat6.0,然后改了hibernate.cfg.xml连接数据库的参数,运行的时候直接start了 tomcat,然后我在浏览器里输入本地地址可以看到服务端的欢迎页面,然后试了一下客户端的一个请求url结果出现了500错误,调试了一下是sessionfactory为空值的原因,就是说hibernate没有连接上mysql,请问是代码的原因还是部署上有什么错误?在启动tomcat的时候需不需要设置什么参数?谢谢了
android 集成H5页面,H5是用MUI框架写的
用MUI框架的缺点就是导航栏和数据页面得分开成两个html文件, 但是安卓这边只能加载一个Html的文件, 前端应该怎么做能够做到两个html文件一起加载?????
Android下缓存音频和Picasso加载图片异常
1.有没有什么比较好的缓存音频的框架,类似于手机酷狗酷我这些,播放过的音频,就将其缓存。 2.我用的Picasso异步加载图片,每次加载5张,加载上二三十张还行,等到图片多了,就加载不出来了,是不是图片优化没做好,还是什么问题???(图片的外围边框已经画出来了,但是没有显示图片)
请评价一下我对主流图片加载框架的看法
Android常见的图片加载框架有Universal ImageLoader (以下简称UIL)、Picasso、Glide、Fresco四种,请评价一下我对它们的看法: UIL是早期常见的框架,没有默认参数,一切需要自己配置。 Picasso 体量最小,而且有默认参数,加载图片较Glide略慢。 Glide 是 Google 官方推荐框架,加载效果比Picasso好,并且能加载gif。 Fresco 加载图片效果最好、耗时最短,明显的缺点是占用空间太大。
使用Glide加载https图片失败
我使用的网络框架是okhttpUtils 经过查看网上资料已经重写了AppGlideModule 并且在AndroidManifest文件注册过了 可是依然加载失败 请大佬们指导一下![图片说明](https://img-ask.csdn.net/upload/201910/12/1570848998_695155.jpg)
最近使用Fresco框架加载图片时,app有时会崩溃
最近使用Fresco框架加载图片时,app有时会崩溃,错误提示为Binary XML file line #9: Error inflating class <unknown>, 第九行正好是<com.facebook.drawee.view.SimpleDraweeView> 是不是跟fresco中文官网上不去有关系
Android在商域app在没网的时候显示上次有网加载的数据,做本地的缓存,有网的时候在清空上次的?
Android在商域app在没网的时候显示上次有网加载的数据,做本地的缓存,有网的时候在清空上次的?现在有什么开源框架可以用,具体该怎么写呢
Android webview里调用 支付宝接口
做的程序是Android框架嵌套js 用webview来加载这些页面,现在在webview里面点击支付时的时候, 会跳转到一个PC版的页面进行支付,这个功能在PC上是正常的。 现在嵌套在Android里的时候 ,经常出现无法登陆,扫码支付后不能返回的现象。 所以决定用支付宝的接口。 https://doc.open.alipay.com/docs/doc.htm?spm=a219a.7629140.0.0.t8Z1SV&treeId=59&articleId=104669&docType=1 就是这种介入方式,里面有个方法接口fetchOrderInfoFromH5PayUrl # 接口功能 # # 从拦截的URL中获取支付请求相关信息,封装成新的订单信息字符串作为返回值。如果该URL不是有效的支付宝支付URL,则返回空字符串。 但是现在这个我总是不能拦截到自己支付地址,还是会跳转到PC版的页面,想要的结果是可以直接底部弹出来支付框(有安装支付宝APP的时候),没有装的话是转到H5的页面中。 这个接入需要申请什么权限吗,我看官方demo里这种方式没有用到, 看到的朋友 可以指点一下吗,第一次集成支付宝 非常迷茫,项目快上线了,这个功能以及纠缠我好多天了,在线等
android textview内容消失问题
我做了一个简单的fragment界面,主要是输入ID,然后向服务器查询内容后赋值回原来的界面上的textview,但是在运行的时候发生了一个奇怪的问题,一部分的textview消失了,具体很难描述,以下是整个过程的描述 ![图片说明](https://img-ask.csdn.net/upload/201605/14/1463197893_214757.jpg) 这是个原始界面,在最上方输入编号,然后查询。 ![图片说明](https://img-ask.csdn.net/upload/201605/14/1463197987_723570.jpg) 点击查询后,可以看见,背景内容已经加载,textview的内容已经进去了,但是加载完成后,textview ![图片说明](https://img-ask.csdn.net/upload/201605/14/1463198182_802396.jpg) 如上图,加载完成后,下面的Textview不见了,而且,连那些实现写好的静态的textview也不见了 然后,我通过弹出输入法,用输入法覆盖部分内容 ![图片说明](https://img-ask.csdn.net/upload/201605/14/1463198282_9279.jpg) 像上图这样,在搜索框中点击之后,输入法会自动弹出,覆盖掉下面的内容,然后再取消 ![图片说明](https://img-ask.csdn.net/upload/201605/14/1463198349_994971.jpg) 然后内容就出来了。。。 每次都是这个样子。。我觉得很奇怪,不知道什么原因导致的,谁能帮忙看看吗?谢谢 整个框架大框架是fragment+viewpage,查询用的AsyncTask查询后赋值。 上代码了,布局文件,是一个fragment_content,xml ``` <?xml version="1.0" encoding="utf-8"?> <ScrollView xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent"> <LinearLayout android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent"> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal"> <EditText android:layout_width="270dip" android:layout_height="52dip" android:id="@+id/searchText" android:hint="请输入客户编号ID或扫二维码" android:background="@android:drawable/editbox_background_normal"/> <ImageButton android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@android:drawable/ic_menu_search" android:id="@+id/search_button"/> <ImageButton android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@android:drawable/ic_menu_camera" android:id="@+id/search_QRcode"/> </LinearLayout> <LinearLayout android:layout_marginTop="5dip" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical" android:background="#F2F3EB"> <TextView android:layout_width="360dip" android:layout_height="35dip" android:text="业主信息" android:gravity="center" android:layout_gravity="center" android:layout_marginTop="8dip" android:background="@android:drawable/btn_default" /> <LinearLayout android:layout_marginTop="8dip" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal"> <TextView android:layout_width="100dip" android:layout_height="wrap_content" android:gravity="center" android:text="业主名称"/> <TextView android:id="@+id/CustomerNAME" android:layout_width="300dip" android:layout_height="wrap_content" android:text="请输入客户ID" android:gravity="center"/> </LinearLayout> <LinearLayout android:layout_marginTop="8dip" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal"> <TextView android:layout_width="100dip" android:layout_height="wrap_content" android:gravity="center" android:text="行业性质"/> <TextView android:layout_width="300dip" android:layout_height="wrap_content" android:gravity="center" android:id="@+id/CustomerSegment"/> </LinearLayout> <LinearLayout android:layout_marginTop="8dip" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal"> <TextView android:layout_width="100dip" android:layout_height="wrap_content" android:gravity="center" android:text="联系地址"/> <TextView android:layout_width="300dip" android:layout_height="wrap_content" android:id="@+id/CustomerAddress" android:gravity="center"/> </LinearLayout> <LinearLayout android:layout_marginTop="8dip" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal"> <TextView android:layout_width="100dip" android:layout_height="wrap_content" android:gravity="center" android:text="联系人"/> <TextView android:layout_width="300dip" android:layout_height="wrap_content" android:id="@+id/CustomerContactor" android:gravity="center"/> </LinearLayout> <LinearLayout android:layout_marginTop="8dip" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal" > <TextView android:layout_width="100dip" android:layout_height="wrap_content" android:gravity="center" android:text="联系电话"/> <TextView android:layout_width="300dip" android:layout_height="wrap_content" android:id="@+id/CustomerPhone" android:gravity="center"/> </LinearLayout> <LinearLayout android:layout_marginLeft="4dip" android:layout_marginTop="8dip" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal" android:layout_marginBottom="5dip"> <TextView android:layout_width="100dip" android:layout_height="wrap_content" android:gravity="center" android:text="保养合约到期时间"/> <TextView android:layout_width="300dip" android:layout_height="wrap_content" android:id="@+id/Customercontactdate" android:gravity="center"/> </LinearLayout> //下面开始就是出问题的部分布局 </LinearLayout> <LinearLayout android:layout_marginTop="10dip" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical" android:background="#F2F3EB"> <TextView android:layout_width="360dip" android:layout_height="35dip" android:text="维护人员信息" android:gravity="center" android:layout_gravity="center" android:layout_marginTop="8dip" android:background="@android:drawable/btn_default" /> <TextView android:layout_width="400dip" android:layout_height="30dip" android:text="专属客户代表" android:gravity="center" /> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal" android:layout_marginBottom="10dip"> <ImageView android:layout_width="120dip" android:layout_height="100dip" android:src="@drawable/unknownpic" android:id="@+id/SRPIC"/> <TableLayout android:layout_width="match_parent" android:layout_height="wrap_content" > <TableRow android:layout_marginTop="7dip"> <TextView android:layout_width="70dip" android:layout_height="wrap_content" android:text="姓名" android:gravity="center"/> <TextView android:layout_width="220dip" android:layout_height="match_parent" android:id="@+id/ServiceRepresentive" android:gravity="center"/> </TableRow> <TableRow android:layout_marginTop="7dip"> <TextView android:layout_width="70dip" android:layout_height="wrap_content" android:text="职位" android:gravity="center"/> <TextView android:layout_width="220dip" android:layout_height="match_parent" android:id="@+id/SRP" android:gravity="center"/> </TableRow> <TableRow android:layout_marginTop="7dip"> <TextView android:layout_width="70dip" android:layout_height="wrap_content" android:text="联系方式" android:gravity="center"/> <TextView android:layout_width="220dip" android:layout_height="match_parent" android:id="@+id/SRN" android:gravity="center"/> </TableRow> <TableRow android:layout_marginTop="7dip"> <TextView android:layout_width="70dip" android:layout_height="wrap_content" android:text="工作年限" android:gravity="center"/> <TextView android:layout_width="220dip" android:layout_height="match_parent" android:id="@+id/SRY" android:gravity="center"/> </TableRow> </TableLayout> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical"> <TextView android:layout_width="400dip" android:layout_height="30dip" android:text="专属服务技师" android:gravity="center" /> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal" android:layout_marginBottom="10dip"> <ImageView android:layout_width="120dip" android:layout_height="100dip" android:src="@drawable/unknownpic" android:id="@+id/STPIC"/> <TableLayout android:layout_width="match_parent" android:layout_height="wrap_content" > <TableRow android:layout_marginTop="7dip"> <TextView android:layout_width="70dip" android:layout_height="wrap_content" android:text="姓名" android:gravity="center"/> <TextView android:layout_width="220dip" android:layout_height="match_parent" android:id="@+id/ServiceTechnician" android:gravity="center"/> </TableRow> <TableRow android:layout_marginTop="7dip"> <TextView android:layout_width="70dip" android:layout_height="wrap_content" android:text="职位" android:gravity="center"/> <TextView android:layout_width="220dip" android:layout_height="match_parent" android:id="@+id/STN" android:gravity="center"/> </TableRow> <TableRow android:layout_marginTop="7dip"> <TextView android:layout_width="70dip" android:layout_height="wrap_content" android:text="工作年限" android:gravity="center"/> <TextView android:layout_width="220dip" android:layout_height="match_parent" android:id="@+id/STY" android:gravity="center"/> </TableRow> <TableRow android:layout_marginTop="7dip"> <TextView android:layout_width="70dip" android:layout_height="wrap_content" android:text="专业技能" android:gravity="center"/> <TextView android:layout_width="220dip" android:layout_height="match_parent" android:id="@+id/STS" android:gravity="center"/> </TableRow> </TableLayout> </LinearLayout> </LinearLayout> </LinearLayout> </LinearLayout> </ScrollView> ``` fragment的文件,里面除了查询,还有一个二维码扫描 ``` public class CustomerInf extends Fragment { ImageButton search,search_QRcode; EditText editText; String searchID; TextView CustomerName,CustomerSegment,CustomerAddress,CustomerContactor,CustomerPhone; TextView Customercontactdate,ServiceRepresentive,SRP,SRN,SRY,ServiceTechnician,STN,STY,STS; ImageView SRPIC,STPIC; @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View view = inflater.inflate(R.layout.fragment_content, container, false); bind(view); return view; } //对各内容进行绑定 public void bind(View view) { search = (ImageButton) view.findViewById(R.id.search_button); editText = (EditText) view.findViewById(R.id.searchText); CustomerName=(TextView)view.findViewById(R.id.CustomerNAME); CustomerSegment=(TextView)view.findViewById(R.id.CustomerSegment); CustomerAddress=(TextView)view.findViewById(R.id.CustomerAddress); CustomerContactor=(TextView)view.findViewById(R.id.CustomerContactor); CustomerPhone=(TextView)view.findViewById(R.id.CustomerPhone); Customercontactdate=(TextView)view.findViewById(R.id.Customercontactdate); ServiceRepresentive=(TextView)view.findViewById(R.id.ServiceRepresentive); SRP=(TextView)view.findViewById(R.id.SRP); SRN=(TextView)view.findViewById(R.id.SRN); SRY=(TextView)view.findViewById(R.id.SRY); ServiceTechnician=(TextView)view.findViewById(R.id.ServiceTechnician); STN=(TextView)view.findViewById(R.id.STN); STY=(TextView)view.findViewById(R.id.STY); STS=(TextView)view.findViewById(R.id.STS); SRPIC=(ImageView) view.findViewById(R.id.SRPIC); STPIC=(ImageView) view.findViewById(R.id.STPIC); search.setOnClickListener(new Click()); search_QRcode=(ImageButton)view.findViewById(R.id.search_QRcode); search_QRcode.setOnClickListener(new QRsearch()); } //此处是一个引用外部二维码扫描的程序 public class QRsearch implements View.OnClickListener{ @Override public void onClick(View v){ if (ContextCompat.checkSelfPermission(getContext(), Manifest.permission.CAMERA) != PackageManager.PERMISSION_GRANTED) { if (ActivityCompat.shouldShowRequestPermissionRationale(getActivity(), Manifest.permission.CAMERA)) { } else { requestPermissions( new String[]{Manifest.permission.CAMERA}, 123); } } else { Toast.makeText(getContext(),"开始扫描",Toast.LENGTH_SHORT).show(); Intent startScan=new Intent(getContext(), CaptureActivity.class); startActivityForResult(startScan, Activity.RESULT_FIRST_USER); } } } //二维码的返回 @Override public void onActivityResult(int requestCode,int resultCode,Intent data){ super.onActivityResult(requestCode,resultCode,data); if(resultCode==Activity.RESULT_OK){ Bundle bundle = data.getExtras(); String scanResult = bundle.getString("result"); editText.setText(scanResult); searchID = editText.getText().toString().trim(); if (TextUtils.isEmpty(searchID)) { Toast.makeText(getActivity(), "请输入客户ID"+searchID, Toast.LENGTH_LONG).show(); } else { SearchTask searchTask = new SearchTask(); String[] array=new String[]{"http://www.klmt001.com/CustomerINF.php",searchID}; searchTask.execute(array); } } } //这里是查询按钮的监听器 public class Click implements View.OnClickListener { @Override public void onClick(View v) { searchID = editText.getText().toString().trim(); if (TextUtils.isEmpty(searchID)) { Toast.makeText(getActivity(), "请输入客户ID"+searchID, Toast.LENGTH_LONG).show(); } else { SearchTask searchTask = new SearchTask(); String[] array=new String[]{"http://www.klmt001.com/CustomerINF.php",searchID}; searchTask.execute(array); } } } //监听按钮的AsyncTask class SearchTask extends AsyncTask<String, Integer, JSONObject> { ProgressDialog p1; @Override protected void onPreExecute() { p1=new ProgressDialog(getActivity()); p1.setTitle("请等待"); p1.setMessage("等待中........"); p1.setCancelable(false); p1.show(); new Handler().postDelayed(new Runnable(){ public void run() { p1.dismiss(); } }, 1000); } protected JSONObject doInBackground(String... inf) { HttpClient httpclient = new DefaultHttpClient(); HttpEntity entity = null; StringBuilder builder = new StringBuilder(); JSONObject jsonObject=null; try { HttpPost httpPost = new HttpPost(inf[0]); List<NameValuePair> list = new ArrayList<>(); list.add(new BasicNameValuePair("CustomerID", inf[1])); httpPost.setEntity(new UrlEncodedFormEntity(list, HTTP.UTF_8)); HttpResponse response = httpclient.execute(httpPost); entity = response.getEntity(); if (response.getEntity() != null) { if (response.getEntity().toString().equals("0")) { jsonObject=null; Log.v("msg",""+"没有收到信息"); } else { BufferedReader reader = new BufferedReader(new InputStreamReader(response.getEntity().getContent())); String s = reader.readLine(); for (; s != null; s = reader.readLine()) { builder.append(s); } Log.v("msg",""+"成功获取信息"); jsonObject = new JSONObject(builder.toString()); } } } catch (Exception E) { Log.e("msg", E.getMessage()); Log.v("msg", "没有成功 "); } finally { try { if (entity != null) { // entity.consumeContent();//强制释放资源 httpclient.getConnectionManager().shutdown();//关闭连接 //这两种释放连接的方法都可以 } } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } } return jsonObject; } //获取值之后开始对原来的textview进行赋值 protected void onPostExecute(JSONObject webcontent){ String cn,cs,ca,cc,cp,cd,sr,srd,srn,sry,st,stn,sty,sts,pic1,pic2; if(webcontent==null){ Toast.makeText(getActivity(),"没有对应的客户信息",Toast.LENGTH_LONG).show(); }else { try { cn=webcontent.getString("CustomerName"); CustomerName.setText(cn); cs=webcontent.getString("CustomerSegment"); CustomerSegment.setText(cs); ca=webcontent.getString("CustomerAddress"); CustomerAddress.setText(ca); cc=webcontent.getString("CustomerContactor"); CustomerContactor.setText(cc); cp=webcontent.getString("CustomerPhone"); CustomerPhone.setText(cp); cd=webcontent.getString("Customercontactdate"); Customercontactdate.setText(cd); sr=webcontent.getString("ServiceRepresentive"); ServiceRepresentive.setText(sr); srd=webcontent.getString("SRP"); SRP.setText(srd); srn=webcontent.getString("SRN"); SRN.setText(srn); sry=webcontent.getString("SRY"); SRY.setText(sry); st=webcontent.getString("ServiceTechnician"); ServiceTechnician.setText(st); stn=webcontent.getString("STN"); STN.setText(stn); sty=webcontent.getString("STY"); STY.setText(sty); sts=webcontent.getString("STS"); STS.setText(sts); pic1=webcontent.getString("SRPIC"); pic2=webcontent.getString("STPIC"); String[] pics=new String[]{pic1,pic2}; Loadpics loadpics=new Loadpics(); loadpics.execute(pics); }catch (Exception E){ E.printStackTrace(); } } } } //这里是用来获取图片的 class Loadpics extends AsyncTask<String, Integer, Bitmap[]>{ protected Bitmap[] doInBackground(String... inf) { Bitmap[] bitmaps=new Bitmap[2]; Bitmap bitmap1,bitmap2; try{ URL url1=new URL(inf[0]); URLConnection conn1=url1.openConnection(); conn1.connect(); InputStream inputStream = conn1.getInputStream(); bitmap1 = BitmapFactory.decodeStream(inputStream); URL url2=new URL(inf[1]); URLConnection conn2=url2.openConnection(); conn2.connect(); InputStream inputStream2 = conn2.getInputStream(); bitmap2 = BitmapFactory.decodeStream(inputStream2); bitmaps[0]=bitmap1; bitmaps[1]=bitmap2; }catch (Exception E){ Log.e("msg", E.getMessage()); }return bitmaps; } protected void onPostExecute(Bitmap[] bitmap){ try{ SRPIC.setImageBitmap(bitmap[0]); STPIC.setImageBitmap(bitmap[1]); }catch (Exception E){ Log.e("msg", E.getMessage()); } } }} ```
eclipse使用fresco框架加载图片,内存没有释放.求大神指导
02-01 17:11:36.785: W/unknown:CloseableReference(17517): Finalized without closing: 429970e8 42997048 (type = CloseableStaticBitmap) 02-01 17:11:36.785: W/unknown:CloseableReference(17517): Finalized without closing: 439866c0 43986500 (type = NativePooledByteBuffer) 02-01 17:11:36.785: W/unknown:CloseableReference(17517): Finalized without closing: 42fc5cf8 42fc5bf0 (type = CloseableStaticBitmap) .... 下面是布局代码: <com.facebook.drawee.view.SimpleDraweeView android:id="@+id/chatting_avatar_iv" android:layout_width="48dp" android:layout_height="48dp" fresco:failureImage="@drawable/user_1" fresco:failureImageScaleType="fitCenter" fresco:placeholderImage="@drawable/user_1" fresco:placeholderImageScaleType="fitCenter" fresco:roundedCornerRadius="180dp" /> 加载的时候 : String userPic = OssUtils.thumbnailUserPic(PictureUtil.getUserPic(context,msg.getPicture())); Uri uri = Uri.parse(userPic); avatar.setImageURI(uri); 这样使用应该是最基本的, 正常情况是没问题的吧 . 会不会因为当前activity关闭的时候,此activity没有被销毁 . 导致这里的内存也没有释放.
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 free -m 其中:m表示兆,也可以用g,注意都要小写 Men:表示物理内存统计 total:表示物理内存总数(total=used+free) use...
Vue + Spring Boot 项目实战(十四):用户认证方案与完善的访问拦截
本篇文章主要讲解 token、session 等用户认证方案的区别并分析常见误区,以及如何通过前后端的配合实现完善的访问拦截,为下一步权限控制的实现打下基础。
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发...
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 演示地点演示 html代码如下` music 这个年纪 七月的风 音乐 ` 然后就是css`*{ margin: 0; padding: 0; text-decoration: none; list-...
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。
数据库优化 - SQL优化
以实际SQL入手,带你一步一步走上SQL优化之路!
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 cpp 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7 p...
通俗易懂地给女朋友讲:线程池的内部原理
餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹...
面试官:你连RESTful都不知道我怎么敢要你?
干货,2019 RESTful最贱实践
SQL-小白最佳入门sql查询一
不要偷偷的查询我的个人资料,即使你再喜欢我,也不要这样,真的不好;
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
漫话:什么是平衡(AVL)树?这应该是把AVL树讲的最好的文章了
这篇文章通过对话的形式,由浅入深带你读懂 AVL 树,看完让你保证理解 AVL 树的各种操作,如果觉得不错,别吝啬你的赞哦。 1、若它的左子树不为空,则左子树上所有的节点值都小于它的根节点值。 2、若它的右子树不为空,则右子树上所有的节点值均大于它的根节点值。 3、它的左右子树也分别可以充当为二叉查找树。 例如: 例如,我现在想要查找数值为14的节点。由于二叉查找树的特性,我们可...
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
开源并不是你认为的那些事
点击上方蓝字 关注我们开源之道导读所以 ————想要理清开源是什么?先要厘清开源不是什么,名正言顺是句中国的古代成语,概念本身的理解非常之重要。大部分生物多样性的起源,...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员...
网易云6亿用户音乐推荐算法
网易云音乐是音乐爱好者的集聚地,云音乐推荐系统致力于通过 AI 算法的落地,实现用户千人千面的个性化推荐,为用户带来不一样的听歌体验。 本次分享重点介绍 AI 算法在音乐推荐中的应用实践,以及在算法落地过程中遇到的挑战和解决方案。 将从如下两个部分展开: AI算法在音乐推荐中的应用 音乐场景下的 AI 思考 从 2013 年 4 月正式上线至今,网易云音乐平台持续提供着:乐屏社区、UGC...
【技巧总结】位运算装逼指南
位算法的效率有多快我就不说,不信你可以去用 10 亿个数据模拟一下,今天给大家讲一讲位运算的一些经典例子。不过,最重要的不是看懂了这些例子就好,而是要在以后多去运用位运算这些技巧,当然,采用位运算,也是可以装逼的,不信,你往下看。我会从最简单的讲起,一道比一道难度递增,不过居然是讲技巧,那么也不会太难,相信你分分钟看懂。 判断奇偶数 判断一个数是基于还是偶数,相信很多人都做过,一般的做法的代码如下...
《C++ Primer》学习笔记(六):C++模块设计——函数
专栏C++学习笔记 《C++ Primer》学习笔记/习题答案 总目录 https://blog.csdn.net/TeFuirnever/article/details/100700212 —————————————————————————————————————————————————————— 《C++ Primer》习题参考答案:第6章 - C++模块设计——函数 文章目录专栏C+...
8年经验面试官详解 Java 面试秘诀
作者 |胡书敏 责编 | 刘静 出品 | CSDN(ID:CSDNnews) 本人目前在一家知名外企担任架构师,而且最近八年来,在多家外企和互联网公司担任Java技术面试官,前后累计面试了有两三百位候选人。在本文里,就将结合本人的面试经验,针对Java初学者、Java初级开发和Java开发,给出若干准备简历和准备面试的建议。 Java程序员准备和投递简历的实...
面试官如何考察你的思维方式?
1.两种思维方式在求职面试中,经常会考察这种问题:北京有多少量特斯拉汽车?某胡同口的煎饼摊一年能卖出多少个煎饼?深圳有多少个产品经理?一辆公交车里能装下多少个乒乓球?一个正常成年人有多少根头发?这类估算问题,被称为费米问题,是以科学家费米命名的。为什么面试会问这种问题呢?这类问题能把两类人清楚地区分出来。一类是具有文科思维的人,擅长赞叹和模糊想象,它主要依靠的是人的第一反应和直觉,比如小孩...
so easy! 10行代码写个"狗屁不通"文章生成器
前几天,GitHub 有个开源项目特别火,只要输入标题就可以生成一篇长长的文章。 背后实现代码一定很复杂吧,里面一定有很多高深莫测的机器学习等复杂算法 不过,当我看了源代码之后 这程序不到50行 尽管我有多年的Python经验,但我竟然一时也没有看懂 当然啦,原作者也说了,这个代码也是在无聊中诞生的,平时撸码是不写中文变量名的, 中文...
知乎高赞:中国有什么拿得出手的开源软件产品?(整理自本人原创回答)
知乎高赞:中国有什么拿得出手的开源软件产品? 在知乎上,有个问题问“中国有什么拿得出手的开源软件产品(在 GitHub 等社区受欢迎度较好的)?” 事实上,还不少呢~ 本人于2019.7.6进行了较为全面的回答,对这些受欢迎的 Github 开源项目分类整理如下: 分布式计算、云平台相关工具类 1.SkyWalking,作者吴晟、刘浩杨 等等 仓库地址: apache/skywalking 更...
相关热词 c# clr dll c# 如何orm c# 固定大小的字符数组 c#框架设计 c# 删除数据库 c# 中文文字 图片转 c# 成员属性 接口 c#如何将程序封装 16进制负数转换 c# c#练手项目
立即提问