httptransportse.call内存溢出..怎么处理啊?

PCU 2015-11-23 11:54:43
11-23 11:45:44.934 3514-3525/? E/StrictMode: A resource was acquired at attached stack trace but never released. See java.io.Closeable for information on avoiding resource leaks.
11-23 11:45:44.934 3514-3525/? E/StrictMode: java.lang.Throwable: Explicit termination method 'end' not called
11-23 11:45:44.934 3514-3525/? E/StrictMode: at dalvik.system.CloseGuard.open(CloseGuard.java:184)
11-23 11:45:44.934 3514-3525/? E/StrictMode: at java.util.zip.Inflater.<init>(Inflater.java:82)
11-23 11:45:44.934 3514-3525/? E/StrictMode: at java.util.zip.GZIPInputStream.<init>(GZIPInputStream.java:96)
11-23 11:45:44.934 3514-3525/? E/StrictMode: at java.util.zip.GZIPInputStream.<init>(GZIPInputStream.java:81)
11-23 11:45:44.934 3514-3525/? E/StrictMode: at com.android.okhttp.internal.http.HttpEngine.initContentStream(HttpEngine.java:471)
11-23 11:45:44.934 3514-3525/? E/StrictMode: at com.android.okhttp.internal.http.HttpEngine.readResponse(HttpEngine.java:669)
11-23 11:45:44.934 3514-3525/? E/StrictMode: at com.android.okhttp.internal.http.HttpURLConnectionImpl.execute(HttpURLConnectionImpl.java:357)
11-23 11:45:44.934 3514-3525/? E/StrictMode: at com.android.okhttp.internal.http.HttpURLConnectionImpl.getResponse(HttpURLConnectionImpl.java:306)
11-23 11:45:44.934 3514-3525/? E/StrictMode: at com.android.okhttp.internal.http.HttpURLConnectionImpl.getInputStream(HttpURLConnectionImpl.java:179)
11-23 11:45:44.934 3514-3525/? E/StrictMode: at org.ksoap2.transport.ServiceConnectionSE.openInputStream(ServiceConnectionSE.java:112)
11-23 11:45:44.934 3514-3525/? E/StrictMode: at org.ksoap2.transport.HttpTransportSE.call(HttpTransportSE.java:150)
11-23 11:45:44.934 3514-3525/? E/StrictMode: at org.ksoap2.transport.HttpTransportSE.call(HttpTransportSE.java:90)
11-23 11:45:44.934 3514-3525/? E/StrictMode: at com.example.pc.weixiu.fragment.TaskFragment.getRemoteInfo(TaskFragment.java:189)
11-23 11:45:44.934 3514-3525/? E/StrictMode: at com.example.pc.weixiu.fragment.TaskFragment.onCreateView(TaskFragment.java:90)
11-23 11:45:44.934 3514-3525/? E/StrictMode: at android.support.v4.app.Fragment.performCreateView(Fragment.java:1965)
...全文
238 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
jklwan 2015-11-23
  • 打赏
  • 举报
回复
发代码看看。话说你用了ksoap2怎么还用到okhttp了。
jklwan 2015-11-23
  • 打赏
  • 举报
回复
getRemoteInfo一下的代码改一下,你这个是因为在主线程执行网络请求的问题,至于1楼的问题明显不是这个demo。
public void getRemoteInfo(String phoneSec) {
        new Thread(new Runnable() {
            @Override
            public void run() {
                // 命名空间
                String nameSpace = "http://tempuri.org/";
                // 调用的方法名称
                String methodName = "UpdateLogLatByOperId";
                // EndPoint
                String endPoint = "http://192.168.0.117:8044/";
                // SOAP Action
                String soapAction = "http://tempuri.org/UpdateLogLatByOperId";

                // 指定WebService的命名空间和调用的方法名
                SoapObject rpc = new SoapObject(nameSpace, methodName);

                // 设置需调用WebService接口需要传入的两个参数mobileCode、userId
                rpc.addProperty("arg0", "1");
                rpc.addProperty("arg1", "1");
                rpc.addProperty("arg2", "333");
                rpc.addProperty("arg3", "444");

                // 生成调用WebService方法的SOAP请求信息,并指定SOAP的版本
                SoapSerializationEnvelope envelope = new SoapSerializationEnvelope(SoapEnvelope.VER10);

                envelope.bodyOut = rpc;
                // 设置是否调用的是dotNet开发的WebService
                envelope.dotNet = true;
                // 等价于envelope.bodyOut = rpc;
                envelope.setOutputSoapObject(rpc);

                HttpTransportSE transport = new HttpTransportSE(endPoint);
                try {
                    // 调用WebService
                    transport.call(soapAction, envelope);
                } catch (Exception e) {
                    e.printStackTrace();
                }


                // 获取返回的数据
                SoapObject object = (SoapObject) envelope.bodyIn;
//        envelope.dotNet = true;

                Message message = handler.obtainMessage();
                message.obj = object;
                handler.sendMessage(message);

            }
        });
    }
    private Handler handler = new Handler(){
        public void handleMessage(android.os.Message msg) {
            // 将WebService得到的结果返回给TextView
            SoapObject object = (SoapObject)msg.obj;
            // 获取返回的结果
            String result = object.getProperty(0).toString();

            // 将WebService返回的结果显示在TextView中
            resultView.setText(result);
        };
    };
PCU 2015-11-23
  • 打赏
  • 举报
回复
http://pan.baidu.com/s/1gd4mFhp这是这个demo的网盘...点击之后会出现内存溢出的错误提醒..谢谢

80,348

社区成员

发帖
与我相关
我的任务
社区描述
移动平台 Android
androidandroid-studioandroidx 技术论坛(原bbs)
社区管理员
  • Android
  • yechaoa
  • 失落夏天
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧