linux生成so,linux进入文件夹命令

大家好,今天小编来为大家解答linux生成so这个问题,linux进入文件夹命令很多人还不知道,现在让我们一起来看看吧!

linuxso文件反编译linux.so文件

linux生成文件中.so文件和.out文件的区别?

在链接的时候指定入口是可以制造可以运行的.so文件的典型的例子:/lib64/ld-linux-x86-64.so.2/lib64/libc.so.6因为它们都是ELF(ExecutableandLinkingFormat)文件顾名思义就知道这种文件同时兼具可执行于可连接的作用。Windows上我不熟悉,当时考虑到DLL于EXE都是PE文件,链接器那边做好入口理论上是可以执行的。但是如果Windows上有什么泾渭分明的区分就无解了

so文件怎么开?

so文件是Linux系统的可执行文件,相当于windows上的exe执行文件,只可以在Linux系统运行。so文件就是常说的动态链接库,都是C或C++编译出来的。与Java比较就是:它通常是用的Class文件(字节码).//Linux下的.so文件时不能直接运行的。一般来讲,.so文件称为共享库.//。

so文件怎么修改?

主要是gcc编译时候选择是静态库还是动态库。如下

gcc-ctest.c

ar-rtest.atest.o生成静态库

gcc-fPIC-sharedtest.c-otest.so生成动态库

自己生成的动态库为了能够让ld找到,必须要修改连接路径或者把动态库放到指定的目录里面。这样so文件就修改好了。

安卓类库so文件与linux类库类库文件区别?

本质上都是一样的,都是Linux的动态链接库

Linux系统libc. so在哪个文件夹里面

在x86_64架构下,在/usr/lib/x86_64-linux-gnu文件夹下默认存放的是GnuC/C++编译器的系统库。

里边的文件很重要,在不知道确切用途的情况下不要移动或删除该文件夹下的库文件。

可以通过命令ls/usr/lib/x86_64-linux-gnu-l查看文件夹下的文件。

扩展资料

在Ubuntu系统安装好GNU编译器后自动生成/usr/lib/x86_64-linux-gnu文件夹。有时候安装其它软件时,产生的动态库也可能出现在该文件夹下。如何引用动态库。

可以在环境变量加入LD_LIBRARY_PATH=/usr/lib/x86_64-linux-gnu/**lib.

或者在编译的时候制定-L/usr/lib/x86_64-linux-gnu-l**

或者在/etc/ld.so.conf.d文件中加入/usr/lib/x86_64-linux-gnu/,然后运行命令ldconf

linux环境java如何调用so文件

用JNI实现

实例:

创建HelloWorld.java

class HelloWorld

{

private native void print();

public staticvoid main(String[] args)

{

new HelloWorld().print();

}

static

{

System.loadLibrary("HelloWorld");

}

}

注意print方法的声明,关键字native表明该方法是一个原生代码实现的。另外注意static代码段的System.loadLibrary调用,这段代码表示在程序加载的时候,自动加载libHelloWorld.so库。

编译HelloWorld.java

在命令行中运行如下命令:

javac HelloWorld.java

在当前文件夹编译生成HelloWorld.class。

生成HelloWorld.h

在命令行中运行如下命令:

javah-jni HelloWorld

在当前文件夹中会生成HelloWorld.h。打开HelloWorld.h将会发现如下代码:

/* DO NOT EDIT THIS FILE- it is machine generated*/

#include<jni.h>

/* Header for class HelloWorld*/

#ifndef _Included_HelloWorld

#define _Included_HelloWorld

#ifdef __cplusplus

extern"C"{

#endif

/*

* Class: HelloWorld

* Method: print

* Signature:()V

*/

JNIEXPORT void JNICALL Java_HelloWorld_print

(JNIEnv*, jobject);

#ifdef __cplusplus

}

#endif

#endif

该文件中包含了一个函数Java_HelloWorld_print的声明。这里面包含两个参数,非常重要,后面讲实现的时候会讲到。

实现HelloWorld.c

创建HelloWorld.c文件输入如下的代码:

#include<jni.h>

#include<stdio.h>

#include"HelloWorld.h"

JNIEXPORT void JNICALL

Java_HelloWorld_print(JNIEnv*env, jobject obj)

{

printf("Hello World!\n");

}

注意必须要包含jni.h头文件,该文件中定义了JNI用到的各种类型,宏定义等。

另外需要注意Java_HelloWorld_print的两个参数,本例比较简单,不需要用到这两个参数。但是这两个参数在JNI中非常重要。

env代表java虚拟机环境,Java传过来的参数和c有很大的不同,需要调用JVM提供的接口来转换成C类型的,就是通过调用env方法来完成转换的。

obj代表调用的对象,相当于c++的this。当c函数需要改变调用对象成员变量时,可以通过操作这个对象来完成。

编译生成libHelloWorld.so

在Linux下执行如下命令来完成编译工作:

cc-I/usr/lib/jvm/java-6-sun/include/linux/

-I/usr/lib/jvm/java-6-sun/include/

-fPIC-shared-o libHelloWorld.so HelloWorld.c

在当前目录生成libHelloWorld.so。注意一定需要包含Java的include目录(请根据自己系统环境设定),因为Helloworld.c中包含了jni.h。

另外一个值得注意的是在HelloWorld.java中我们LoadLibrary方法加载的是

“HelloWorld”,可我们生成的Library却是libHelloWorld。这是Linux的链接规定的,一个库的必须要是:lib+库

名+.so。链接的时候只需要提供库名就可以了。

运行Java程序HelloWorld

大功告成最后一步,验证前面的成果的时刻到了:

java HelloWorld

如果你这步发生问题,如果这步你收到java.lang.UnsatisfiedLinkError异常,可以通过如下方式指明共享库的路径:

java-Djava.library.path='.' HelloWorld

当然还有其他的方式可以指明路径请参考《在Linux平台下使用JNI》。

我们可以看到久违的“Hello world!”输出了。

阅读剩余
THE END