欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android OKHTTP的單例和再封裝的實(shí)例

 更新時(shí)間:2017年07月31日 09:23:44   作者:下一個(gè)丶奇跡  
這篇文章主要介紹了Android OKHTTP的單例和再封裝的實(shí)例的相關(guān)資料,這里對(duì)OKHTTP的單例進(jìn)行了分析總結(jié),需要的朋友可以參考下

Android OKHTTP的單例和再封裝的實(shí)例

/**
 * Created by zm on 16-2-1
 * okhttp的再封裝,對(duì)于2.x版本,3.x版本將原有對(duì)okhttpclient配置
 * 改成了builder模式配
 * 置,對(duì)于超時(shí)、代理、dns,okhttp已經(jīng)做好了配置,
 * 若不需要特殊配置,可以跳過(guò)
 */
public class OkHttpUtil
{
  private static OkHttpClient singleton;
  //非常有必要,要不此類還是可以被new,但是無(wú)法避免反射,好惡心
  private OkHttpUtil(){

  }
  public static OkHttpClient getInstance() {
    if (singleton == null)
    {
      synchronized (OkHttpUtil.class)
      {
        if (singleton == null)
        {
          singleton = new OkHttpClient();
        }
      }
    }
    return singleton;
  }
}

之前在看okhttp源碼的時(shí)候,發(fā)現(xiàn)square沒(méi)有對(duì)okhttpclient進(jìn)行單例,網(wǎng)上也沒(méi)找到合適的解釋,以下是自己的猜測(cè)

優(yōu)點(diǎn):使用單例模式,避免了多次創(chuàng)建所產(chǎn)生的垃圾

缺點(diǎn):對(duì)于一些特殊需求的代碼進(jìn)行一些靈活的配置,單例模式難以實(shí)現(xiàn)

總結(jié):做為優(yōu)秀的開源框架,square出發(fā)點(diǎn)是讓用戶更好更靈活的使用和擴(kuò)展,從用戶角度來(lái)說(shuō),對(duì)于不需要多次配置的項(xiàng)目,可以手動(dòng)寫一個(gè)單例模式,便于內(nèi)存的高效利用

/**
 * okhttp再次封裝
 * Created by zm on 16-2-1
 * update by zm on 16-3-19 增加Builder,方便以后內(nèi)容或者字段的擴(kuò)展
 * 
 */
public class HttpTools
{
  private Context context;
  private final RequestParams req;
  private final Handler handler;

  public HttpTools(Builder builder)
  {
    // TODO Auto-generated constructor stub
    context = builder.context;
    req = builder.req;
    handler = builder.handler;
  }

  public static class Builder
  {
    private final RequestParams req;
    private final Context context;
    private final Handler handler;

    public Builder(RequestParams req, Context mContext, Handler handler)
    {
      // TODO Auto-generated constructor stub
      this.req = req;
      this.context = mContext;
      this.handler = handler;
    }

    public HttpTools build() {
      return new HttpTools(this);
    }
  }

  public void requestBuilder() {
    // TODO Auto-generated method stub
    if(req==null||context==null||handler==null){
      throw new NullPointerException("NullPointerException");
    }
    requestGet(req, context, handler);
  }

  private static void parse(Call call, final Handler handler,
      final RequestParams req) {
    // 請(qǐng)求加入調(diào)度
    call.enqueue(new Callback()
    {
      @Override
      public void onResponse(Call call, Response response)
          throws IOException {
        // TODO Auto-generated method stub
        String result = response.body().string();
        if (result != null)
        {
          Message message = Message.obtain();
          message.obj = result;
          message.what = req.getSuccessMsgWhat();
          handler.sendMessage(message);
        }
      }

      @Override
      public void onFailure(Call call, IOException e) {
        // TODO Auto-generated method stub
        handler.sendEmptyMessage(req.getFailMsgWhat());
      }
    });
  }

  /**
   * 
   * @param req
   * @param context
   * @param handler
   * 
   *      get請(qǐng)求
   */
  public static void requestGet(final RequestParams req,
      final Context context, final Handler handler) {
    // 創(chuàng)建一個(gè)Request
    final Request request = new Request.Builder().url(req.getRequestUrl()).build();
    Call call = OkHttpUtil.getInstance().newCall(request);
    parse(call, handler, req);
  }

  /**
   * post請(qǐng)求
   */
  public static void requestPost(final RequestParams req,
      final Context context, final Handler handler) {
    FormBody.Builder builder = new FormBody.Builder();
    //此處是對(duì)RequestParams的遍歷,RequestParams類省略
    for (Map.Entry<String, Object> mEntry : req.getParamEntry())
    {
      String mEntryKey = mEntry.getKey();
      Object mEntryValue = mEntry.getValue();
      if (TextUtils.isEmpty(mEntryKey))
      {
        continue;
      }
      builder.add(mEntryKey, mEntryValue.toString());
    }
    RequestBody body = builder.build();
    Request request = new Request.Builder().url(req.getUrl()).post(body).build();

    Call call = OkHttpUtil.getInstance().newCall(request);
    parse(call, handler, req);
  }

  /**
   *      數(shù)據(jù)請(qǐng)求的集中管理,方便以后一鍵替換,從get到post
   */
  public static void request(RequestParams req, Context mContext,
      Handler handler) {
    // TODO Auto-generated method stub
    requestGet(req, mContext, handler);
  }
}

最后再奉獻(xiàn)上一個(gè)封裝類

/**
 * 
 * Created by zm on 16-2-1
 * 基于Gson的json轉(zhuǎn)model封裝類
 *
 */
public class JsonToModel
{

private static String info = "info";

  public static String getInfo()
  {
    return info;
  }

  public static void setInfo(String info)
  {
    JsonToModel.info = info;
  }
  /**
   * 
   * @param msg
   * @param t
   *      model類
   * @param model
   *      model對(duì)象
   * @return
   */
  public static <T> List<T> getJsonArrayToModel(Message msg, Class<T> t,
      T model) {
    // TODO Auto-generated method stub
    List<T> list = new ArrayList<T>();
    try {
      JSONObject json = new JSONObject(msg.obj.toString());
      for (int i = 0; i < json.getJSONArray(getInfo()).length(); i++) {
        model = GsonHelper.toType(json.getJSONArray(getInfo()).get(i).toString(), t);
        list.add(model);
      }
      return list;
    } catch (Exception e) {
      // TODO Auto-generated catch block
      Log.e("getJsonArrayToModel", "error");
      e.printStackTrace();
    }
    return null;
  }
}

json轉(zhuǎn)model的這個(gè)類中,當(dāng)時(shí)沒(méi)考慮到過(guò)多性能的問(wèn)題,在此類中即使用了org.json.JSONObject也使用了gson,此處還可以做出相應(yīng)的優(yōu)化

如有疑問(wèn)請(qǐng)留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!

相關(guān)文章

最新評(píng)論