- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
使用 C# 将字符串写入二进制文件时,长度(以字节为单位)会自动添加到输出中。根据MSDN documentation这是一个无符号整数,但也是一个字节。他们给出的示例是单个 UTF-8 字符将是三个写入字节:1 个大小字节和 2 个字符字节。这适用于长度不超过 255 的字符串,并且与我观察到的行为相匹配。
但是,如果您的字符串超过 255 个字节,则无符号整数的大小会根据需要增加。作为一个简单的例子,将 1024 个字符视为:
string header = "ABCDEFGHIJKLMNOP";
for (int ii = 0; ii < 63; ii++)
{
header += "ABCDEFGHIJKLMNOP";
}
fileObject.Write(header);
在字符串前面加上 2 个字节的结果。创建一个 2^17 长度的字符串会产生一个有点令人抓狂的 3 字节数组。
那么问题来了,读取时如何知道要读取多少字节才能得到后面的内容的大小呢?我不一定先验知道 header 大小。最终,我能否强制 Write(string) 方法始终使用一致的大小(比如 2 个字节)?
一个可能的解决方法是编写我自己的 write(string) 方法,但出于明显的原因我想避免这种情况(类似问题 here 和 here 接受这个作为答案)。另一个更可口的解决方法是让读者寻找启动 ASCII 字符串信息的特定字符(可能是不可打印的字符?),但这并非万无一失。最后一个解决方法(我能想到的)是强制字符串在特定大小字节数的大小范围内;同样,这也不理想。
虽然强制字节数组的大小保持一致是最简单的,但我可以控制读取器,因此也欢迎任何聪明的读取器解决方案。
最佳答案
BinaryWriter
和 BinaryReader
不是写入二进制数据的唯一方式;简单地说:它们提供了一个在特定读者和作者之间共享的约定。不,你不能告诉他们使用另一个约定——当然除非你将它们都子类化并完全覆盖 ReadString
和 Write(string)
方法。
如果您想使用不同的约定,那么只需:不要使用 BinaryReader
和 BinaryWriter
。直接使用任何文本 Encoding
与 Stream
对话非常容易,您可以获取字节数和字节数。然后您可以使用任何您想要的约定。如果您只需要写入最大 65k 的字符串,那么确定:使用固定的 2 个字节(unsigned short)。当然,您还需要决定哪个字节先出现(“字节顺序”)。
至于前缀的大小:本质上是使用:
int byteCount = this._encoding.GetByteCount(value);
this.Write7BitEncodedInt(byteCount);
与:
protected void Write7BitEncodedInt(int value)
{
uint num = (uint) value;
while (num >= 0x80)
{
this.Write((byte) (num | 0x80));
num = num >> 7;
}
this.Write((byte) num);
}
这种类型的长度编码很常见 - 它与 "varint" that "protobuf" uses 的想法相同,例如(base-128,最低有效组在前,保留7位组中的位顺序,第8位作为延续)
关于C# BinaryWriter 写入方法字符串大小,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47409296/
我有这个代码 var myChart = new FusionCharts("../themes/clean/charts/hbullet.swf", "myChartId", "400", "75
既然写入是立即进行的(复制到内核缓冲区并返回),那么使用 io_submit 进行写入有什么好处? 事实上,它 (aio/io_submit) 看起来更糟,因为您必须在堆上分配写入缓冲区并且不能使用基
我正在使用 mootool 的 Request.JSON 从 Twitter 检索推文。收到它后,我将写入目标 div 的 .innerHTML 属性。当我在本地将其作为文件进行测试时,即 file:
最终,我想将 Vertica DB 中的数据抓取到 Spark 中,训练机器学习模型,进行预测,并将这些预测存储到另一个 Vertica DB 中。 当前的问题是确定流程最后部分的瓶颈:将 Spark
我使用 WEKA 库编写了一个 Java 程序, 训练分类算法 使用经过训练的算法对未标记的数据集运行预测 将结果写入 .csv 文件 问题在于它当前写出离散分类结果(即算法猜测一行属于哪个类别)。我
背景 - 我正在考虑使用 clickonce 通过 clickonce(通过网站)部署 WinForms 应用程序。相对简单的应用程序的要素是: - 它是一个可执行文件和一个数据库文件(sqlite)
是否有更好的解决方案来快速初始化 C 数组(在堆上创建)?就像我们使用大括号一样 double** matrix_multiply(const double **l_matrix, const dou
我正在读取 JSON 文件,取出值并进行一些更改。 基本上我向数组添加了一些值。之后我想将其写回到文件中。当我将 JSONArray 写回文件时,会被写入字符串而不是 JSONArray 对象。怎样才
我为两个应用程序使用嵌入式数据库,其中一个是服务器,另一个是客户端。客户端应用程序。可以向服务器端发送获取数据请求以检索数据并显示在表格(或其他)中。问题是这样的:如何将获取的数据保存(写入)到页面文
是否有更好的解决方案来快速初始化 C 数组(在堆上创建)?就像我们使用大括号一样 double** matrix_multiply(const double **l_matrix, const dou
从问题得出问题:找到所有 result = new ArrayList(); for (int i = 2; i >(i%8) & 0x1) == 0) { result.add(i
由于某种原因,它没有写入 CSV。谁能明白为什么它不写吗? def main(): list_of_emails = read_email_csv() #read input file, cr
关闭。 这个问题是 not reproducible or was caused by typos 。它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能在这里出现,
我目前正在开发一个保存和加载程序,但我无法获得正确的结果。 编写程序: #include #include #define FILENAME "Save" #define COUNT 6 type
import java.io.*; public class Main2 { public static void main(String[] args) throws Exception {
我需要使用预定义位置字符串“Office”从所有日历中检索所有 iOS 事件,然后将结果写入 NSLog 和 UITextView。 到目前为止,这是我的代码: #import "ViewCo
我正在尝试将 BOOL 值写入 PFInstallation 中的列,但会不停地崩溃: - (IBAction)pushSwitch:(id)sender { NSUserDefaults *push
我以前在学校学过一些简单的数据库编程,但现在我正在尝试学习最佳实践,因为我正在编写更复杂的应用程序。写入 MySQL 数据库并不难,但我想知道让分布式应用程序写入 Amazon EC2 上的远程数据库
是否可以写回到ResourceBundle?目前我正在使用 ResourceBundle 来存储信息,在运行时使用以下内容读取信息 while(ResourceBundle.getBundle("bu
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
我是一名优秀的程序员,十分优秀!