摘要:數據庫數據表的設計的示例代碼實際上在異步的處理過程中很難做到,這里的類型無法確定,調用方法也無法做到,需要反射的示例代碼弱類型語言就沒有這樣的麻煩,就能得到原來的實例對象。
在舊的業務流程加入一個“攔截”,原來從前端表單提交到后臺的處理邏輯延后處理,本質上是一個異步化的處理過程。
此時將表單參數存儲到數據庫,在適當的時刻“攔截”結束通過時調用原來的處理邏輯。
F代表表單參數,A代表控制器參數,
F --> A --> F" --> A";
思考以上的流程,
①F --> A,從前端到controller方法
②A --> F",將參數存儲到數據庫
③F" --> A", 從數據庫取出原來的參數對象,希望A"能夠完全表達A, A" == A,包括參數類型與順序。
數據庫數據表的設計
table at_form{ id bigint, name varchar json varchar type_token varchar? }
Java的示例代碼
public class AtFormApp { public static void main(String[] args) throws IOException, ClassNotFoundException { Person p = new Person(); p.name = "Honey"; p.age = 26; controlMethod1(p); controlMethod2(); } static class Person { String name; int age; } static void controlMethod1(Person p) throws IOException { saveService(p, "p"); } static void controlMethod2() throws IOException, ClassNotFoundException { AtForm atForm = query(); ObjectInputStream ois = new ObjectInputStream(new ByteArrayInputStream(atForm.typeToken.getBytes())); Type type = (Type) ois.readObject(); //Person type here Person p = new Gson().fromJson(atForm.json, type.getClass()); realService(p); } static void saveService(Person p, String name) throws IOException { Type type = new TypeToken() {}.getType(); String json = new Gson().toJson(p); ByteArrayOutputStream baos = new ByteArrayOutputStream(); ObjectOutputStream oos = new ObjectOutputStream(baos); oos.writeObject(type); oos.close(); String typeToken = baos.toString(); AtForm atForm = new AtForm(); atForm.name = name; atForm.json = json; atForm.typeToken = typeToken; insert(atForm); } static void realService(Person p) { //good } static AtForm query() throws IOException { AtForm atForm = new AtForm(); atForm.name = "p"; atForm.json = "{"name":"Honey","age":26}"; Type type = new TypeToken () {}.getType(); ByteArrayOutputStream baos = new ByteArrayOutputStream(); ObjectOutputStream oos = new ObjectOutputStream(baos); oos.writeObject(type); oos.close(); String typeToken = baos.toString(); atForm.typeToken = typeToken; return atForm; } //imitate insert behavior static int insert(AtForm atForm) { return 1; } static class AtForm { Long id; String typeToken; String name; String json; } }
實際上在異步的處理過程中很難做到,
這里的Person類型無法確定,調用realService方法也無法做到,需要反射?
PHP的示例代碼
name = "Honey"; $p->age = 26; $this->controlMethod1($p); $this->controlMethod2(); } public function controlMethod1(Person $p) { $this->saveService($p, "p"); } public function controlMethod2() { $atForm = AtForm::findOne(["name" => "p"]); $p = unserialize($atForm->data); $this->realService($p); } public function saveService(Person $p, $name) { $atForm = new AtForm(); $atForm->name = $name; $atForm->data = serialize($p); $atForm.save(); } public function realService(Person $p) { // good } } class Person { public $name; public $age; } class AtForm() { public $id; public $name; public $data; public static findOne($condition) {} public save() {} }
弱類型語言就沒有這樣的麻煩,
$p = unserialize($atForm->data);就能得到原來的Person實例對象。
后面調用realService($p)也很自然。雖然這里討論的示例中只有一個參數,但是多個參數的情況下,PHP也能支持。
感謝@Tranch提供的PHP示例代碼
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/68644.html
摘要:數據庫數據表的設計的示例代碼實際上在異步的處理過程中很難做到,這里的類型無法確定,調用方法也無法做到,需要反射的示例代碼弱類型語言就沒有這樣的麻煩,就能得到原來的實例對象。 在舊的業務流程加入一個攔截,原來從前端表單提交到后臺的處理邏輯延后處理,本質上是一個異步化的處理過程。此時將表單參數存儲到數據庫,在適當的時刻攔截結束通過時調用原來的處理邏輯。F代表表單參數,A代表控制器參數, F...
摘要:然而,中依然有可能發生內存泄漏。所以你的安卓快速定位解決內存泄漏掘金昨天是個好日子,程序員的節日,在這里給所有的程序員送上一份遲到的祝福。應用內存泄漏的定位分析與解決策略掘金,大家好,我是。 Android 性能優化之巧用軟引用與弱引用優化內存使用 - Android - 掘金前言: 從事Android開發的同學都知道移動設備的內存使用是非常敏感的話題,今天我們來看下如何使用軟引用與弱...
摘要:第一次初始化對象,并且用變量來引用,所以這里的引用計數就為。接下來通過創建一個弱引用,通過打印引用計數后,發現計數并沒有改變。由于一次僅能有一個對象被回收,引用計數無法回收循環引用的對象。所以弱引用很適合處理這種循環引用的場景。 寫在前邊: 之前的socket系列就告一段落,主要是對自己所學做一個總結與記錄。 接下來我打算基于libevent寫一個支持并發的HTTP服務器。因為之前學習...
閱讀 1527·2023-04-25 17:41
閱讀 3048·2021-11-22 15:08
閱讀 849·2021-09-29 09:35
閱讀 1613·2021-09-27 13:35
閱讀 3332·2021-08-31 09:44
閱讀 2722·2019-08-30 13:20
閱讀 1945·2019-08-30 13:00
閱讀 2565·2019-08-26 12:12