博客
关于我
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 replace first,MySQL中处理各种重复的一些方法
查看>>
MySQL replace函数替换字符串语句的用法(mysql字符串替换)
查看>>
Mysql Row_Format 参数讲解
查看>>
mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
查看>>
MySQL Server 5.5安装记录
查看>>
mysql slave 停了_slave 停止。求解决方法
查看>>
MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
查看>>
mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
查看>>
mysql Timestamp时间隔了8小时
查看>>
Mysql tinyint(1)与tinyint(4)的区别
查看>>
mysql union orderby 无效
查看>>
mysql where中如何判断不为空
查看>>
mysql workbench6.3.5_MySQL Workbench
查看>>
MySQL Workbench安装教程以及菜单汉化
查看>>
MySQL Xtrabackup 安装、备份、恢复
查看>>
mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
查看>>
MySQL _ MySQL常用操作
查看>>
MySQL – 导出数据成csv
查看>>
MySQL —— 在CentOS9下安装MySQL
查看>>
mysql 不区分大小写
查看>>