DYLD_PRINT_LIBRARIES 不工作

oku*_*ane 3 java macos darwin dyld dynamic-library

尝试使用其他 DYLD_ 属性进行试验时,我发现 jvm 正在使用属性进行操作,并且在执行过程中会忽略这些属性。
我的 Java 测试:

class Env {
    public static void main(String... args) {
        System.getenv().entrySet().stream().forEach(e -> System.out.println(e.getKey() + " = " + e.getValue()));
    }
}
Run Code Online (Sandbox Code Playgroud)

调用:

$ export DYLD_PRINT_LIBRARIES=1
$ export MY_PRINT_LIBRARIES=2
$ javac Env.java && java Env|grep PRINT
MY_PRINT_LIBRARIES = 2
$ 
Run Code Online (Sandbox Code Playgroud)

另一方面,我的 C 测试:

#include <stdio.h>

int main(int argc, char **argv, char **envp) {
    while (*envp) {
        printf("%s\n", *envp);
        envp++;
    }
    return 0;
}
Run Code Online (Sandbox Code Playgroud)

调用:

$ gcc env.c && ./a.out|grep PRINT
dyld: loaded: /Users/okutane/test/java/./a.out
dyld: loaded: /usr/lib/libSystem.B.dylib
dyld: loaded: /usr/lib/system/libcache.dylib
...
dyld: loaded: /usr/lib/libc++.1.dylib
dyld: loaded: /usr/lib/libDiagnosticMessagesClient.dylib
MY_PRINT_LIBRARIES=2
DYLD_PRINT_LIBRARIES=1
$
Run Code Online (Sandbox Code Playgroud)

我希望 jvm test 也能工作,有什么解决方法吗?

rai*_*mue 7

随着 SIP 的引入,DYLD_*在执行受限二进制文件之前,所有匹配的环境变量都将被剥离。这包括/usr/bin/java您将使用的二进制文件:

$ ls -lOL /usr/bin/java
-rwxr-xr-x  1 root  wheel  restricted,compressed 58560 Sep  7 06:41 /usr/bin/java*
Run Code Online (Sandbox Code Playgroud)