SAP CRM WebClient UI的内存清理策略分析
If we searched 5 PPR and go to Account and then go to PPR again, search results are still there.
data:image/s3,"s3://crabby-images/8cb3a/8cb3ab63fce27f168b463c38193c6db6ae7f6e63" alt=""
Why are the two navigation causing different behavior?
Some key points we must remember:
Every time you navigate away from current view, WD_DESTROY will be called, either the child’s own redefined one or default implementation of parent.
data:image/s3,"s3://crabby-images/3f7c8/3f7c8695984200f2d3aed1b9d5f25fa6914994ee" alt=""
DESTROY method of context node class will be called one by one.
data:image/s3,"s3://crabby-images/7b731/7b73183affd0ffe2c23ea0691101bdb191f3f336" alt=""
data:image/s3,"s3://crabby-images/3d136/3d136f3d377d4b14d52be71dba162dfdf99cf308" alt=""
In PPR case, since RESULT node in view controller is mapped to RESULT in component controller via context binding, so collection wrapper will not be cleared.
data:image/s3,"s3://crabby-images/a833e/a833ea581b3ad6500801a9a6ca6aea989f52fec0" alt=""
Instead it will just clear the context node reference itself.
Let’s record down the real BOL collection in collection wrapper before CLEAR me->typed_context.
data:image/s3,"s3://crabby-images/7c717/7c7172f9bab8f2f8d08bf88a4d07d8e4145ce2a5" alt=""
{O:1253*\CLASS=CL_CRM_BOL_ENTITY_COL}
After clear is executed, we check {O:1253*\CLASS=CL_CRM_BOL_ENTITY_COL} in debugger:
The 5 PPR BOL entities are still there:
data:image/s3,"s3://crabby-images/34949/349493a91fb3dfed4d55eff370472bc4998e163d" alt=""
That means WD_DESTORY will only clear context node reference itself, but not the real BOL content in BOL wrapper.
The BOL content will only be cleared when:
When navigation is being executed, framework event will be raised:
data:image/s3,"s3://crabby-images/de847/de847d433a68fe6c3f59b6a7d70a9bf4e1cd0c04" alt=""
data:image/s3,"s3://crabby-images/4a8bd/4a8bd6b36d3b969ccb666f8a81da434bf0e7d21e" alt=""
CL_CRM_UI_SESSION_RESTART works as event handler and will clear bol buffer by evaluating flag gv_bol_reset_requested.
data:image/s3,"s3://crabby-images/94f03/94f0313311c13ac775f9b63d13323af7884a7ca2" alt=""
In lv_bolcore_reset the 5 PPR entities will be deleted in BOL container.
data:image/s3,"s3://crabby-images/8e8aa/8e8aa684513df4f7a02b9d118163ee8931e4c826" alt=""
So now question is when is gv_bol_reset_requested set?
For example if you click “Home”,
data:image/s3,"s3://crabby-images/99972/999727e328d3d17e2a3dcf87612bdd4f145c041d" alt=""
Framework will evaluate if the navigation target is a Workcenter.
data:image/s3,"s3://crabby-images/012b4/012b4afe80a80d4826337f698983996e2fa2f511" alt=""
If so, the framework event before_context_change will be raised.
data:image/s3,"s3://crabby-images/c5f12/c5f12d1e82050fed6b6dae6397ccde7498f83f4d" alt=""
The event handler for it will simply set restart_requested flag to ‘X’.
data:image/s3,"s3://crabby-images/fdc4b/fdc4bfc1d5c03ab84b9604ec53a6e9db50bbf3ee" alt=""
Later this flag will be evaluated and set gv_bol_reset_requested.
data:image/s3,"s3://crabby-images/0ecc3/0ecc37736e116d31522c4651174ee37a78edb416" alt=""
If you just click a work center view for example “Accounts”, line 91 will not be executed and thus gv_bol_reset_requested will always equal to abap_false.
data:image/s3,"s3://crabby-images/c018c/c018cdea618cfaf5073ffc0f3be9c9859c893338" alt=""
要获取更多Jerry的原创文章,请关注公众号"汪子熙":
data:image/s3,"s3://crabby-images/dbdb5/dbdb58b6e07a167b4c721ac53e4d5857cad20da6" alt=""