ObjectExtensions.cs 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. using Newtonsoft.Json;
  2. using System;
  3. using System.Collections;
  4. using System.Threading.Tasks;
  5. namespace Masuit.Tools
  6. {
  7. public static partial class ObjectExtensions
  8. {
  9. #region Map
  10. /// <summary>
  11. /// 浅克隆
  12. /// </summary>
  13. /// <param name="source">源</param>
  14. /// <typeparam name="TDestination">目标类型</typeparam>
  15. /// <returns>目标类型</returns>
  16. public static TDestination Clone<TDestination>(this object source)
  17. where TDestination : new()
  18. {
  19. TDestination dest = new TDestination();
  20. dest.GetType().GetProperties().ForEach(p =>
  21. {
  22. p.SetValue(dest, source.GetType().GetProperty(p.Name)?.GetValue(source));
  23. });
  24. return dest;
  25. }
  26. /// <summary>
  27. /// 深克隆
  28. /// </summary>
  29. /// <param name="source">源</param>
  30. /// <typeparam name="TDestination">目标类型</typeparam>
  31. /// <returns>目标类型</returns>
  32. public static TDestination DeepClone<TDestination>(this object source)
  33. where TDestination : new()
  34. {
  35. return JsonConvert.DeserializeObject<TDestination>(JsonConvert.SerializeObject(source));
  36. }
  37. /// <summary>
  38. /// 浅克隆(异步)
  39. /// </summary>
  40. /// <param name="source">源</param>
  41. /// <typeparam name="TDestination">目标类型</typeparam>
  42. /// <returns>目标类型</returns>
  43. public static Task<TDestination> CloneAsync<TDestination>(this object source)
  44. where TDestination : new()
  45. {
  46. return Task.Run(() =>
  47. {
  48. return source.Clone<TDestination>();
  49. });
  50. }
  51. /// <summary>
  52. /// 深克隆(异步)
  53. /// </summary>
  54. /// <param name="source">源</param>
  55. /// <typeparam name="TDestination">目标类型</typeparam>
  56. /// <returns>目标类型</returns>
  57. public static async Task<TDestination> DeepCloneAsync<TDestination>(this object source)
  58. where TDestination : new()
  59. {
  60. return await Task.Run(() => JsonConvert.DeserializeObject<TDestination>(JsonConvert.SerializeObject(source)));
  61. }
  62. #endregion Map
  63. #region CheckNull
  64. /// <summary>
  65. /// 检查参数是否为null,为null时抛出异常
  66. /// </summary>
  67. /// <typeparam name="T"></typeparam>
  68. /// <param name="obj"> 要检查的对象</param>
  69. /// <param name="paramName">抛出异常时,显示的参数名</param>
  70. /// <exception cref="ArgumentNullException"><paramref name="obj" /> 为null时抛出</exception>
  71. public static void CheckNullWithException<T>(this T obj, string paramName)
  72. {
  73. if (obj == null) throw new ArgumentNullException(paramName);
  74. }
  75. /// <summary>
  76. /// 检查参数是否为null,为null时抛出异常
  77. /// </summary>
  78. /// <typeparam name="T"></typeparam>
  79. /// <param name="obj"> 要检查的对象</param>
  80. /// <param name="paramName">抛出异常时,显示的参数名</param>
  81. /// <param name="message"> 抛出异常时,显示的错误信息</param>
  82. /// <exception cref="ArgumentNullException"><paramref name="obj" /> 为null时抛出</exception>
  83. public static void CheckNullWithException<T>(this T obj, string paramName, string message)
  84. {
  85. if (obj == null) throw new ArgumentNullException(paramName, message);
  86. }
  87. /// <summary>
  88. /// 检查参数是否为null或emtpy,为null或emtpy时抛出异常
  89. /// </summary>
  90. /// <param name="obj"> 要检查的对象</param>
  91. /// <param name="paramName">抛出异常时,显示的参数名</param>
  92. /// <exception cref="ArgumentNullException"><paramref name="obj" /> 为null或emtpy时抛出</exception>
  93. public static void CheckNullOrEmptyWithException(this IEnumerable obj, string paramName)
  94. {
  95. if (obj.IsNullOrEmpty()) throw new ArgumentNullException(paramName);
  96. }
  97. /// <summary>
  98. /// 检查参数是否为null或emtpy,为null或emtpy时抛出异常
  99. /// </summary>
  100. /// <param name="obj"> 要检查的对象</param>
  101. /// <param name="paramName">抛出异常时,显示的参数名</param>
  102. /// <param name="message"> 抛出异常时,显示的错误信息</param>
  103. /// <exception cref="ArgumentNullException"><paramref name="obj" /> 为null或emtpy时抛出</exception>
  104. public static void CheckNullOrEmptyWithException(this IEnumerable obj, string paramName, string message)
  105. {
  106. if (obj.IsNullOrEmpty()) throw new ArgumentNullException(paramName, message);
  107. }
  108. #endregion CheckNull
  109. /// <summary>
  110. /// 判断是否为null,null或0长度都返回true
  111. /// </summary>
  112. /// <typeparam name="T"></typeparam>
  113. /// <param name="value"></param>
  114. /// <returns></returns>
  115. public static bool IsNullOrEmpty<T>(this T value)
  116. where T : class?
  117. {
  118. #region 1.对象级别
  119. //引用为null
  120. bool isObjectNull = value == null;
  121. if (isObjectNull == true) return true;
  122. //判断是否为集合
  123. IEnumerator? tempEnumerator = (value as IEnumerable)?.GetEnumerator();
  124. if (tempEnumerator == null) return false;//这里出去代表是对象 且 引用不为null.所以为false
  125. #endregion 1.对象级别
  126. #region 2.集合级别
  127. //到这里就代表是集合且引用不为空,判断长度
  128. //MoveNext方法返回tue代表集合中至少有一个数据,返回false就代表0长度
  129. bool isZeroLenth = tempEnumerator.MoveNext() == false;
  130. if (isZeroLenth == true) return true;
  131. return isZeroLenth;
  132. #endregion 2.集合级别
  133. }
  134. /// <summary>
  135. /// 转换成json字符串
  136. /// </summary>
  137. /// <param name="obj"></param>
  138. /// <returns></returns>
  139. public static string ToJsonString(this object obj, JsonSerializerSettings setting = null)
  140. {
  141. if (obj == null) return string.Empty;
  142. if (setting == null)
  143. {
  144. return JsonConvert.SerializeObject(obj);
  145. }
  146. return JsonConvert.SerializeObject(obj, setting);
  147. }
  148. /// <summary>
  149. /// 严格比较两个对象是否是同一对象(判断引用)
  150. /// </summary>
  151. /// <param name="this">自己</param>
  152. /// <param name="o">需要比较的对象</param>
  153. /// <returns>是否同一对象</returns>
  154. public new static bool ReferenceEquals(this object @this, object o)
  155. {
  156. return object.ReferenceEquals(@this, o);
  157. }
  158. }
  159. }