博客
关于我
C# 多个class之间共享变量
阅读量:789 次
发布时间:2019-03-24

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

C#中的变量管理与C++有所区别,因为它不支持全局变量的概念。因此,所有变量都需要放置在某个类中。为了保证类A和类B能够互相访问和修改变量,可以采取以下两种方法来实现数据传递和变量更新。

方法一:通过静态变量实现变量共享

为了实现类A和类B之间的变量共享,可以定义一个全局类(Global Variable),将其设为公共类,供所有类引用。这样,类A和类B都可以访问并修改这些变量。具体实现方式如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace P
{
static class GlobalVariable
{
public static bool CornerInfoFlag = true;
public static bool RTArrayInfoFlag = true;
public static bool RTLineInfoFlag = true;
public static bool RTGuaiJiaoInfoFlag = true;
public static bool SideArrayInfoFlag = true;
public static bool SideLineInfoFlag = true;
}
}

方法二:通过类A的静态变量进行数据传递

另一种方法是,在类A中定义静态变量,并提供public方法供类B在修改数据后调用。类B在完成计算后,通过调用类A的方法,将最新数据写入类A的静态变量中。这样可以避免全局变量的多处修改问题。示例代码如下:

public class A
{
private static List
Dot = new List
();
public void WriteData(List
threadDot)
{
Dot.InsertRange(0, threadDot);
}
}
public class B : Thread
{
byte[] data;
private List
threadDot = new List
();
private Vector3 xyz;
private readonly A mainThreadData;
public B(byte[] buffer)
{
data = buffer;
mainThreadData = new A();
}
public void ThreadProc()
{
xyz.x = BitConverter.ToSingle(data, 0);
xyz.y = BitConverter.ToSingle(data, 4);
xyz.z = BitConverter.ToSingle(data, 8);
threadDot.Add(xyz);
mainThreadData.WriteData(threadDot);
}
}

这种方法通过类A的静态变量实现了变量的传递和更新,保证了数据的一致性和安全性。

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

你可能感兴趣的文章
Mysql学习总结(66)——设置MYSQL数据库编码为UTF-8
查看>>
Mysql学习总结(67)——MYSQL慢查询日志
查看>>
Mysql学习总结(68)——MYSQL统计每天、每周、每月、每年数据 SQL 总结
查看>>
Mysql学习总结(69)——Mysql EXPLAIN 命令使用总结
查看>>
Mysql学习总结(6)——MySql之ALTER命令用法详细解读
查看>>
Mysql学习总结(70)——MySQL 优化实施方案
查看>>
Mysql学习总结(71)——MySQL 重复记录查询与删除总结
查看>>
Mysql学习总结(71)——数据库介绍(MySQL安装 体系结构、基本管理)再回顾
查看>>
Mysql学习总结(72)——MySQL 开发者开发,设计规范再总结
查看>>
Mysql学习总结(73)——MySQL 查询A表存在B表不存在的数据SQL总结
查看>>
Mysql学习总结(74)——慢SQL!压垮团队的最后一根稻草!
查看>>
Mysql学习总结(75)——并发量大、数据量大的互联网业务数据库设计军规
查看>>
Mysql学习总结(76)——MySQL执行计划(explain)结果含义总结
查看>>
Mysql学习总结(77)——温故Mysql数据库开发核心原则与规范
查看>>
Mysql学习总结(78)——MySQL各版本差异整理
查看>>
Mysql学习总结(79)——MySQL常用函数总结
查看>>
Mysql学习总结(7)——MySql索引原理与使用大全
查看>>
Mysql学习总结(80)——统计数据库的总记录数和库中各个表的数据量
查看>>
Mysql学习总结(81)——为什么MySQL不推荐使用uuid或者雪花id作为主键?
查看>>
Mysql学习总结(82)——MySQL逻辑删除与数据库唯一性约束如何解决?
查看>>