ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

对 JsonConvert 的认识太肤浅了,终于还是遇到了问题

2021-02-24 22:04:36  阅读:215  来源: 互联网

标签:set get int 遇到 肤浅 JsonConvert Model public


一:背景

1. 讲故事

在开始本文之前,真的好想做个问卷调查,到底有多少人和我一样,对 JsonConvert 的认识只局限在 SerializeObject 和 DeserializeObject 这两个方法上(┬_┬), 这样我也好结伴同行,不再孤单落魄,或许是这两个方法基本上能够解决工作中 80% 的场景,对于我来说确实是这样,但随着编码的延续,终究还是会遇到那剩下的 20% ,所以呀。。。

我的场景是这样的:前段时间写业务代码的时候,我有一个自定义的客户算法类型的Model,这个Model中有这种算法类型下的客户群以及Report统计信息,还用了 HashSet 记录了该类型下的 CustomerID集合,为了方便讲述,我把Model简化如下:


   class CustomerAlgorithmModel
   {
       public string DisplayName { get; set; }

       public int CustomerType { get; set; }

       public ReprotModel Report { get; set; }

       public HashSet<int> CustomerIDHash { get; set; }
   }

   class ReprotModel
   {
       public int TotalCustomerCount { get; set; }

       public int TotalTradeCount { get; set; }
   }

那有意思的就来了,我个人是有记日志的癖好,就想着以后不会出现死无对证的情况,然后就理所当然的使用 JsonConvert.SerializeObject, 这一下就出问题了,日志送入到了 ElasticSearch ,然后通过 Kibana 查不出来,为啥呢?看完上面的 Model 我想你也猜到了原因,json体太大了哈,好歹 CustomerIDHash 中也有几十万个撒,这一下全导出成json了,这 size 还能小吗?要不我写段代码看一看。


       static void Main(string[] args)
       {
           var algorithModel = new CustomerAlgorithmModel()
           {
               CustomerType = 1,
               DisplayName = "

标签:set,get,int,遇到,肤浅,JsonConvert,Model,public
来源: https://blog.51cto.com/15057829/2636046

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有