微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在Perl中,我可以将字符串视为字节数组吗?

在Perl中,将字符串用作包含8位数据的字节数组是否合适?我在这主题上找到的所有文档都集中在7位字符串上.

例如,如果我将二进制文件中的一些数据读入$data

my $data;

open FILE,"<",$filepath;
binmode FILE;
read FILE $data 1024;

我想得到第一个字节,是substr($data,1,1)合适吗? (再次,假设它是8位数据)

我来自一个主要是C的背景,我习惯将char指针传递给read()函数.我的问题可能是我不明白字符串的底层表示是什么在Perl中.

解决方法

这里复制的read命令的捆绑文档提供了许多与您的问题相关的信息.

读FILEHANDLE,SCALAR,LENGTH,OFFSET

读FILEHANDLE,LENGTH

Attempts to read LENGTH characters of data into variable SCALAR
from the specified FILEHANDLE. Returns the number of
characters actually read,0 at end of file,or undef if there
was an error (in the latter case $! is also set). SCALAR will
be grown or shrunk so that the last character actually read is
the last character of the scalar after the read.

An OFFSET may be specified to place the read data at some place
in the string other than the beginning. A negative OFFSET
specifies placement at that many characters counting backwards
from the end of the string. A positive OFFSET greater than the
length of SCALAR results in the string being padded to the
required size with “\0” bytes before the result of the read is
appended.

The call is actually implemented in terms of either Perl’s or
system’s fread() call. To get a true read(2) system call,see
“sysread”.

Note the characters: depending on the status of the filehandle,
either (8-bit) bytes or characters are read. By default all filehandles operate on bytes,but for example if the filehandle has been opened with the “:utf8” I/O layer (see “open”,and the “open” pragma,open),the I/O will operate on UTF-8 encoded Unicode characters,not bytes. Similarly for the “:encoding” pragma: in that case pretty much any characters can be read.

原文地址:https://www.jb51.cc/Perl/171333.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐