Android架构: MVC 新浪微博
由于项目的需要,最近研究了一下需要连接网络项目的MVC架构,参考了一下一个新浪微博的开发架构
http://www.open-open.com/lib/view/open1345524526767.html
大体描述如下
需求:项目中接口很多,联网操作在Activity中处理会非常浩大且那一维护
解决方案:将数据提供层和表现层分开,数据层请求接口的数据 , Activity只处理从数据层来的数据,
那我们看一下Activity的实现:
首先定义了一个接口用于规范将来的activty中的方法
1
2
3
4
5
6
7
8
9
10
11
|
package com.testaijialogic; public interface IAijiaActivity { void init(); // 初始化数据 void initView(); // 初始化界面控件 void refresh(Object... param); // 刷新 内容 不知道可变参数的可以再去学习下coreJva } |
然后是Activity
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
|
package com.testaijialogic; /** * MVC * M 提供数据 * V 显示给用户 * C 把M的数据显示到视图 */ import java.util.HashMap; import java.util.List; import com.testaijialogic.domain.PersonEntity; import com.testaijialogic.widget.PersonAdapter; import android.app.Activity; import android.app.ProgressDialog; import android.content.Context; import android.content.Intent; import android.os.Bundle; import android.util.Log; import android.view.View; import android.widget.Button; import android.widget.ListView; public class TestAijiaLogicActivity extends Activity implements IAijiaActivity { private Context context; private ListView listView; private ProgressDialog progressDialog; private Button button; private ListView listView2; public void onCreate(Bundle savedInstanceState) { super .onCreate(savedInstanceState); setContentView(R.layout.main); context = TestAijiaLogicActivity. this ; Intent intent = new Intent( "com.testaijialogic.MainService" ); // 在首个Activity开启服务 startService(intent); initView(); init(); Log.i( "Create" , "=====" ); } protected void onPause() { super .onPause(); Log.i( "onPause" , "=====" ); } protected void onResume() { super .onResume(); Log.i( "onResume" , "=====" ); } protected void onDestroy() { super .onDestroy(); android.os.Process.killProcess(android.os.Process.myPid()); } @Override public void init() { // 初始化list的数据 @SuppressWarnings ( "rawtypes" ) HashMap param = new HashMap(); param.put( "product" , "testTask" ); // 加载搜索页面微博信息的任务 MainService.addActivity(TestAijiaLogicActivity. this ); Task task = new Task(Task.GETPRODUCT, param, context); MainService.newTask(task); // 添加新任务 progressDialog.show(); } @Override public void refresh(Object... param) { @SuppressWarnings ( "unchecked" ) HashMap map = (HashMap) param[ 0 ]; // 获取map的数据 List<PersonEntity> personlist = (List<PersonEntity>) map.get( "product" ); PersonAdapter personAdapter = new PersonAdapter(context, personlist); listView.setAdapter(personAdapter); List<PersonEntity> subpersonlist = (List<PersonEntity>) map // 加载第二个listview .get( "subproduct" ); PersonAdapter subpersonAdapter = new PersonAdapter(context, subpersonlist); listView2.setAdapter(subpersonAdapter); progressDialog.dismiss(); Log.i( "测试" , "setadapter" ); } public void initView() { listView = (ListView) findViewById(R.id.listView1); listView2 = (ListView) findViewById(R.id.listView2); button = (Button) findViewById(R.id.button1); button.setOnClickListener( new View.OnClickListener() { @Override public void onClick(View v) { init(); } }); progressDialog = new ProgressDialog( this ); progressDialog.setMessage( "正在获取数据" ); } } |
可以看到,表现层只是把数据展示到xml中,没有牵扯到请求接口
下面是数据请求层
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
|
package com.testaijialogic; /** * 任务实体,由于储存认为信息 */ import java.util.HashMap; import android.content.Context; public class Task { public static final int GETPRODUCT = 1 ; public static final int GETPRODUCT2 = 5 ; public static final int MSGACTIVITY = 4 ; public static final int NEWWEIBO = 7 ; public static final int HOMEREFRESH = 3 ; public static final int VIEWWEIBO = 8 ; private int taskId; private HashMap taskParams; private Context ctx; public Task( int taskId, HashMap taskParams, Context ctx) { super (); this .taskId = taskId; this .taskParams = taskParams; this .ctx = ctx; } public int getTaskId() { return taskId; } public void setTaskId( int taskId) { this .taskId = taskId; } public HashMap getTaskParams() { return taskParams; } public void setTaskParams(HashMap taskParams) { this .taskParams = taskParams; } public Context getCtx() { return ctx; } public void setCtx(Context ctx) { this .ctx = ctx; } } |
Person实体,储存人员信息
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
package com.testaijialogic.domain; public class PersonEntity { // {"amount":100,"id":1,"name":"itcastliming"} private int id; private String name; private String amount; public PersonEntity( int id, String name, String amount) { setId(id); setAmount(amount); setName(name); } /** * @return the id */ public int getId() { return id; } /** * @param id * the id to set */ public void setId( int id) { this .id = id; } /** * @return the name */ public String getName() { return name; } /** * @param name * the name to set */ public void setName(String name) { this .name = name; } /** * @return the amount */ public String getAmount() { return amount; } /** * @param amount * the amount to set */ public void setAmount(String amount) { this .amount = amount; } } |
核心网络服务,请求项目的所有接口数据
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
|
package com.testaijialogic; /* * 获取服务器信息服务 * */ import java.util.ArrayList; import java.util.HashMap; import java.util.List; import org.json.JSONArray; import org.json.JSONException; import org.json.JSONObject; import com.testaijialogic.domain.PersonEntity; import com.testaijialogic.util.WebSender; import android.app.Activity; import android.app.AlertDialog; import android.app.Service; import android.content.Context; import android.content.DialogInterface; import android.content.Intent; import android.content.DialogInterface.OnClickListener; import android.os.Handler; import android.os.IBinder; import android.os.Message; import android.util.Log; public class MainService extends Service implements Runnable { private static ArrayList<IAijiaActivity> allActivity = new ArrayList<IAijiaActivity>(); private static ArrayList<Task> allTasks = new ArrayList<Task>(); List<String> p = new ArrayList<String>();// post的参数 注意设置成全局变量后只能一次放松一个Post了 List<String> v = new ArrayList<String>();// post的数值 public static boolean isRun = false; public static void newTask(Task t) { allTasks.add(t); } public static void addActivity(IAijiaActivity iw) { allActivity.add(iw); } public static void removeActivity(IAijiaActivity iw) { allActivity.remove(iw); } public static IAijiaActivity getActivityByName(String name) { for (IAijiaActivity iw : allActivity) { if (iw.getClass().getName().indexOf(name) >= 0) { return iw; } } return null; } @Override public void onCreate() { // TODO Auto-generated method stub super.onCreate(); isRun = true; new Thread(this).start(); Log.e("=============================", "MainService onCreate()"); } @Override public void onDestroy() { isRun = false; stopSelf(); super.onDestroy(); } @Override public void run() { // TODO Auto-generated method stub while (isRun) { try { if (allTasks.size() > 0) { // 执行任务,可以遍历执行多个任务 // doTask(allTasks.get(0)); for (Task task : allTasks) { doTask(task); } } else { try { Thread.sleep(1000); } catch (Exception e) { } } } catch (Exception e) { if (allTasks.size() > 0) allTasks.remove(allTasks.get(0)); Log.d("error", "------------------" + e); } } } private Handler handler = new Handler() { @Override public void handleMessage(Message msg) { // TODO Auto-generated method stub super.handleMessage(msg); switch (msg.what) { case Task.GETPRODUCT: MainService.getActivityByName("TestAijiaLogicActivity") .refresh(msg.obj);// 调用TestAijiaLogicActivity的方法刷新控件 break; case Task.GETPRODUCT2:// 个人资料 break; case Task.MSGACTIVITY: break; case Task.NEWWEIBO: break; case Task.VIEWWEIBO: break; default: break; } } }; @SuppressWarnings("unchecked") private void doTask(Task task) throws JSONException { // TODO Auto-generated method stub Message msg = handler.obtainMessage(); msg.what = task.getTaskId(); switch (task.getTaskId()) { case Task.GETPRODUCT:// 获取产品信息 Log.i("有任务执行", "MainS" + task.getTaskId()); String urlStr = "http://10.1.49.230/test/testjson.php"; p.add("product");// 增加post的参数名 v.add((String) task.getTaskParams().get("product"));// 增加post的参数的值 String result = WebSender.httpClientSendPost(urlStr, p, v);// 发送httppost请求 List<PersonEntity> personEntities = new ArrayList<PersonEntity>(); JSONArray jsonArray = new JSONArray(result); for (int i = 0; i < jsonArray.length(); i++) { JSONObject jsonObject = jsonArray.getJSONObject(i); PersonEntity personEntity = new PersonEntity( jsonObject.getInt("id"), jsonObject.getString("name"), jsonObject.getString("amount")); personEntities.add(personEntity); } /** * 第二次请求联网,返回list , 也可以使用多任务处理,但是当前项目中界面的listview特别多所以使用这样 */ String suburlStr = "http://10.1.49.230/test/testsubjson.php"; p.add("product");// 增加post的参数名 v.add((String) task.getTaskParams().get("product"));// 增加post的参数的值 String subresult = WebSender.httpClientSendPost(suburlStr, p, v);// 发送httppost请求 List<PersonEntity> subpersonEntities = new ArrayList<PersonEntity>(); JSONArray subjsonArray = new JSONArray(subresult); for (int i = 0; i < jsonArray.length(); i++) { JSONObject jsonObject = subjsonArray.getJSONObject(i); PersonEntity personEntity = new PersonEntity( jsonObject.getInt("id"), jsonObject.getString("name"), jsonObject.getString("amount")); subpersonEntities.add(personEntity); } @SuppressWarnings("rawtypes") HashMap map = new HashMap(); map.put("product", personEntities); map.put("subproduct", subpersonEntities); msg.obj = map; // msg.obj = personEntities;//如果只需要一个list那用这个就可以 break; default: break; } allTasks.remove(task); // 通知主线程更新UI handler.sendMessage(msg); } @Override public IBinder onBind(Intent intent) { // TODO Auto-generated method stub return null; } /** * 退出应用程序 * * @param context */ public static void exitAPP(Context context) { Intent it = new Intent("weibo4android.logic.util.MainService"); context.stopService(it);// 停止服务 // 杀死进程 我感觉这种方式最直接了当 android.os.Process.killProcess(android.os.Process.myPid()); } public static void finshall() { for (IAijiaActivity activity : allActivity) {// 遍历所有activity 一个一个删除 ((Activity) activity).finish(); } } /** * 网络连接异常 * * @param context */ public static void AlertNetError( final Context context) { AlertDialog.Builder alerError = new AlertDialog.Builder(context); alerError.setTitle( "网络错误" ); alerError.setMessage( "请检查网络" ); alerError.setNegativeButton( "退出" , new OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { dialog.dismiss(); exitAPP(context); } }); alerError.setPositiveButton( "确定" , new OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { dialog.dismiss(); context.startActivity( new Intent( android.provider.Settings.ACTION_WIRELESS_SETTINGS)); } }); alerError.create().show(); } } |
网络工具类
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
|
package com.testaijialogic.util; /** *网络通信类(已优化) * */ import java.io.BufferedReader; import java.io.DataOutputStream; import java.io.InputStream; import java.io.InputStreamReader; import java.io.PrintWriter; import java.net.HttpURLConnection; import java.net.URL; import java.util.ArrayList; import java.util.List; import org.apache.http.HttpEntity; import org.apache.http.HttpResponse; import org.apache.http.HttpStatus; import org.apache.http.NameValuePair; import org.apache.http.client.HttpClient; import org.apache.http.client.ResponseHandler; import org.apache.http.client.entity.UrlEncodedFormEntity; import org.apache.http.client.methods.HttpGet; import org.apache.http.client.methods.HttpPost; import org.apache.http.impl.client.BasicResponseHandler; import org.apache.http.impl.client.DefaultHttpClient; import org.apache.http.message.BasicNameValuePair; import org.apache.http.util.EntityUtils; import android.util.Log; public class WebSender { /* * 比较原始的 POST Cookies */ public static String[] sendPost(String urlStr, String[] param, String[] value, String cookies) { String[] result = { "", "" }; String paramValue = ""; StringBuffer buffer = null; HttpURLConnection con = null; try { URL url = new URL(urlStr); con = (HttpURLConnection) url.openConnection(); con.setRequestMethod("POST"); con.setRequestProperty("Connection", "Keep-Alive"); con.setRequestProperty("Charset", "UTF-8"); // con.setRequestProperty("Content-Type", "text/html"); // set cookies if (QHFlag.isNotEmpty(cookies)) { con.setRequestProperty("cookie", cookies); } paramValue = WebSender.getParamStr(param, value); con.setDoOutput(true); con.setDoInput(true); con.setUseCaches(false); con.setConnectTimeout(50000);// 设置连接主机超时(单位:毫秒) con.setReadTimeout(50000);// 设置从主机读取数据超时(单位:毫秒) con.connect();// connect open PrintWriter out = new PrintWriter(con.getOutputStream());// 发送数据 out.print(paramValue); out.flush(); out.close(); // get cookies String cks = con.getHeaderField("set-cookie"); if (cks != "" && cks != null) result[1] = cks; // get status int res = 0; res = con.getResponseCode(); // get info response if (res == 200 || res == 302) { BufferedReader in = new BufferedReader(new InputStreamReader( con.getInputStream(), "UTF-8")); buffer = new StringBuffer(); String line = ""; while ((line = in.readLine()) != null) { buffer.append(line); } } else { QHFlag.e("Web Response:" + res); } con.disconnect();// Connect Close! } catch (Exception e) { // e.printStackTrace(); } if (buffer.length() != 0 && buffer != null) { result[0] = buffer.toString(); } return result; } /* * 使用HttpClient对象发送GET请求 */ public static String httpClientSendGet(String webUrl) { String content = null; // DefaultHttpClient DefaultHttpClient httpclient = new DefaultHttpClient(); // HttpGet HttpGet httpget = new HttpGet(webUrl); // ResponseHandler ResponseHandler<String> responseHandler = new BasicResponseHandler(); try { content = httpclient.execute(httpget, responseHandler); } catch (Exception e) { e.printStackTrace(); } httpclient.getConnectionManager().shutdown(); return content; } /* * 使用HttpClient对象发送有cookie的GET请求 */ public static String httpClientSendGet(String urlStr, String Cookies) { String httpUrl = urlStr; HttpGet httpGet = new HttpGet(httpUrl); try { HttpClient httpClient = new DefaultHttpClient(); httpGet.setHeader("cookie", Cookies); // 请求HttpClient,取得HttpResponse HttpResponse httpResponse = httpClient.execute(httpGet); // 请求成功 if (httpResponse.getStatusLine().getStatusCode() == HttpStatus.SC_OK) { // 取得返回的字符串 String strResult = EntityUtils.toString(httpResponse .getEntity()); return strResult; } } catch (Exception e) { } return "0"; } /* * 使用HttpClient对象发送POST请求 */ public static String httpClientSendPost(String urlStr, List<String> paraName, List<String> val) { String httpUrl = urlStr; // HttpPost对象 HttpPost httpPost = new HttpPost(httpUrl); // 使用NameValuePair来保存要传递的Post参数 List<NameValuePair> params = new ArrayList<NameValuePair>(); // 添加要传递的参数 System.out.println("===================================="); for (int i = 0; i < paraName.size(); i++) { params.add(new BasicNameValuePair(paraName.get(i), val.get(i))); System.out.println(paraName.get(i) + "->" + val.get(i)); } System.out.println("===================================="); try { // 设置字符集 HttpEntity httpEntity = new UrlEncodedFormEntity(params, "utf-8"); httpPost.setEntity(httpEntity); // httpClient对象 HttpClient httpClient = new DefaultHttpClient(); // 请求HttpClient,取得HttpResponse HttpResponse httpResponse = httpClient.execute(httpPost); // 请求成功 if (httpResponse.getStatusLine().getStatusCode() == HttpStatus.SC_OK) { // 取得返回的字符串 String strResult = EntityUtils.toString(httpResponse .getEntity()); System.out.println(strResult); return strResult; } } catch (Exception e) { } return ""; } /* * 使用HttpClient对象发送POST请求 */ public static String httpClientSendPost(String urlStr, List<String> paraName, List<String> val, String Cookies) { String httpUrl = urlStr; // HttpPost对象 HttpPost httpPost = new HttpPost(httpUrl); // 使用NameValuePair来保存要传递的Post参数 List<NameValuePair> params = new ArrayList<NameValuePair>(); // 添加要传递的参数 System.out.println("===================================="); for (int i = 0; i < paraName.size(); i++) { params.add(new BasicNameValuePair(paraName.get(i), val.get(i))); System.out.println(paraName.get(i) + "->" + val.get(i)); } System.out.println("===================================="); try { // 设置字符集 HttpEntity httpEntity = new UrlEncodedFormEntity(params, "utf-8"); httpPost.setEntity(httpEntity); httpPost.setHeader("cookie", Cookies); // httpClient对象 HttpClient httpClient = new DefaultHttpClient(); // 请求HttpClient,取得HttpResponse HttpResponse httpResponse = httpClient.execute(httpPost); // 请求成功 if (httpResponse.getStatusLine().getStatusCode() == HttpStatus.SC_OK) { // 取得返回的字符串 String strResult = EntityUtils.toString(httpResponse .getEntity()); System.out.println(strResult); return strResult; } } catch (Exception e) { } return ""; } public static String uploadBitmap1(String urlString, byte[] imageBytes, String cookie) { // String boundary = "*****"; try { URL url = new URL(urlString); final HttpURLConnection con = (HttpURLConnection) url .openConnection(); // 允许input、Output,不使用Cache con.setDoInput(true); con.setDoOutput(true); con.setUseCaches(false); // 设置传送的method=POST con.setRequestMethod("POST"); // setRequestProperty con.setRequestProperty("Connection", "Keep-Alive"); con.setRequestProperty("Charset", "UTF-8"); con.setRequestProperty("Content-Type", "text/html"); if (cookie != null && cookie != "") { Log.i("myEvent", "send cookies value is:" + cookie); con.setRequestProperty("cookie", cookie); } // 从主机读取数据的超时时间(单位:毫秒) con.setReadTimeout(50000); // 设置连接主机的超时时间(单位:毫秒) con.setConnectTimeout(50000); // System.out.println(con.getResponseCode()); // 设置DataOutputStream DataOutputStream dsDataOutputStream = new DataOutputStream( con.getOutputStream()); // dsDataOutputStream.writeBytes(twoHyphen + boundary + endString); // dsDataOutputStream.writeBytes("Content-Disposition:form-data;" // + "name=\"file1\";filename=\"" + "11.jpg\"" + endString); // dsDataOutputStream.writeBytes(endString); dsDataOutputStream.write(imageBytes, 0, imageBytes.length); // dsDataOutputStream.writeBytes(endString); // dsDataOutputStream.writeBytes(twoHyphen + boundary + twoHyphen // + endString); dsDataOutputStream.close(); int cah = con.getResponseCode(); if (cah == 200) { InputStream isInputStream = con.getInputStream(); int ch; StringBuffer buffer = new StringBuffer(); while ((ch = isInputStream.read()) != -1) { buffer.append((char) ch); } return buffer.toString(); } else { return "false"; } } catch (Exception e) { e.printStackTrace(); return "false"; } } /** * 请求字符串 * */ public static String getParamStr(String[] param, String[] value) { String res = "" ; if (param.length == value.length) { for ( int i = 0 ; i < param.length; i++) { res += param[i] + "=" + toUTF8(value[i]) + "&" ; } } return res.substring( 0 , res.length() - 1 ); } public static String toUTF8(String str) { String u = str; try { u = java.net.URLEncoder.encode(u, "UTF-8" ); } catch (Exception e) { } return u; } }
|
Android架构: MVC 新浪微博的更多相关文章
- 一种更清晰的Android架构(转)
一种更清晰的Android架构 一种更清晰的Android架构 原文链接 : Architecting Android…The clean way? 译者 : Mr.Simple & So ...
- Android进阶笔记07:Android之MVC 理解
1. 为什么需要MVC ? 软件中最核心的,最基本的东西是什么? 答:是的,是数据.我们写的所有代码,都是围绕数据的. 围绕着数据的产生.修改等变化,出现了业务逻辑. 围绕着数 ...
- Android架构初探
#一 背景点评美团合并之后,业务需要整合,我们部门的几条业务需要往美团平台迁移,为了降低迁移成本,开发和维护成本,以及将来可能要做的单元测试,需要对架构进行相应的调整.之前的代码都堆在Activity ...
- Android中MVC模型(复合模式)
mvc是model,view,controller的缩写,mvc包括三个部分: 1.模型(model)对象:是应用程序的主体部分,全部的业务逻辑都应该写在该层. 2.视图(view)对象:是应用程序中 ...
- Android中MVC、MVP、MVVM具体解释
前言 今天有时间就刚好有想写关于这几个名词.对于我来说.事实上这么多名词.思想归根究竟就是要依据项目实际.人员配置来做合理优化,既不能纸上谈兵.又不能畏惧不前.那么合理分阶段架构和完好代码才是关键,本 ...
- Android与MVC设计模式
写在前面,之前做过一段时间移动开发,后来因为工作原因搁浅了,最新重新拿起Android权威编程指南学习,顺道做个学习笔记. 首先呢,我想说无论是计算机科班出身还是培训班出身,都听说过高内聚低耦合以及M ...
- Android和MVC
Activity和Android的mvc模式 http://blog.csdn.net/dengshengjin2234/article/details/8502097 //android涉及到的 ...
- 一个Android 架构师的成长之路
前言 总所周知,当下流行的编程语言有Java.PHP.C.C++.Python.Go等.其中,稳坐榜首的仍然是Java编程语言,且在以面向对象思想占主导的应用开发中,Java往往成为其代名词.Java ...
- 架构 MVC MVP MVVM 简介 MD
Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...
随机推荐
- 团队作业4---第一次项目冲刺(AIpha版本)第二天
一.Daily Scrum Meeting照片 二.燃尽图 三.项目进展 1.界面 完成了主页及登录页面 2.功能 完成了后端数据处理的全部基本功能:a.数据结构设计及数据交互操作 b.博客页面数据采 ...
- spring 注入使用注解(不用xml)
(一):导入spring4的jar包 (二):在xml中配置扫描的包 <context:component-scan base-package="entity">< ...
- 201521123073 《Java程序设计》第5周学习总结
1. 本周学习总结 2. 书面作业 1.代码阅读:Child压缩包内源代码 1.1 com.parent包中Child.java文件能否编译通过?哪句会出现错误?试改正该错误.并分析输出结果. 1.2 ...
- 201521123117 《Java程序设计》第12周学习总结
1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多流与文件相关内容. 2. 书面作业 将Student对象(属性:int id, String name,int age,doubl ...
- Linux系统下用户与组的管理
Linux系统下用户与组的管理 一.用户及组基本概述 Linux 系统上,用户管理是基于用户名和密码的方式进行资源的分配. 1.uid(用户身份标识) (1)root用户 uid为0 (2)普通用户: ...
- java使用POI操作XWPFDocument 生成Word实战(一)
注:我使用的word 2016功能简介:(1)使用jsoup解析html得到我用来生成word的文本(这个你们可以忽略)(2)生成word.设置页边距.设置页脚(页码),设置页码(文本) 一.解析ht ...
- Windbg调试(关于句柄表的获取,32位)
今天利用Windbg(x86)进行了获得句柄表的调试,从中获益良多,对调试步骤和按键又一次进行了熟悉,对于句柄表页的概念更是得到了进一步的清晰认识.windbg调试和句柄表不熟悉的朋友可以借鉴我的调试 ...
- JS中关于数组的内容
前 言 LIUWE 在网站制作过程中,数组可以说是起着举足轻重的地位.今天就给大家介绍一下数组的一些相关内容.例如:如何声明一个数组和在网站制作过程中我们常用的一些数组的方法.介绍的不好还请多多 ...
- java 基础语法 2
一.语句
- ArrayList底层实现原理
ArrayList概述: ArrayList是List接口的可变数组的实现.实现了所有可选列表操作,并允许包括null在内的所有元素.除了实现列表接口外,此类还提供一些方法来操作内部用来存储列表的数组 ...