C#基础|对象属性Property基础使用,业务特性

哈喽,你好,我是雷工。

探究OOP中属性的奥秘

认识类的属性(Property)

01 属性的使用

作用:在面向对象(OOP)中主要用来封装数据。

要求:一般采用Pascal命名法(首字母要大写),数据类型和字段要一致,使用public修饰。

02 属性的定义

C#2.0时代标准属性的基本形式:

csharp 复制代码
private int courseld;//返回四有字段的值
public int Courseld
{
    get{return courseld;}//返回四有字段的值
    set{courseld=value;}//通过value给私有字段赋值
}

C#3.0时代,对标准属性做了简化(以后,标准属性,都可以按下方形式):

csharp 复制代码
public int Courseld{get;set;}

C#4.0时代,增加属性表达式(但不常用)

csharp 复制代码
private int unitPrice=4000;
public int UnitPrice{get=>unitPrice;set=>unitPrice=value;}

//C#4.0时代以后,可以直接赋值

public string Type{get;set;}="雷工笔记";

private DateTime FirstDate{get;set;}//首发时间

03 对象属性Property业务特性

在属性get和set方法中添加业务逻辑

代码示例:

csharp 复制代码
private int courseld=0;
public int Courseld
{
    get{return courseld;}
    set
    {
        if(value<0)
            courseld=0;
        else
            courseld=value;
    }
}

在get和set方法中可以添加任何我们需要的业务逻辑,从而有效避免非法数据。

04 属性样例

样例代码:

添加个Course1类,代码如下:

csharp 复制代码
 //C#2.0时代标准属性;
        private int courseId;
        public int CourseId
        {
            get { return courseId; }
            set 
            {
                if (value < 0)
                    courseId = 100;
                else
                    courseId = value;
            }
        }
        //C#3.0时代对标准属性做了简化(以后,标准属性,都可以按下方写)
        public string CourseName { get; set; }
        //C#4.0时代,增加属性表达式
        public int UnitPrice { get; set; } = 189;
        public string ShowCourseInfo()
        {
            return $"账号名称:{CourseName},账号编号:{CourseId},原创数量:{UnitPrice}";
        }
      
    }
    class TestClass1
    {
        public void Dowork1()
        {
            Course1 course = new Course1();
            course.CourseId = -100;
            course.CourseName = "雷工笔记";
            string info = course.ShowCourseInfo();
            Console.WriteLine(info);
        }
    }

Program.cs中代码为:

csharp 复制代码
 static void Main(string[] args)
        {
            TestClass1 testClass1 = new TestClass1();
            testClass1.Dowork1();
            Console.ReadLine();
        }

代码运行结果为:

05 后记

日拱一卒,每天学习一点点,不断更新自己的知识结构,只要学了就是积累,就能更好地应对未来未知的挑战。

相关推荐
daidaidaiyu6 小时前
一文学习 工作流开发 BPMN、 Flowable
java
l1t6 小时前
DeepSeek总结的 pg_regresql插件:真正可移植的 PostgreSQL 统计信息
数据库·postgresql
oradh6 小时前
Oracle 11.2.0.1版本升级至11.2.0.4_单机环境
数据库·oracle·oracle11g·oracle升级
l1t6 小时前
用docker安装测试crate数据库
数据库·docker·容器·cratedb
anzhxu6 小时前
QT数据库(三):QSqlQuery使用
数据库·qt·oracle
身如柳絮随风扬6 小时前
MySQL核心知识
数据库·mysql
德彪稳坐倒骑驴7 小时前
Oracle 11g安装
数据库·oracle
SuniaWang7 小时前
《Spring AI + 大模型全栈实战》学习手册系列 · 专题六:《Vue3 前端开发实战:打造企业级 RAG 问答界面》
java·前端·人工智能·spring boot·后端·spring·架构
韩立学长7 小时前
Springboot校园跑腿业务系统0b7amk02(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
sheji34167 小时前
【开题答辩全过程】以 基于springboot的扶贫系统为例,包含答辩的问题和答案
java·spring boot·后端