博客
关于我
C#结构体与方法
阅读量:396 次
发布时间:2019-03-05

本文共 1452 字,大约阅读时间需要 4 分钟。

结构体在C#中的应用指南

1. 结构体成员作为方法参数

结构体的成员可以直接作为方法的参数使用,其用法与变量相同。在C#中,结构体的成员可以作为值参数、引用参数或输出参数传递给方法。

例子说明
static double distance(int a, int b); // 方法定义struct POINT // 结构体定义{    public int x;    public int y;}static void Main(){    POINT p; // 结构体变量声明    p.x = 1; // 成员赋值    p.y = 2; // 成员赋值    double d = distance(p.x, p.y); // 结构体成员作为方法参数调用}
说明
  • 结构体成员可以直接作为方法的参数使用,语法与传递常规变量相同。
  • 当结构体成员作为引用参数或输出参数时,方法调用方式也与其他数据类型一致。

2. 结构体作为方法参数

结构体可以作为方法的值参数、引用参数或输出参数。在C#中,结构体作为方法参数的使用遵循以下规则:

1. 结构体作为值参数
  • 当结构体作为值参数传递时,方法会对传递的结构体进行复制。因此,方法内部的修改不会影响原结构体。
  • 传递结构体作为值参数时需要考虑内存占用问题。
2. 结构体作为引用参数
  • 当结构体作为引用参数传递时,可以直接在方法中修改结构体的成员不会导致原结构体的值改变。
  • 使用ref关键字来表示引用参数。
3. 结构体作为输出参数
  • 结构体作为输出参数时,方法可以修改传递的结构体,其修改会反映到原结构体。
  • 使用out关键字来表示输出参数。
示例
struct POINT{    public int x;    public int y;}static void Test(POINT a, ref POINT b, out POINT c){    a = b;    b.x++;    b.y++;    c = b;}static void Main(){    POINT p1, p2, p3;    p1.x = 1;    p1.y = 1;    p2.x = 2;    p2.y = 2;    Test(p1, ref p2, out p3);        Console.WriteLine("p1 ({0},{1})", p1.x, p1.y); // 输出p1(1,1)    Console.WriteLine("p2 ({0},{1})", p2.x, p2.y); // 输出p2(3,3)    Console.WriteLine("p3 ({0},{1})", p3.x, p3.y); // 输出p3(3,3)}
说明
  • 结构体作为值参数、引用参数或输出参数时,方法的定义和调用方式与其他数据类型一致。
  • 传递结构体作为值参数时需要考虑内存的使用成本。

3. 结构体作为方法返回值

结构体除了可以作为方法的参数之外,还可以作为方法的返回值。在C#中,结构体可以作为方法的返回类型。

示例
static STUSCORE Translate(STUSCORE A){    // 方法定义}STUSCORE SINFO; // 结构体变量SINFO = Translate(SINFO); // 方法调用
说明
  • 结构体可以作为方法的返回值,其定义和调用方式与其他数据类型一致。
  • 结构体作为返回值时,其成员可以被方法修改。

转载地址:http://ntrwz.baihongyu.com/

你可能感兴趣的文章
Pandas模块,我觉得掌握这些就够用了!
查看>>
Pandas玩转文本处理!
查看>>
SpringBoot 整合 Mybatis Plus 实现基本CRUD功能
查看>>
pandas的to_sql方法中使用if_exists=‘replace‘
查看>>
Springboot ppt转pdf——aspose方式
查看>>
pandas读取csv编码utf-8报错
查看>>
pandas读取parquet报错
查看>>
pandas读取数据用来深度学习
查看>>
pandas读取文件时,不去掉前面的0 保留原有的数据格式
查看>>
Pandas进阶大神!从0到100你只差这篇文章!
查看>>
spring5-介绍Spring框架
查看>>
pandas,python - 如何在时间序列中选择特定时间
查看>>
Spring 框架之 AOP 原理深度剖析
查看>>
Pandas:如何按列元素的组合分组,以指示基于不同列的值的同现?
查看>>
Pandas:将一列与数据帧的所有其他列进行比较
查看>>
PANDA和GLOB:将文件夹中的所有xlsx文件转换为CSV类型错误:__init__()获得意外的关键字参数‘;xfid‘;
查看>>
panda查找想要找的行合并成一个新pd
查看>>
PANDA:基于多列对数据表的行运行计算,并将输出存储在新列中
查看>>
PandoraFMS 监控软件 SQL注入漏洞复现
查看>>
PandoraFMS 监控软件 任意文件上传漏洞复现
查看>>