【问题标题】:Strawberry Perl warning Subroutine Config::STORE redefined from perl libs?Strawberry Perl 警告 Subroutine Config::STORE 从 perl 库重新定义?
【发布时间】:2026-01-11 01:40:01
【问题描述】:

我正在维护一些 Perl 脚本,最近我注意到它们中的许多都从一些“系统”内容输出Subroutine ... redefined 警告,而不是来自我们编写的任何代码。

我现在可以举出一个精简的例子:

#!perl -W

use strict;
use warnings;
use 5.14.0;

# These work without warnings:
use Carp;
use URI;
use POSIX;

# Any of these will generate warnings:
# use LWP; # Subroutine Config::STORE redefined at C:/local/Perl-5.32.1-64bit-portable/perl/vendor/lib/Portable/Config.pm line 68.
# use XML::LibXML; # Subroutine Config::STORE redefined at C:/local/Perl-5.32.1-64bit-portable/perl/vendor/lib/Portable/Config.pm line 68.
# use Win32::Service; # Subroutine Win32::GetCwd redefined at C:/local/Perl-5.32.1-64bit-portable/perl/lib/DynaLoader.pm line 210. (and 20!! more)
# ...

say "Hello world.";

在 Windows 10 上使用 Strawberry Perl 5.32.1 x64 ZIP/Portable。还使用 Strawberry 5.14 进行了测试。 通过portableshell.bat 运行 -> perl testscript.pl

我觉得奇怪的是这么多“系统”模块应该生成这些警告,尤其是因为我不记得几个月前我上次做一些维护工作时看到过这些。

  • 我应该取消这些警告吗?
  • 还有什么我可以检查的吗?

C:\local\Perl-5.32.1-64bit-portable>perl -V
Summary of my perl5 (revision 5 version 32 subversion 1) configuration:

  Platform:
    osname=MSWin32
    osvers=10.0.19042.746
    archname=MSWin32-x64-multi-thread
    uname='Win32 strawberry-perl 5.32.1.1 #1 Sun Jan 24 15:00:15 2021 x64'
    config_args='undef'
    hint=recommended
    useposix=true
    d_sigaction=undef
    useithreads=define
    usemultiplicity=define
    use64bitint=define
    use64bitall=undef
    uselongdouble=undef
    usemymalloc=n
    default_inc_excludes_dot=define
    bincompat5005=undef
  Compiler:
    cc='gcc'
    ccflags =' -DWIN32 -DWIN64 -D__USE_MINGW_ANSI_STDIO -DPERL_TEXTMODE_SCRIPTS -DPERL_IMPLICIT_CONTEXT -DPERL_IMPLICIT_SYS -DUSE_PERLIO -fwrapv -fno-strict-aliasing -mms-bitfields'
    optimize='-s -O2'
    cppflags='-DWIN32'
    ccversion=''
    gccversion='8.3.0'
    gccosandvers=''
    intsize=4
    longsize=4
    ptrsize=8
    doublesize=8
    byteorder=12345678
    doublekind=3
    d_longlong=define
    longlongsize=8
    d_longdbl=define
    longdblsize=16
    longdblkind=3
    ivtype='long long'
    ivsize=8
    nvtype='double'
    nvsize=8
    Off_t='long long'
    lseeksize=8
    alignbytes=8
    prototype=define
  Linker and Libraries:
    ld='g++.exe'
    ldflags ='-s -L"C:\local\Perl-5.32.1-64bit-portable\perl\lib\CORE" -L"C:\local\Perl-5.32.1-64bit-portable\c\lib"'
    libpth=C:\local\Perl-5.32.1-64bit-portable\c\lib C:\local\Perl-5.32.1-64bit-portable\c\x86_64-w64-mingw32\lib C:\local\Perl-5.32.1-64bit-portable\c\lib\gcc\x86_64-w64-mingw32\8.3.0
    libs= -lmoldname -lkernel32 -luser32 -lgdi32 -lwinspool -lcomdlg32 -ladvapi32 -lshell32 -lole32 -loleaut32 -lnetapi32 -luuid -lws2_32 -lmpr -lwinmm -lversion -lodbc32 -lodbccp32 -lcomctl32
    perllibs= -lmoldname -lkernel32 -luser32 -lgdi32 -lwinspool -lcomdlg32 -ladvapi32 -lshell32 -lole32 -loleaut32 -lnetapi32 -luuid -lws2_32 -lmpr -lwinmm -lversion -lodbc32 -lodbccp32 -lcomctl32
    libc=
    so=dll
    useshrplib=true
    libperl=libperl532.a
    gnulibc_version=''
  Dynamic Linking:
    dlsrc=dl_win32.xs
    dlext=xs.dll
    d_dlsymun=undef
    ccdlflags=' '
    cccdlflags=' '
    lddlflags='-mdll -s -L"C:\local\Perl-5.32.1-64bit-portable\perl\lib\CORE" -L"C:\local\Perl-5.32.1-64bit-portable\c\lib"'


Characteristics of this binary (from libperl):
  Compile-time options:
    HAS_TIMES
    HAVE_INTERP_INTERN
    MULTIPLICITY
    PERLIO_LAYERS
    PERL_COPY_ON_WRITE
    PERL_DONT_CREATE_GVSV
    PERL_IMPLICIT_CONTEXT
    PERL_IMPLICIT_SYS
    PERL_MALLOC_WRAP
    PERL_OP_PARENT
    PERL_PRESERVE_IVUV
    USE_64_BIT_INT
    USE_ITHREADS
    USE_LARGE_FILES
    USE_LOCALE
    USE_LOCALE_COLLATE
    USE_LOCALE_CTYPE
    USE_LOCALE_NUMERIC
    USE_LOCALE_TIME
    USE_PERLIO
    USE_PERL_ATOF
  Built under MSWin32
  Compiled at Jan 24 2021 15:05:42
  @INC:
    C:/local/Perl-5.32.1-64bit-portable/perl/site/lib
    C:/local/Perl-5.32.1-64bit-portable/perl/vendor/lib
    C:/local/Perl-5.32.1-64bit-portable/perl/lib

【问题讨论】:

  • perl -V 的输出是什么?尤其是@INC 部分很重要。
  • @choroba - 我现在自己回答了。看来-W不太实用。

标签: perl compiler-warnings strawberry-perl


【解决方案1】:

在尝试进一步缩小示例脚本的范围时,我终于明白了这一点:

与我一直相信的相反,即使在 Windows 命令提示符下通过 perl script.pl 运行时,脚本 #!perl -W 开头的特定形式的 shebang 行也会被解释。

我们有:

...
-W                enable all warnings
...

如果我删除该行(在我们的 Windows 环境中不需要)或将其更改为 -w(小写),那么这些警告就会消失。

【讨论】: