首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么我要避免在C#中使用Properties?

在C#中,Properties是一种特殊的成员变量,它们提供了一种简洁的语法来访问和设置类的成员变量。它们通常用于将类的内部实现与外部使用者隔离开来,以提高代码的可读性和可维护性。

然而,在某些情况下,使用Properties可能会导致一些问题,例如:

  1. 性能问题:Properties是通过getter和setter方法实现的,这意味着它们可能比直接访问成员变量要慢。在性能敏感的应用程序中,这可能会导致问题。
  2. 逻辑问题:Properties可能会导致逻辑问题,因为它们可能会在访问或设置成员变量时引入错误。例如,如果Property的setter方法没有正确地更新相关的成员变量,则可能会导致逻辑错误。
  3. 可维护性问题:Properties可能会导致可维护性问题,因为它们可能会使代码更难以理解和维护。例如,如果Property的getter或setter方法引入了错误,则可能会导致难以发现的错误。

因此,在某些情况下,避免使用Properties可能是一个好主意。相反,可以直接访问和设置成员变量,以提高代码的性能和可维护性。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

在 Andorid 中为什么要避免「内存抖动」?

内存抖动是指内存频繁的分配和回收,占用内存忽高忽低,内存占用图形上呈现锯齿状 在 Android 开发过程中,你一定听说过「内存抖动」这个词,别人肯定也告诫过你要避免内存抖动,但是为什么呢?...但是其实初步想,为什么要避免内存抖动呢?频繁创建对象,被 Java 虚拟机的回收机制自动回收了,这不是挺好的吗?开发者为什么还需要关心这个问题呢?...下面讲一下原因 1.频繁 GC 会导致卡顿 在传统的 GC 模式下,当虚拟机触发一次 GC,会先暂停所有线程。当频繁的 GC 这样 Android 主线程会被频繁的暂停,势必会引发卡顿。...2.GC 会导致内存碎片化 在传统的 GC 模式下,回收一次后,会导致内存碎片化,即导致很多内存块不连续,导致寻址变慢拖慢程序。...但是也不能完全避免上述问题。所以开发者一定还是要考虑「内存抖动」的情况,优化自己的代码。

1.1K10
  • 为什么我避免使用asyncawait?

    例如,一个模式可能是干净的、简洁的或广泛使用的,但如果它导致了容易出错的代码,它就是一个我可能会拒绝的模式。这些模式是双刃剑,很容易搬起石头砸自己的脚。首先,它是建立在一个谎言之上的。...在async/await版本中并不是没有提示。关键字async和await应该给我们同样的直觉,就像第三个版本中的then一样。但我敢打赌,对许多工程师来说,它并没有。为什么没有呢?...为了处理同步代码中可能出现的错误,我们通常使用try/catch。...我觉得它们是一种精神上的负担。每当有try/catch时,我们现在不仅要担心函数返回什么,还要担心它抛出什么。我们不仅有分支逻辑,这增加了复杂性,而且还必须担心同时处理两种不同的范式。...但后来我真的看到了一些promise的代码,它们看起来惊人地像回调地狱。我很困惑,为什么有人会这样使用promise。最终,我得出结论,有些人对promise的工作原理有一个非常基本的误解。

    2K42

    Swift: 为什么要避免在结构体中使用闭包?

    好吧,如果这使我们工作变得容易,那为什么我要避免在Swift结构中使用闭包呢? 原因是:内存泄漏和意外行为。 结构内存泄漏,可能吗? 结构是值类型,并且不可能发生内存泄漏。那句话是真的吗?...引用类型(Reference type) 引用类型在初始化时保留对数据的引用(即指针)。只要将变量分配给现有引用类型,该引用就在变量之间共享。引用类型的分配在堆中完成。...在使用类(Class)的情况下,我们可以使用[weak self]打破循环引用。...由于闭包及其环境无法完全复制,属性speed的值被复制了,但是myNewCar的属性increaseSpeed在捕获的环境变量中引用了myCar的increaseSpeed和myCar的speed。...这就是为什么Swift结构中的闭包很危险的原因。 直接的解决方案是,避免在值类型中使用闭包。如果要使用它们,则应格外小心,否则可能会导致意外结果。

    1.8K20

    PyTorch中的In-place操作是什么?为什么要避免使用这种操作?

    在神经网络中使用in-place操作可能有助于避免上述方法的缺点,同时节省一些GPU内存。但是,由于几个原因,不建议使用in-place操作。...在这篇文章中,内容包括: 描述什么是in-place操作,并演示他们如何可能有助于节省GPU内存。 告诉我们为什么要避免in-place操作或非常小心地使用它们。...这就是为什么它们可以帮助在操作高维数据时减少内存使用。 我想演示in-place操作如何帮助消耗更少的GPU内存。...然而,我们在使用现场操作时应该非常谨慎,并且要反复检查。在接下来的部分,我将告诉你为什么。...要小心使用in-place操作的另一个原因是,它们的实现非常棘手。这就是为什么我建议使用PyTorch标准的in-place操作(如上面的就地ReLU),而不是手动实现。

    1.4K30

    为什么我要推荐你使用Core WebApi?

    作为分布式实施的基础,跨进程通信的技术也是五花八门,为什么Core WebApi越来越火,被众多大牛们一直推荐?小编这就为你一一解答!...03 远程调用模式 远程调用模式,包括FX下的RPC和.NetCore下的gRPC,有使用限制和优异的性能。大部分的开发者和项目选型中,第二类是最为广泛的。下文对gRPC和WebApi有细致比对。...Core WebApi的变化 WebApi刚出来时,大家都非常兴奋,终于有原生的RESTful API了,但实践中却发现太多槽点,跟MVC框架同项目不同管道,鉴权授权参数绑定也很不友好,让学习者苦不堪言...然而,这个在Core WebApi得到了转变,和Asp.NetCore管道的统一,让大家开发和学习成本都降低了,再加上跨平台的优势,和全新中间件模式加成,毫不客气地说,CoreWebApi已经成为当下服务的首选...,REST的通用性更强,像典型的前后端分离架构,当下各公众平台对外数据提供,都是选择的REST接口,包括在微服务架构实施上,Core WebApi使用还是更广泛一些。

    1.3K20

    在java中String类为什么要设计成final?

    String为什么被定义为final在面试中经常被问到。 首先,先得清楚 final 这个关键字。 final的出现就是为了为了不想改变,而不想改变的理由有两点:设计(安全)或者效率。...所有 *在java程序中的字符串,如“ABC”,是 *实现为这个类的实例。 * *字符串是常量,它们的值在它们之后不能更改 *创建。支持可变字符串字符串缓冲区。...//编译器报错,final不可变 但如果我直接对数组元素动手 final int[] value={1,2,3}; value[2]=100; //这时候数组里已经是{1,2,100} 当String...为final类型时: package test; public class 为什么String要设计成不可变类 { public static void main(String[] args...String要设计成不可变类{ public static void main(String[] args) { StringBuffer a, b, c;

    93330

    在java中String类为什么要设计成final?

    String不可变很简单,如下图,给一个已有字符串"abcd"第二次赋值成"abcedl",不是在原内存地址上修改数据,而是重新指向一个新对象,新地址。 ? 2. String为什么不可变?...但如果我直接对数组元素动手,分分钟搞定。...示例1 package _12_01字符串;public class 为什么String要设计成不可变类你 { public static void main(String[] args) { String...如果String是可变的,就可能如下例,我们使用StringBuffer来模拟String是可变的 package _12_01字符串;public class 为什么String要设计成不可变类2 {...这样在大量使用字符串的情况下,可以节省内存空间,提高效率。但之所以能实现这个特性,String的不可变性是最基本的一个必要条件。要是内存里字符串内容能改来改去,这么做就完全没有意义了。

    1.1K31

    在设计原则中,为什么反复强调组合要优于继承?

    面向对象编程中,有一条非常经典的设计原则,那就是:组合优于继承,多用组合少用继承。同样地,在《阿里巴巴Java开发手册》中有一条规定:谨慎使用继承的方式进行扩展,优先使用组合的方式实现。 ?...为什么不推荐使用继承   每个人在刚刚学习面向对象编程时都会觉得:继承可以实现类的复用。所以,很多开发人员在需要复用一些代码的时候会很自然的使用类的继承的方式,因为书上就是这么写的。...我们知道,大部分鸟都会飞,那我们可不可以在 AbstractBird抽象类中,定义一个fly()方法呢?   答案是否定的。尽管大部分鸟都会飞,但也有特例,比如鸵鸟就不会飞。...Java8的接口默认方法 在Java8中,我们可以在接口中写默认实现方法。...所谓多用与少用,实际指的是要弄清楚在具体的场景下需要哪种。软件开发原则这类问题,不宜死扣字眼。其实在《Thinking in Java》里有提到,当你用继承的时候,肯定是想要使用多态的特性。

    2.6K10

    为什么我在容器中不能 kill 1 号进程?

    使用容器的理想境界是一个容器只启动一个进程,现实中有时是做不到的。比如容器除了主进程外还启动辅助进程,做监控或者logs;再比如程序本身就是多进程的。...而容器中也是由init进程直接或间接创建了Namespace中的其他进程。 linux信号 而为什么不能在容器中kill 1号进程呢?进程在收到信号后,就会去做相应的处理。...为什么在容器中不能kill 1号进程? 对于不同的程序,结果是不同的。把c程序作为1号进程就无法在容器中杀死,而go程序作为1号进程却可以。...在 Linux 中,kill 命令调用了 kill() 系统调用(内核的调用接口)而进入到了内核函数 sys_kill()。...0000000000004000 [root@043f4f717cb5 /]# kill 1 # docker ps CONTAINER ID IMAGE COMMAND CREATED 重点总结 “为什么我在容器中不能

    26510

    在设计原则中,为什么反复强调组合要优于继承?

    同样地,在《阿里巴巴Java开发手册》中有一条规定:谨慎使用继承的方式进行扩展,优先使用组合的方式实现。为什么不推荐使用继承  每个人在刚刚学习面向对象编程时都会觉得:继承可以实现类的复用。...我们知道,大部分鸟都会飞,那我们可不可以在 AbstractBird抽象类中,定义一个fly()方法呢?  答案是否定的。尽管大部分鸟都会飞,但也有特例,比如鸵鸟就不会飞。...Java8的接口默认方法在Java8中,我们可以在接口中写默认实现方法。...所谓多用与少用,实际指的是要弄清楚在具体的场景下需要哪种。软件开发原则这类问题,不宜死扣字眼。其实在《Thinking in Java》里有提到,当你用继承的时候,肯定是想要使用多态的特性。  ...其实我们很难真正使用好继承,根本原因在于,自然界中,代际之间是存在变异的,物种之间也是,而且这种变化是无法做规律化描述的,既伴随着某些功能的增加,也伴随着某些功能的弱化,甚至还有某些功能的改变。

    1.1K20

    为什么我在 Linux 上使用 exa 而不是 ls?

    我们生活在一个繁忙的世界里,当我们需要查找文件和数据时,使用 ls 命令可以节省时间和精力。但如果不经过大量调整,默认的 ls 输出并不十分舒心。...当有一个 exa 替代方案时,为什么要花时间眯着眼睛看黑白文字呢? exa 是一个常规 ls 命令的现代替代品,它让生活变得更轻松。这个工具是用 Rust 编写的,该语言以并行性和安全性而闻名。...安装 exa 要安装 exa,请运行: $ dnf install exa 探索 exa 的功能 exa 改进了 ls 文件列表,它提供了更多的功能和更好的默认值。它使用颜色来区分文件类型和元数据。...image.png 我相信 `exa 是最简单、最容易适应的工具之一。它帮助我跟踪了很多 Git 和 Maven 文件。...它的颜色编码让我更容易在多个子目录中进行搜索,它还能帮助我了解当前的 xattrs。

    2K40

    在Java中为什么不推荐使用Float

    在Java中为什么不推荐使用Float 在Java中,我们可以使用两种数据类型来表示浮点数:Float和Double。...使用Float类型可能会导致精度丢失。 类型转换:在Java中,浮点数常量默认为Double类型。如果要在计算中使用Float类型,需要进行类型转换,这增加了代码的复杂性和易错性。...下面是几个在工作中常见的案例,说明为什么在Java中不推荐使用Float类型: 1. 金融计算 在金融领域,精确的计算是至关重要的。例如,计算利息、股票价格或货币兑换时,需要高精度的计算。...地理位置计算 在地理位置计算中,需要进行浮点数运算来计算距离、坐标等。使用Float类型可能会导致精度丢失,从而产生不准确的结果。因此,推荐使用Double类型来进行地理位置计算,以获得更高的精度。...科学计算 在科学计算中,需要进行高精度的浮点数运算,以获得准确的结果。使用Float类型可能会导致精度丢失,从而影响实验结果或计算精度。

    7910

    为什么在静态方法中不能使用this

    看到这个标题的读者,在你们的心里多多少少都有自己的答案,下面说一下我的答案....在JVM的运行时数据区中有个虚拟机栈(或Java栈),在它的里面是由栈帧'叠加'而成.栈帧由局部变量表,操作数栈,动态连接,方法返回地址等组成. 那么我们就从局部变量表角度解答下这个问题....我这里安装了jclasslib Bytecode viewer插件,方便查看字节码....详细看下两个方法的局部变量表 query方法的局部变量表,如下 shadow方法的局部变量表,如下 我们发现,非静态方法shadow的局部变量表中有this,而在静态方法query的局部变量表中没有...在普通方法中,在它的局部变量表中的第一个槽存放了this, 而静态方法的局部变量表中没有存放this.

    1.9K30
    领券