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

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

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

结构体的成员可以直接作为方法的参数使用,其用法与变量 相同。

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.结构体作为方法参数

结构体可以作为方法的值参数、引用形参和输出形参。

当结构体作为方法的值参数、引用形参或输出形参时,方法 的定义和调用语法与其它数据类型作为方法的形参时基本一致

结构体作为方法的值参数、引用形参和输出 形参时方法的定义和调用形式。

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.结构体作为方法返回值

结构体除了可以作为方法的参数之外,还可以作为方法的返 回值。

此时方法的定义和调用语法与其它数据类型作为方法的返回 类型时基本一致。

static STUSCORE Translate(STUSCORE A){……}//方法定义 STUSCORE SINFO;//定义结构体变量 SINFO = Translate(SINFO);//方法调用

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

你可能感兴趣的文章
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>
mysql中出现Unit mysql.service could not be found 的解决方法
查看>>
mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
查看>>
Mysql中各类锁的机制图文详细解析(全)
查看>>
MySQL中地理位置数据扩展geometry的使用心得
查看>>
Mysql中存储引擎简介、修改、查询、选择
查看>>
Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>
Mysql中怎样使用update更新某列的数据减去指定值
查看>>
Mysql中怎样设置指定ip远程访问连接
查看>>
mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
查看>>
Mysql中文乱码问题完美解决方案
查看>>
mysql中的 +号 和 CONCAT(str1,str2,...)
查看>>
Mysql中的 IFNULL 函数的详解
查看>>