属性和字段之间的语义差异及其含义

如何解决属性和字段之间的语义差异及其含义

| 取
private string Property {get; set;}
private string field
。 请注意,两者都是私有的(因此它们不会在此类之外公开),并且该属性未使用额外的验证。 至于语义,它们有不同的含义吗?从某种意义上说,当像这样使用时它们可以互换吗? 当涉及到诸如(micro?)性能之类的含义时,是否创建字段而不是属性无关紧要,即让编译器为您处理后备字段。     

解决方法

        当它们是私有的时,我知道的唯一区别是该属性不适用于
out
ref
参数。 但是,大多数情况下,私有财产并没有带来任何优势(相对于田间而言),那为什么还要麻烦呢? 可能会有(微)性能成本。我会担心额外的混乱。     ,         属性是关于字段的数据隐藏 私有财产意义不大,因为有权访问该财产的人也将有权访问该字段 对于自动属性与后备字段没有性能影响,因为编译器吐出了后备字段,但是可能会有序列化/反序列化警告。 更新 性能影响: 使用属性(自动或有后备字段)与字段相比,性能稍有下降,因为属性是一种方法,需要调用CLR 4。 但是正如我所说,使用属性没有太多意义,而且我相信字段的可读性更高,通常可以通过命名约定立即看到(以下划线或驼峰开头)。     ,        您无法引用属性,但是可以引用成员。因此,如果使用成员,则以后无论出于何种原因(例如添加臭名昭著的验证),都可能无法将它们切换到属性。     ,        创建私有自动属性没有用,我可以看到。如果不是自动的,则可以将其用作某种内部“事件处理程序”以使对象状态保持最新:每次字段更改时(通过setter)在代码中的任何位置执行一些操作。 性能?我认为即使在微观层面上也不会存在问题。     ,属性是功能。 字段是“至少具有类别可见性的变量”。 因此,如果您拥有私有财产与私有领域: 与性能点的区别: 如果您使用优化并且没有跟踪,则没有区别(属性被视为内联)。 语义上的差异: 1)正式没有区别。 2)更深入地讲,存在区别。由于属性是函数,因此您可以从getter和setter获取委托。并且可以将委托用作...委托,就像将此委托与其他委托放到列表中一样(通过属性getter或setter方法创建委托) 从设计角度看的区别: 但是属性是看起来像变量的函数。为什么可能需要看起来像变量的函数? 假设您有Hand类,并且此手具有可变的FingersNumber。
 class Hand
 {
     public int fingersNumber;
 }
那么您可能会有很多类似的代码
 if(he is BadPerson) leftHand.fingersNumber--
 if(doctor.Heal()) leftHand.fingersNumber++
但是在某些时候,您可能需要向Hand添加一些其他变量。可以说它是ringsNumber。而且您知道,每个手指的指环不能超过10个。
 class Hand
 {
     public int fingersNumber;
     public int ringsNumber;

 }
现在,你不能只是做
 leftHand.fingersNumber-- 
因为您必须控制fingerNumber依赖项上的ringsNumber。 因此,您必须创建一些函数来检查这种依赖性。另外,您还必须向用户隐藏fingerNumber和eringNumber,以便他们不进行检查就无法更改此字段。
 class Hand
 {
     private int fingersNumber;
     private int ringsNumber; 
     public int GetFingersNumber(){...check logic...}
     public void SetFingersNumber(int value){...check logic...}
     public int GetRingsNumber(){...check logic...}
     public void SetRingsNumber(int value){...check logic...}
 }
并将此功能用作
 if(he is BadPerson) leftHand.SetFingersNumber(leftHand.GetFingersNumber()-1)
这里的问题是旧代码leftHand.fingersNumber--现在无法正常工作。从一开始,您就不会知道将来会添加戒指。为了解决这些问题,将字段设置为私有并使用Set和Get函数来获取和更改变量成为一种范例,并确保将来可以在其中添加任何逻辑并且代码可以工作! Setter和Getters是C ++,Java和许多语言的最新情况。 但是C#创建者走得更远,并装饰了诸如“属性”之类的吸气器和设置器功能。
 class Hand
 {
     private int fingersNumber; 
     public int FingersNumber
     {
          get{return fingersNumber;}
          set{fingersNumber=value;}
     }
     ...     
  }
  ...
  if(he is BadPerson) leftHand.FingersNumber--;
但是大多数情况下,人们会创建这种简单的属性,而您看到的示例是5行例程代码。因此,在某些版本的C#中,添加了自动属性以简化程序员的工作。所以您的课程可能看起来像
 class Hand
 {
     public int FingersNumber{get;set;}
 }
但您随时可以扩展此get set行为:
  class Hand
 {
     private int fingersNumber; 
     public int FingersNumber
     {
          get{...check logic...}
          set{...check logic...}
     }

     ...     
  }
而且它不会违反任何代码。喜欢
  if(he is BadPerson) leftHand.FingersNumber--;
多数民众赞成在什么是属性,为什么要使用它们以及与字段有什么区别。 同样,正如我之前所说,如果使用优化,则简单属性和自动属性的性能与变量相同。 Se反汇编或只是谷歌关于它。     

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 <select id="xxx"> SELECT di.id, di.name, di.work_type, di.updated... <where> <if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 <property name="dynamic.classpath" value="tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams['font.sans-serif'] = ['SimHei'] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -> systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping("/hires") public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate<String
使用vite构建项目报错 C:\Users\ychen\work>npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-