C#入门--字段与属性
C#入门--字段与属性
“字段”,它是包含在类或结构中的对象或值。字段使类和结构可以封装数据。
属性是这样的成员:它们提供灵活的机制来读取、编写或计算私有字段的值。可以像使用公共数据成员一样使用属性,但实际上它们是称为“访问器”的特殊方法。这使得数据在可被轻松访问的同时,仍能提供方法的安全性和灵活性。
public class Program
{
private int _number; //_number为字段 public int Number //Number 为属性
{
get { return _number ;}
set { _number = value ;}
} }
从上面的例子可以明显看出,字段就是变量,而属性就是字段的访问方式(通常字段是private,属性是public),这类似于C++,申明一个private 类型的变量x,通过 GetX()与SetX()函数来对x进行操作。而这里的属性就是将这两个函数合在一起通过set与get关键字对相应的字段进行处理。
属性的出现,极大的简化了我们的编码工作。与C++和Java比较一下,你会发现我们不必为了一个字段而专门写两个函数(虽然这些函数很简单),而且使得代码编的更简洁,更易读,更易改。
当然,属性也可对字段进行一些处理(例如返回字段时判断其是否为空,对字段进行赋值时判断value是否有效等简单或者其它更复杂的操作)。也可以设置属性的访问权限(如只读,只写,可读可写,不可读不可写)。而且现在的C#版本已经支持自动属性,即不必为属性指定字段,如 public int Number {get;set;} 这样就可以申明一个属性,编译器会为其自动分配一个字段(编译时),总之通过属性,可以极大的简化我们的操作,使得代码的可读性更高,可维护性更高。下面让我们通过一些例子来深入理解属性的作用。
public class Program
{
private static string _number; public static string Number //非自动属性,可读可写
{
get
{
if (_number == null)
return Convert.ToString(new NullReferenceException());
return _number; }
set
{
string temp = "";
foreach (var ch in value)
{
if (char.IsDigit(ch))
temp += ch;
}
_number = temp;
}
} public static string ReadWrite { get; set; } //自动属性,可读可写 public static string ReadOnly { get { return ""; }} //自动属性,只读 private static string _writeOnly; public static string WriteOnly { set { _writeOnly = value; } } //非自动属性,只写 public static void Main(string[] args)
{
Number = "23kljk3j423903kj43kj432kj";
ReadWrite = "ReadWrite";
//ReadOnly = "ReadOnly"; //报错,此属性只读
WriteOnly = "WriteOnly"; Console.WriteLine(Number);
Console.WriteLine(ReadWrite);
Console.WriteLine(ReadOnly);
//Console.WriteLine(WriteOnly); //报错,此属性只写
Console.ReadKey();
}
} //Results:
//23342390343432
//ReadWrite
//
C#入门--字段与属性的更多相关文章
- C#——字段和属性
//我的C#是跟着猛哥(刘铁猛)(算是我的正式老师)<C#语言入门详解>学习的,微信上猛哥也给我讲解了一些不懂得地方,对于我来说简直是一笔巨额财富,难得良师! 在刚开始学习属性这一节时,开 ...
- [.net 面向对象编程基础] (10) 类的成员(字段、属性、方法)
[.net 面向对象编程基础] (10) 类的成员(字段.属性.方法) 前面定义的Person的类,里面的成员包括:字段.属性.方法.事件等,此外,前面说的嵌套类也是类的成员. a.类的成员为分:静态 ...
- .NET面试题解析(05)-常量、字段、属性、特性与委托
系列文章目录地址: .NET面试题解析(00)-开篇来谈谈面试 & 系列文章索引 弱小和无知不是生存的障碍,傲慢才是!——<三体> 常见面试题目: 1. const和reado ...
- C#.NET如何不序列化字段、属性
当我们使用公开属性以及公开字段时,都可以顺利的被序列化, 01.[Serializable] 02.public class MyClass 03.{ 04. public int ID; 05 ...
- mysql字段额外属性,除去字段类型外的其他属性
如果你不想字段为 NULL 可以设置字段的属性为 NOT NULL, 在操作数据库时如果输入该字段的数据为NULL ,就会报错. AUTO_INCREMENT定义列为自增的属性,一般用于主键,数值会自 ...
- 不允许修改SQLserver2008r2表中字段的属性问题
SQLserver2008r2修改表中字段的属性时弹出 点击工具->选项,取消阻止保存要求重新创建表的更改
- C#:字段与属性
MSDN中是这么介绍字段和属性的: A field is a variable of any type that is declared directly in a class or struct. ...
- 1.4.2 solr字段类型--(1.4.2.1)字段类型定义和字段类型属性
1.4.2 solr字段类型 (1.4.2.1) 字段类型定义和字段类型属性. (1.4.2.2) solr附带的字段类型 (1.4.2.3) 使用货币和汇率 (1.4.2.4) 使用Dates(日期 ...
- C# 字段、属性、成员变量
引言: C#与java,C++中的这些基本概念略有不同. 由于easy混淆,所以这里总结下差别. 希望能对刚開始学习的人有帮助! 一.定义与作用 1.字段(field):是C#类级别定义的,和方法同一 ...
随机推荐
- 洛谷 P3806 【模板】点分治1
P3806 [模板]点分治1 题目背景 感谢hzwer的点分治互测. 题目描述 给定一棵有n个点的树 询问树上距离为k的点对是否存在. 输入输出格式 输入格式: n,m 接下来n-1条边a,b,c描述 ...
- C语言数据结构-单链表的实现-初始化、销毁、长度、查找、前驱、后继、插入、删除、显示操作
1.数据结构-单链表的实现-C语言 typedef struct LNode { int data; struct LNode* next; } LNode,*LinkList; //这两者等价.Li ...
- maven 项目 配置docker镜像生成(dockerfile-maven-plugin)
插件地址:https://github.com/spotify/dockerfile-maven 依github上备注,只要在项目根上录上编写dockerfile,然后引用插件即可 编写Dockerf ...
- 【Leetcode】Largest Rectangle in Histogram
Given n non-negative integers representing the histogram's bar height where the width of each bar is ...
- Charles使用方法简介
Charles是一个web代理器,用来记录和展示你所发出和接收到的所有数据. 主要特性: SSL Proxying——易清晰地文本展示SSL请求和响应Bandwidth Throttling是用来模拟 ...
- Kibana6.x.x源码开发——执行 yarn start --no-base-path 启动命令后报错
错误信息如下: Unhandled rejection Error: Request Timeout after 30000ms at /home/kibana_git/kibana6.2.2/nod ...
- SQL语句 ANSI_NULLS 值(ON|OFF)的含义
官方说明: 1.当 SET ANSI_NULLS 为 ON 时,即使 column_name 中包含空值,使用 WHERE column_name = NULL 的 SELECT 语句仍返回零行. 即 ...
- python3 continue和break 区别
for i in range(10): if i==5: continue #跳出当次循环 if i==8: break #跳出整个for循环 print(i)
- CPU的CAS操作
https://blog.csdn.net/qq_35492857/article/details/78471032 https://www.cnblogs.com/gdjdsjh/p/5076815 ...
- 23-----BBS论坛
BBS论坛(二十三) 23.添加板块 (1)apps/models class BoardModel(db.Model): __tablename__ = 'board' id = db.Column ...