perl – 从标量变量创建VSTRING而不使用eval

我只是很好奇,– 甚至可以从标量变量创建一个V字符串而不需要使用eval?

I. e.,这有效,但使用eval:

my $var = 'v1.2.3';
my $conversion = to_vstring_1($var);
# Prints "Version: 1.2.3,type: VSTRING"
printf("Version: %vd,type: %s\n",$conversion,ref \$conversion);

sub to_vstring_1 {
    my ($arg) = @_;

    $arg =~ tr/0-9.//cd;
    $arg = 'v' . $arg;

    return eval $arg;
}

这两个变体也有效,并且不使用eval,但它们打印“SCALAR”而不是“VSTRING”:

my $conversion_2 = to_vstring_2($var);
# Prints "Version: 1.2.3,type: SCALAR"
printf("Version: %vd,$conversion_2,ref \$conversion_2);

my $conversion_3 = to_vstring_3($var);
# Prints "Version: 1.2.3,$conversion_3,ref \$conversion_3);

sub to_vstring_2 {
    my ($arg) = @_;

    $arg =~ tr/0-9.//cd;
    $arg = pack('U*',split(/\./,$arg));

    return $arg;
}

sub to_vstring_3 {
    my ($arg) = @_;

    $arg =~ tr/0-9.//cd;
    $arg =~ s/[._]?(\d+)/chr($1 & 0x0FFFF)/eg;

    return $arg;
}

那么,还有第四种方法吗?

解决方法

is it even possible to create a v-string from a scalar variable without resorting to eval?

是的,它是,但这是一个痛苦,没有充分的理由.

您可以编写以下XS代码

>解析您的输入字符串
>将数字转换为其等效的char
>通过调用sv_magic为你的标量指定v-string魔法

但是,这正是070​​01中Perl_scan_vstring的内部函数所做的.为什么重新发明轮子?

相关文章

1. 如何去重 #!/usr/bin/perl use strict; my %hash; while(...
最近写了一个perl脚本,实现的功能是将表格中其中两列的数据...
表的数据字典格式如下:如果手动写MySQL建表语句,确认麻烦,...
巡检类工作经常会出具日报,最近在原有日报的基础上又新增了...
在实际生产环境中,常常需要从后台日志中截取报文,报文的形...
最近写的一个perl程序,通过关键词匹配统计其出现的频率,让...