博客
关于我
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/

你可能感兴趣的文章
mysql8.0新特性-自增变量的持久化
查看>>
Mysql8.0注意url变更写法
查看>>
Mysql8.0的特性
查看>>
MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
查看>>
MySQL8修改密码的方法
查看>>
Mysql8在Centos上安装后忘记root密码如何重新设置
查看>>
Mysql8在Windows上离线安装时忘记root密码
查看>>
MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
查看>>
mysql8的安装与卸载
查看>>
MySQL8,体验不一样的安装方式!
查看>>
MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
查看>>
Mysql: 对换(替换)两条记录的同一个字段值
查看>>
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>
MYSQL:基础——3N范式的表结构设计
查看>>
MYSQL:基础——触发器
查看>>
Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
查看>>
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 参数--lock-tables浅析
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump 导出数据库中每张表的前n条
查看>>