c# – 如何使程序集的后续实例共享相同的内存?

我想要类似静态类变量的东西,除非不同的应用程序加载我的程序集我希望它们共享同一个变量.

我知道我可以写入磁盘或数据库,但这是一个与sql查询一起使用的进程,这可能会减慢太多(实际上我会测试这些选项但是我在问这个问题)与此同时,我认为这不是一个可以接受的解决方案.

我更愿意使用在部署中产生最少开销的解决方案,我不介意解决方案是否易于创建,只要它在我完成时易于使用.

我知道那里有一些持久的内存框架.我还没有检查过它们中的任何一个,也许其中一个是完美的,所以随意推荐一个.我也非常满足于自己写一些东西,特别是如果它让我更容易部署.

提前感谢任何和所有建议!

编辑:看起来我忽略了一个非常简单的解决方案.我的问题涉及SQL只提供8000字节的空间来在我写的SQL聚合函数调用之间序列化数据.我读了一篇关于如何压缩数据并从8000字节中获取最多的文章,并假设我无能为力.事实证明,我可以设置MaxBytes = -1而不是0到8000之间的范围,以获得高达2GB的空间.我相信这是他们在3.5框架中添加的新内容,因为有很多文章在讨论这个8000字节的限制.

谢谢大家的答案,因为这是一个我过去想解决的问题,现在我知道如果我需要一个非常简单快捷的方式在应用程序之间进行通信,该怎么办.

解决方法:

您不能将其存储为内存数据并在进程之间共享,因为每个进程都有自己独立的内存地址空间.

但是,一种选择是使用.NET Memory-mapped file支持来“存储”共享数据.这将允许您在每个进程可以访问的位置编写包含信息的文件.

上一篇:使用Spring JDBCTemplate在数据库中插入新数据记录后如何获取生成的ID?


下一篇:Android应用具有persistent属性时升级清理AMS缓存数据