JNI用C调用java程序,程序class.forname(其他包的类)时发生类找不到异常

我用的ubuntu,需要用c调用java程序,现在将编写好没问题的java程序打包乘jar文件,jni直接调用的方法是edu.unika.aifb.jnikernel.KernelManager里的initialize,initialize里有一句Class backendClass = Class.forName(kernelClassString);这个kernelClassString值为“
edu.unika.aifb.kernels.examples.Linear”,这个类我确保确确实实已经写好放那了,但是这个问题一直解决不掉。希望有过这方面经验的同仁能拉小弟一把,不深感激。
如果需要的话 c程序在此,java程序和异常在附件里
[code="c"]
/**

  • JNI Kernel Extension for SVMlight - http://www.aifb.uni-karlsruhe.de/WBS/sbl/software/jnikernel/
  • v0.9 (c) 19.01.2007 Stephan Bloehdorn, Institute AIFB, University of Karlsruhe, Germany
  • v1.0 (c) 25.05.2007 Stephan Bloehdorn, Institute AIFB, University of Karlsruhe, Germany
  • v1.1 (c) 29.05.2007 Stephan Bloehdorn, Institute AIFB, University of Karlsruhe, Germany
  • v1.2 (c) 04.07.2007 Stephan Bloehdorn, Institute AIFB, University of Karlsruhe, Germany */

extern "C" {

include "svm_common.h"

include "kernel.h"

}

#include
#include
#include "jni.h"
#include
#include

#define __VERSION "v1.2"

#define __MAX_LINE 1024
#define __MANAGERCLASS "edu/unika/aifb/jnikernel/KernelManager"
#define __CLASS_PARAM "jnikernel.class"
#define __OPTION_PARAM "jvm.option"
#define __NORMALIZE_PARAM "jnikernel.normalize"

using namespace std;

bool initialized = false;

//jvm references
JNIEnv *env;
JavaVM *jvm;

//backend references
jclass backend;
jmethodID m_initialize;
jmethodID m_evaluate;

// cosine normalization options and cache
bool normalize = false;
//REMOVE map norms;

//functions

void initialize(char* param);
void printErrorAndExit(char* message);
void printFileErrorAndExit(char* param);

extern "C" double custom_kernel(KERNEL_PARM *kernel_parm, SVECTOR *a, SVECTOR *b) {

if(!initialized) initialize(kernel_parm->custom);

//determine number of array elements...
int anum = 0;
int bnum = 0;
WORD *wordpointer;

wordpointer=a->words;
while (wordpointer->wnum) {
    anum++;
    wordpointer++;
}
wordpointer=b->words;
while (wordpointer->wnum) {
    bnum++;
    wordpointer++;
}

//create java arrays and copy values
jlongArray arg1indicesJ = env->NewLongArray(anum);
jfloatArray arg1valuesJ = env->NewFloatArray(anum);
jlongArray arg2indicesJ = env->NewLongArray(bnum);
jfloatArray arg2valuesJ = env->NewFloatArray(bnum);

if (arg1indicesJ==NULL||arg2indicesJ==NULL||arg1valuesJ==NULL||arg2valuesJ==NULL) {
    if (env->ExceptionCheck()) {
        printf("\n");
        env->ExceptionDescribe();
    }
    printErrorAndExit("Error when creating JNI array(s).");
}

jlong * arg1indices = env->GetLongArrayElements(arg1indicesJ, 0);
jlong * arg2indices = env->GetLongArrayElements(arg2indicesJ, 0);

float * arg1values = env->GetFloatArrayElements(arg1valuesJ, 0);
float * arg2values = env->GetFloatArrayElements(arg2valuesJ, 0);

for (int i=0;i<anum;i++) {
    arg1indices[i]=a->words[i].wnum;
    arg1values[i]=a->words[i].weight;
}
for (int i=0;i<bnum;i++) {
    arg2indices[i]=b->words[i].wnum;
    arg2values[i]=b->words[i].weight;
}

//release the changes back to java arrays
env->ReleaseLongArrayElements(arg1indicesJ, arg1indices, 0);
env->ReleaseLongArrayElements(arg2indicesJ, arg2indices, 0);
env->ReleaseFloatArrayElements(arg1valuesJ, arg1values, 0);
env->ReleaseFloatArrayElements(arg2valuesJ, arg2values, 0);

//construct java strings out of userdefined fields
jstring arg1stringJ = env->NewStringUTF(a->userdefined);
jstring arg2stringJ = env->NewStringUTF(b->userdefined);

if (arg1stringJ==NULL||arg2stringJ==NULL) {
    if (env->ExceptionCheck()) {
        printf("\n");
        env->ExceptionDescribe();
    }
    printErrorAndExit("Java exception when creating JNI string(s) (see stderr).");
}

//  jclass cls=env->FindClass("\home\zhenchao\workspace\svm_light\HW");
//  if (!cls) {
//      printf("Class %s not found\n");
//      return -1;
//  }
//
//  jmethodID mid=env->GetStaticMethodID(cls,"get","()I");
//  if (!mid) {
//      printf("Method %s of Class %s not found\n");
//      return -1;
//  }
//  double test_result=env->CallStaticDoubleMethod(cls,mid);
//  printf("%f\n",test_result);
//call backend kernel evaluation, check for java exceptions
double result = env->CallStaticDoubleMethod(backend,m_evaluate,arg1indicesJ,arg1valuesJ,arg1stringJ,arg2indicesJ,arg2valuesJ,arg2stringJ);

if (env->ExceptionCheck()) {
    printf("\n");
    env->ExceptionDescribe();
    printErrorAndExit("Java exception when computing kernel (see stderr).");
}

if(result!=0&&normalize) {

    /*
     * NOTE:
     * Internally, we "abuse" the "twonorm_sq" field of the SVECTOR to allow
     * for fast retrieval of the squared norms.
     * To indicate that the value is not the original vector length but
     * the squared kernel norm supplied by this kernel, we store inverted
     * (i.e. negative) values.
     *
     * This is obviously a hack, but we do not want to meddle with the SVMlight
     * code. It won't affect your application unless you use SVMlight as a library
     * and apply different kernels to the same dataset loaded only once. So this does
     * not seem critical ;-)
     */

    double norm_sq_negativeA,norm_sq_negativeB;

    if (a->twonorm_sq<0) {
        norm_sq_negativeA = a->twonorm_sq;
    }
    else {
        norm_sq_negativeA=-1*env->CallStaticDoubleMethod(backend,m_evaluate,arg1indicesJ,arg1valuesJ,arg1stringJ,arg1indicesJ,arg1valuesJ,arg1stringJ);
        a->twonorm_sq=norm_sq_negativeA;
    }
    if (b->twonorm_sq<0) {
        norm_sq_negativeB = b->twonorm_sq;
    }
    else {
        norm_sq_negativeB=-1*env->CallStaticDoubleMethod(backend,m_evaluate,arg2indicesJ,arg2valuesJ,arg2stringJ,arg2indicesJ,arg2valuesJ,arg2stringJ);
        b->twonorm_sq=norm_sq_negativeB;
    }

    //multiplication is ok, as *both* values will be negative.
    result = result/sqrt(norm_sq_negativeA*norm_sq_negativeB);
}

//clean up
env->DeleteLocalRef(arg1indicesJ);
env->DeleteLocalRef(arg2indicesJ);
env->DeleteLocalRef(arg1valuesJ);
env->DeleteLocalRef(arg2valuesJ);
env->DeleteLocalRef(arg1stringJ);
env->DeleteLocalRef(arg2stringJ);

return 0.0;

}

void printErrorAndExit(char* message) {
fflush(stdout);
fflush(stderr);
printf("An error occured in custom kernel module: ");
printf("%s\n", message);
printf("exiting...\n");
exit(1);
}

void printFileErrorAndExit(char* file, char* message) {
fflush(stdout);
fflush(stderr);
printf("Error reading from parameter file: %s\n", file);
printf("%s\n", message);
printf("exiting...\n");
exit(1);
}

void initialize(char* param) {

fflush(stdout);
printf("Using custom kernel module: JNI kernel version "__VERSION".\n");

FILE * pFile;
char line[__MAX_LINE ];
char classname[__MAX_LINE ];
char option[__MAX_LINE ];

//first pass: count... (needed for determining number of options)
pFile = fopen(param, "r");
if (pFile == NULL)
    printFileErrorAndExit(param, "Can not open file.");
int optioncount = 0;
int classcount = 0;
while (fgets(line, __MAX_LINE, pFile)) {
    if (sscanf(line, __CLASS_PARAM" %[^\n]", &classname))
        classcount++;
    if (sscanf(line, __OPTION_PARAM" %[^\n]", &option) > 0)
        optioncount++;
}
fclose(pFile);

if (classcount != 1)
    printFileErrorAndExit(param, "Invalid number of classes.");

//second pass: read content
char** optionstrings = (char**) malloc(optioncount * sizeof(char *));
int optionindex = 0;
pFile = fopen(param, "r");
if (pFile == NULL)
    printFileErrorAndExit(param, "Can not open file.");

while (fgets(line, __MAX_LINE, pFile)) {
    sscanf(line, __CLASS_PARAM" %[^\n]", &classname);
    if (sscanf(line, __OPTION_PARAM" %[^\n]", &option) > 0) {
        optionstrings[optionindex] = (char*) malloc(
                __MAX_LINE * sizeof(char));
        strcpy(optionstrings[optionindex], option);
        optionindex++;
    } else if (strncmp(line, __NORMALIZE_PARAM, strlen(__NORMALIZE_PARAM))
            == 0)
        normalize = true;
}
fclose(pFile);

//prepare Java Virtual Machine, locate classes and methods
//class specification needs to follow corresponding KernelManager Java class...
if (verbosity > 0)
    printf(
            "Preparing Java backend... (increase verbosity to see more details)\n");

JavaVMOption * options = (JavaVMOption *) malloc(
        sizeof(JavaVMOption) * optioncount);

for (int i = 0; i < optioncount; i++) {
    if (verbosity > 1)
        printf("JVM option: %s\n", optionstrings[i]);
    options[i].optionString = optionstrings[i];
}

/*
 JavaVMOption options[4];
 options[0].optionString = "-Xmx512M";
 options[1].optionString = "-Xms128M";
 options[2].optionString = "-Djava.class.path=" USER_CLASSPATH;
 options[3].optionString = "-Djava.library.path=.";
 */

JavaVMInitArgs vm_args;
vm_args.version = JNI_VERSION_1_2;
vm_args.options = options;
vm_args.nOptions = optioncount;
vm_args.ignoreUnrecognized = JNI_TRUE;
jint status;
status = JNI_CreateJavaVM(&jvm, (void**) &env, &vm_args);

if (status < 0) {
    char message[__MAX_LINE ];
    sprintf(message, "Can't create Java VM (err %d)\n", status);
    printErrorAndExit(message);
} else if (verbosity > 1)
    printf("Java VM ok.\n");

backend = env->FindClass(__MANAGERCLASS);
if (backend == NULL)
    printErrorAndExit("Can't locate KernelManager class.");
else if (verbosity > 1)
    printf("KernelManager class ok.\n");

m_initialize = env->GetStaticMethodID(backend, "initialize",
        "(Ljava/lang/String;Ljava/lang/String;)V");
if (m_initialize == NULL)
    printErrorAndExit("Can't locate initialization method.");
else if (verbosity > 1)
    printf("Init method ok.\n");

m_evaluate = env->GetStaticMethodID(backend, "evaluate",
        "([J[FLjava/lang/String;[J[FLjava/lang/String;)D");
if (m_evaluate == NULL)
    printErrorAndExit("Can't locate evaluation method.");
else if (verbosity > 1)
    printf("Evaluation method ok.\n");

jstring classnamearg = env->NewStringUTF(classname);
jstring paramarg = env->NewStringUTF(param);

if (verbosity > 0)
    printf("Backend class: %s\n", classname);
//calls "public static void initialize(String kernelClassString, String paramFileString) ..."
fflush(stdout);

env->CallStaticBooleanMethod(backend, m_initialize, classnamearg, paramarg);

fflush(stdout);
printf("OOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOO");
if (env->ExceptionCheck()) {
    printf("\n");
    env->ExceptionDescribe();
    printErrorAndExit("Java exception during initialization (see stderr).");
} else if (verbosity > 0)
    printf("Java backend ready.\n");

if (normalize)
    printf("Kernel normalization is on.\n");

initialized = true;
fflush(stdout);

}

[/code]

c

1个回答

附件异常在哪里?
你把这个
options[2].optionString = "-Djava.class.path=" USER_CLASSPATH;

改成
options[2].optionString = "-classpath" ;
options[3].optionString = USER_CLASSPATH;
试试
USER_CLASSPATH里确定要包含所有需要的java类。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
Java项目调用jni接口报NoClassDefFoundError,直接执行main方法就可以,但是从controller调就报错

项目中需要调用C语言写的方法,网上查到用jni操作,然后根据网上的方法编译出了.h文件和C文件, 放到linux 通过java xxx 执行main方法,成功调用。 下面贴一下java代码 ``` package com.yufeng.cj.common; public class MyNative { static { System.loadLibrary( "HelloNative" ); } public static native void greeting(); public static void main(String[] args) { greeting(); } } ``` C代码 ``` #include <stdio.h> #include "com_yufeng_cj_common_MyNative.h" JNIEXPORT void JNICALL Java_com_yufeng_cj_common_MyNative_greeting(JNIEnv *env, jobject c1) { printf("Hello Native!!\n"); } ``` 命令行执行,打印出东西 ![](https://img-ask.csdn.net/upload/201811/10/1541831575_975104.png) 但是后面换到controller方法里去调就报错了 ``` @PostMapping("/toC") public void toC(){ MyNative.greeting(); } ``` 报错信息: ``` 2018-11-10 14:34:29.996 ERROR -- com.yufeng.cj.controller.AdviceController.handlerException [line51 ] : Handler dispatch failed; nested exception is java.lang.NoClassDefFoundError: Could not initialize class com.yufeng.cj.common.MyNative org.springframework.web.util.NestedServletException: Handler dispatch failed; nested exception is java.lang.NoClassDefFoundError: Could not initialize class com.yufeng.cj.common.MyNative at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1006) at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:925) at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:974) at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:877) at javax.servlet.http.HttpServlet.service(HttpServlet.java:661) at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:851) at javax.servlet.http.HttpServlet.service(HttpServlet.java:742) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:99) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) at org.springframework.web.filter.HttpPutFormContentFilter.doFilterInternal(HttpPutFormContentFilter.java:109) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) at org.springframework.web.filter.HiddenHttpMethodFilter.doFilterInternal(HiddenHttpMethodFilter.java:93) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) at org.springframework.boot.web.servlet.support.ErrorPageFilter.doFilter(ErrorPageFilter.java:130) at org.springframework.boot.web.servlet.support.ErrorPageFilter.access$000(ErrorPageFilter.java:66) at org.springframework.boot.web.servlet.support.ErrorPageFilter$1.doFilterInternal(ErrorPageFilter.java:105) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) at org.springframework.boot.web.servlet.support.ErrorPageFilter.doFilter(ErrorPageFilter.java:123) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:200) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:198) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96) at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:493) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:81) at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:650) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:342) at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:800) at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66) at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:806) at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1498) at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624) at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) at java.lang.Thread.run(Thread.java:748) Caused by: java.lang.NoClassDefFoundError: Could not initialize class com.yufeng.cj.common.MyNative at com.yufeng.cj.controller.TestController.toC(TestController.java:21) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:498) at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:209) at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:136) at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:102) at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:891) at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:797) at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:991) ... 51 common frames omitted 2018-11-10 14:34:30.000 WARN -- springframework.web.servlet.mvc.method.annotation.ExceptionHandlerExceptionResolver.resolveException [line140 ] : Resolved [org.springframework.web.util.NestedServletException: Handler dispatch failed; nested exception is java.lang.NoClassDefFoundError: Could not initialize class com.yufeng.cj.common.MyNative] ``` 目前目录结构里是这样的: ![图片说明](https://img-ask.csdn.net/upload/201811/10/1541832416_824298.png) 求大神解答

android jni java.lang.UnsatisfiedLinkError

在调用jni时,报java.lang.UnsatisfiedLinkError: No implementation found for void com.eaglive.voip.VoipSdk.init(java.lang.String, int, java.lang.String) (tried Java_com_eaglive_voip_VoipSdk_init and Java_com_eaglive_voip_VoipSdk_init__Ljava_lang_String_2ILjava_lang_String_2) 还有调用了其他的so文件,但是这里出现的错误好像与它们无关,就暂时不贴出来了, 网上说的检查java类包名和jni方法名这个我检查了,没问题,还有使用命令查看了so文件是否加载到目录里,结果如下: ![图片说明](https://img-ask.csdn.net/upload/201709/04/1504532197_671134.png) System.loadLibrary("voip"); 这句也没报异常。跪求大牛帮我看看,还是哪里的问题。拜托,拜托……

菜鸟请教,Java项目中如何使用JNI调用.so文件,已有现成的.so文件

现在我有一个Java项目,是win系统下面,因为项目需求,需要调用.so文件去将.dat文件转换成.txt文件。因整个项目都在win下,没办法再提供Linux环境去运行.so文件。有没有方法直接在java项目中集成调用.so文件?我使用的工具是eclipse。哪位大佬能否详细解答一下。。最好有demo

java程序通过JNI调用第三方so文件,运行出现crash,导致程序退出

在spring boot中使用JNI集成第三方so文件,通过 java -XX:+UnlockDiagnosticVMOptions -XX:+VerifyBeforeGC -XX:+VerifyAfterGC -jar xxxxx.jar运行,在调用第三方so文件时出现crash,导致程序退出 ![图片说明](https://img-ask.csdn.net/upload/201803/16/1521168248_575820.jpg) 下面是crash产生的日志文件hs_err_pid17314.log ``` # # A fatal error has been detected by the Java Runtime Environment: # # Internal Error (instanceKlass.cpp:3358), pid=17314, tid=0x00007ff1fe6e6700 # guarantee(false) failed: boom # # JRE version: Java(TM) SE Runtime Environment (8.0_111-b14) (build 1.8.0_111-b14) # Java VM: Java HotSpot(TM) 64-Bit Server VM (25.111-b14 compiled mode linux-amd64 compressed oops) # Core dump written. Default location: /data/html/agora/core or core.17314 # # If you would like to submit a bug report, please visit: # http://bugreport.java.com/bugreport/crash.jsp # --------------- T H R E A D --------------- Current thread (0x00007ff22c1c6000): VMThread [stack: 0x00007ff1fe5e6000,0x00007ff1fe6e7000] [id=17324] Stack: [0x00007ff1fe5e6000,0x00007ff1fe6e7000], sp=0x00007ff1fe6e5200, free space=1020k Native frames: (J=compiled Java code, j=interpreted, Vv=VM code, C=native code) V [libjvm.so+0xac5c2a] VMError::report_and_die()+0x2ba V [libjvm.so+0x4fbc92] report_vm_error(char const*, int, char const*, char const*)+0x62 V [libjvm.so+0x655582] VerifyFieldClosure::do_oop(unsigned int*)+0x102 V [libjvm.so+0x64b651] InstanceKlass::oop_oop_iterate_nv(oopDesc*, NoHeaderExtendedOopClosure*)+0x91 V [libjvm.so+0x63ea8f] InstanceKlass::oop_verify_on(oopDesc*, outputStream*)+0x5f V [libjvm.so+0x8dd059] MutableSpace::verify()+0x69 V [libjvm.so+0x992486] PSYoungGen::verify()+0x16 V [libjvm.so+0xa8cf6c] Universe::verify(VerifyOption, char const*, bool)+0xcc V [libjvm.so+0x98e6f0] PSScavenge::invoke_no_policy()+0x330 V [libjvm.so+0x98fa81] PSScavenge::invoke()+0x41 V [libjvm.so+0x9467d0] ParallelScavengeHeap::failed_mem_allocate(unsigned long)+0x70 V [libjvm.so+0xac7647] VM_ParallelGCFailedAllocation::doit()+0x97 V [libjvm.so+0xacf125] VM_Operation::evaluate()+0x55 V [libjvm.so+0xacd4fa] VMThread::evaluate_operation(VM_Operation*)+0xba V [libjvm.so+0xacd87e] VMThread::loop()+0x1ce V [libjvm.so+0xacdcf0] VMThread::run()+0x70 V [libjvm.so+0x924ea8] java_start(Thread*)+0x108 VM_Operation (0x00007ff1753d7780): ParallelGCFailedAllocation, mode: safepoint, requested by thread 0x00007ff128001000 ```

java web项目如何调用.so文件?

我这里有一个libhf_test.so文件,开始是放在android project里边的,调用什么的都没有问题。 现在新加了一个需求:把这个libhf_test.so文件放到web project项目中 然后我就写了个小小的测试类 ``` public class AppUtil{ static{ System.loadLibrary("hf_test"); } //so文件中的native方法 public native static String getNString(String paramsString); public static void main(String[] args) { System.out.println("load:"+getNString("020#2#B621#merexpand")); } } ``` 然后运行报错了 java.lang.UnsatisfiedLinkError: no hfswpay in java.library.path at java.lang.ClassLoader.loadLibrary(ClassLoader.java:1709) at java.lang.Runtime.loadLibrary0(Runtime.java:823) at java.lang.System.loadLibrary(System.java:1030) at com.umpay.huafubao.util.AppUtil.<clinit>(AppUtil.java:8) Exception in thread "main" 百度了好多解决办法,有把so文件放到java.library.path各个路径中的,有用System.load("路径/libhf_test.so")的,都不行啊 System.load("路径/libhf_test.so")会报文件类型的错,好像只能加载.dll文件 然而我就只想用System.loadLibrary()这个方法了, adnroid工程可以直接调用是因为,它本身已经做好了配置 我想web工程也需要做一些ndk的配置才能使用吧? 希望大家能指点一二 另外:还有说要用到.h头文件的,我的开发工具myeclipse,用Java,不是vs

jni调用java方法报错!!!

12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] JNI DETECTED ERROR IN APPLICATION: calling static method java.lang.String com.library.utils.MD5Utils.md5(java.lang.String) with CallObjectMethod 12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] in call to CallObjectMethod 12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] from java.lang.String com.mb.library.nativeutils.DmCoding.getMD5(java.lang.String) 12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] "main" prio=5 tid=1 Runnable 12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] | group="main" sCount=0 dsCount=0 obj=0x752bf000 self=0xf4827800 12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] | sysTid=23825 nice=0 cgrp=default sched=0/0 handle=0xf74bbbec 12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] | state=R schedstat=( 387939683 56711068 527 ) utm=33 stm=5 core=0 HZ=100 12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] | stack=0xff7b0000-0xff7b2000 stackSize=8MB 12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] | held mutexes= "mutator lock"(shared held) 12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] at com.mb.library.nativeutils.DmCoding.getMD5(Native method) 12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] at com.colorpick.activity.CorCppTestActivity.onClick(CorCppTestActivity.java:53) 12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] at android.view.View.performClick(View.java:4908) 12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] at android.view.View$PerformClick.run(View.java:20378) 12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] at android.os.Handler.handleCallback(Handler.java:815) 12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] at android.os.Handler.dispatchMessage(Handler.java:104) 12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] at android.os.Looper.loop(Looper.java:194) 12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] at android.app.ActivityThread.main(ActivityThread.java:5691) 12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] at java.lang.reflect.Method.invoke!(Native method) 12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] at java.lang.reflect.Method.invoke(Method.java:372) 12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:959) 12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:754) 12-04 11:33:08.818: A/art(23825): art/runtime/check_jni.cc:70] 12-04 11:33:08.818: A/libc(23825): Fatal signal 6 (SIGABRT), code -6 in tid 23825 (com.colorpick)

java用JNI调用第三方库的时候,出现 java.lang.UnsatisfiedLinkError

Exception in thread "main" java.lang.UnsatisfiedLinkError: test.VoiceTest.MSPLogin(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String; at test.VoiceTest.MSPLogin(Native Method) at test.VoiceTest.main(VoiceTest.java:10) 这是调用自己封装的dll出现的问题

jni回调函数 c++调用java

typedef void (*app_mrcp_callback)(enum MrcpMessageCallback_E type, void* message); int mrcp_init(app_mrcp_callback cb); struct MrcpJoinClassParam { char* siteID; int siteIDLen; int classID; char* userName; int userNameLen; char* userID; int userIDLen; int nodeID; int userType; char* password; int passwordLen; char* portal; int portalLen; int max_channels; char* customer; }; 这个回调jni里面应该怎么写,江湖急救

JNI 调用GetMethodID 获得System.out.println()方法的jmethodid时出错的问题。

症状如下: 作为练习,为了在C代码中调用java的System.out.println()方法,我写了如下代码。 java代码片段如下: [size=xx-small] public class JNI_JAVA { public static native void println(String str); // 在C代码里打算调用System.out.println()。 public static void main(String[] args) { JNI_JAVA.println("Lady Gaga"); } } [/size] 生成如下头文件 JNI_JAVA.h 的片段: [size=xx-small] /* * Class: JNI_JAVA * Method: println * Signature: (Ljava/lang/String;)V */ JNIEXPORT void JNICALL Java_JNI_1JAVA_println (JNIEnv *, jclass, jstring); [/size] 以下是我自己写的C代码 JNI_JAVA.C的片段: [size=xx-small] /* * Class: JNI_JAVA * Method: println * Signature: (Ljava/lang/String;)V */ JNIEXPORT void JNICALL Java_JNI_1JAVA_println (JNIEnv *env, jclass clz, jstring str) { //获取java.lang.system类 jclass cls_system = (**env).FindClass(env, "java/lang/System"); if (NULL == cls_system) { fprintf(stderr, "Error %s:%d\n", __FILE__, __LINE__); return; } //获取System.out的FID jfieldID fid_out = (**env).GetStaticFieldID(env, cls_system, "out", "Ljava/io/PrintStream;"); if (NULL == fid_out) { fprintf(stderr, "Error %s:%d\n", __FILE__, __LINE__); return; } fprintf(stderr, "alive1\n");//正常输出 //获取System.out的对象 jobject obj_out = (**env).GetStaticObjectField(env, cls_system, fid_out); if (NULL == obj_out) { fprintf(stderr, "Error %s:%d\n", __FILE__, __LINE__); return; } fprintf(stderr, "alive2\n");//正常输出 //[color=red]百分百死在下面这一句[/color] //获取System.out.println()的MID jmethodID mid_println = (**env).GetMethodID(env, obj_out, "println", "(Ljava/lang/String;)V"); fprintf(stderr, "alive3\n");//这句不会输出,下面也不会执行 if (NULL == mid_println) { fprintf(stderr, "Error %s:%d\n", __FILE__, __LINE__); return; } (**env).CallVoidMethod(env, obj_out, mid_println, str); fprintf(stderr, "Yeah\n"); } [/size] 执行到 jmethodID mid_println = (**env).GetMethodID(env, obj_out, "println", "(Ljava/lang/String;)V"); 这一句时程序会死掉,同时给出以下输出: //下面的alive1,alive2是我故意输出的 [size=xx-small]alive1 alive2 # # An unexpected error has been detected by HotSpot Virtual Machine: # # SIGSEGV (0xb) at pc=0x00000000, pid=11192, tid=3076175552 # # Java VM: Java HotSpot(TM) Client VM (1.5.0_19-b02 mixed mode, sharing) # Problematic frame: # C 0x00000000 # # An error report file with more information is saved as hs_err_pid11192.log # # If you would like to submit a bug report, please visit: # http://java.sun.com/webapps/bugreport/crash.jsp # [/size] [b]问题: 我调用 jmethodID mid_println = (**env).GetMethodID(env, obj_out, "println", "(Ljava/lang/String;)V"); 为啥会死?? 是不是违反了什么安全限制,所以才使得程序死掉?[/b]

jni创建虚拟机失败问题,c++dll调用java类在VM初始化中出现错误

![图片说明](https://img-ask.csdn.net/upload/201706/15/1497487523_282629.png) 如上图错误,代码如下: string tmp0 ="-Djava.class.path=.;"; //cout<<tmp0<<endl; string configTmp = tmp0 + m_p0 + ";" + m_p1; //cout<<configTmp<<endl; options[0].optionString = (char*)configTmp.c_str(); vm_args.version = JNI_VERSION_1_6; //设置版本号 vm_args.nOptions = 1; vm_args.options = options; vm_args.ignoreUnrecognized = JNI_TRUE; //定义一个函数指针,下面用来指向JVM中的JNI_CreateJavaVM函数 typedef jint (WINAPI *PFunCreateJavaVM)(JavaVM **, void **, void *); //const wchar_t szJvmPath[]=L"D:\\Java\\jdk1.8.0_131\\jre\\bin\\client\\jvm.dll"; int p2Len = m_p2.length(); WCHAR *szJvmPath = new WCHAR[p2Len+1]; MultiByteToWideChar(0, 0, m_p2.c_str(), -1, szJvmPath, p2Len+1); cout<<szJvmPath<<endl; hInstance = ::LoadLibrary(szJvmPath); cout<<"成功"<<endl; delete []szJvmPath; szJvmPath = NULL; if (hInstance == NULL) { cout<< "LoadLibrary False"<<endl; cout<<::GetLastError()<<endl; return false; } cout<<"成功1"<<endl; //取得里面的JNI_CreateJavaVM函数指针 PFunCreateJavaVM funCreateJavaVM = (PFunCreateJavaVM)::GetProcAddress(hInstance, "JNI_CreateJavaVM"); cout<<"成功2"<<endl; long status = (*funCreateJavaVM)(&jvm, (void**)&env, &vm_args); //查找类,返回JAVA类的CLASS对象 //jclass cls = env->FindClass("D:\\javaOfWorkspace\\Test20170502\\src\\test\\c_call_j"); cout<<"成功3"<<endl; cls = env->FindClass("test20170505/ParserDemo"); 在: long status = (*funCreateJavaVM)(&jvm, (void**)&env, &vm_args);这一步出现错误,如果这个cpp不封装到dll中则能正常运行,封装以后就出现错误,其他配置都一样的,求大神解决。

JAVA MVC项目报错:java.lang.NoClassDefFoundError:

错误信息如下: java.lang.NoClassDefFoundError: Could not initialize class SketchYourHouse.MediumInCJ SketchYourHouse.SketchBeans.savePic(SketchBeans.java:56) SketchYourHouse.SketchServlet.doPost(SketchServlet.java:46) javax.servlet.http.HttpServlet.service(HttpServlet.java:648) javax.servlet.http.HttpServlet.service(HttpServlet.java:729) org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) 整个项目网站部分用java MVC(jsp+servlet+javabeans)搭建,核心算法用c++写的,然后通过JNI与javabeans连接起来,SketchBeans就是我的javabeans,声明部分是这样写的: MediumInCJ mcj = new MediumInCJ(); System.out.println("I got " + mcj.getProbeFeature() + "/n"); MediumInCJ()里是这样写的: public class MediumInCJ { static{ System.loadLibrary("dll/DLLforProbe"); } public native int getProbeFeature(); } 请问各位大神我这是哪里出问题了,个人觉得声明这部分没什么问题阿···

本地运行spark,JNI error, NoClassDefFoundError

异常信息如下:运行spark 的wordcount demo,引用 的jar都依赖好好的, 部署spark 的时候遇见过类似错误,通过环境变量指定hadoop的jni就好了,现在在本机ide不知道该怎么办了 Error: A JNI error has occurred, please check your installation and try again Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/spark/api/java/function/FlatMapFunction at java.lang.Class.getDeclaredMethods0(Native Method) at java.lang.Class.privateGetDeclaredMethods(Class.java:2701) Disconnected from the target VM, address: '127.0.0.1:58564', transport: 'socket' at java.lang.Class.privateGetMethodRecursive(Class.java:3048) at java.lang.Class.getMethod0(Class.java:3018) at java.lang.Class.getMethod(Class.java:1784) at sun.launcher.LauncherHelper.validateMainClass(LauncherHelper.java:544) at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:526) Caused by: java.lang.ClassNotFoundException: org.apache.spark.api.java.function.FlatMapFunction at java.net.URLClassLoader.findClass(URLClassLoader.java:381) at java.lang.ClassLoader.loadClass(ClassLoader.java:424) at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331) at java.lang.ClassLoader.loadClass(ClassLoader.java:357) ... 7 more

关与jni多层调用C/C++

最近做一个项目,逻辑大概是这样子的。jni直接生成的接口(func.c),调用C代码已经成功(暂且叫做func1.c),func1.c还要调用一个func2.c。 我把func2.c,制作成了动态库的形式。func2.h有。我的这个func1.c怎么调用这个库。怎么尝试总是报错。 望前辈们指教下,我才注册的这个,么有BB。在此谢谢。

在Windows上使用JNI从Java调用Golang会导致“动态链接库(DLL)初始化例程失败”

<div class="post-text" itemprop="text"> <p>I created the following example project to test out calling Golang code from Java using JNI: <a href="https://github.com/blaubaer/golang-jni" rel="nofollow noreferrer">https://github.com/blaubaer/golang-jni</a></p> <p>When I call <code>build.cmd</code> I receive an error message like this:</p> <pre><code>Exception in thread "main" java.lang.UnsatisfiedLinkError: [...]\out\hello.dll: A dynamic link library (DLL) initialization routine failed at java.base/java.lang.ClassLoader$NativeLibrary.load0(Native Method) at java.base/java.lang.ClassLoader$NativeLibrary.load(ClassLoader.java:2430) at java.base/java.lang.ClassLoader$NativeLibrary.loadLibrary(ClassLoader.java:2487) at java.base/java.lang.ClassLoader.loadLibrary0(ClassLoader.java:2684) at java.base/java.lang.ClassLoader.loadLibrary(ClassLoader.java:2649) at java.base/java.lang.Runtime.loadLibrary0(Runtime.java:829) at java.base/java.lang.System.loadLibrary(System.java:1867) at Hello.&lt;clinit&gt;(Hello.java:3) </code></pre> <p>Used environment:</p> <ul> <li>Windows: 10.0.17763, Build 17763, 64bit</li> <li>Golang: 1.11.5, windows/amd64</li> <li>Java: 11.0.2 2019-01-15 LTS, 64-Bit</li> <li>MinGW-w64: x86_64-8.1.0-win32-sjlj-rt_v6-rev0</li> </ul> <p>Thanks!</p> </div>

java使用JNI调用的dll依赖于其它dll路径该如何配置

jni调用dll扩展程序直接配置-Djava.library.path来指定dll所在目录即可以加载到dll,但是如果dll要依赖其它dll的时候会提示 Can't find dependent librarie即找不到dll的依赖库,这种情况可以将需要依赖的dll放到项目根目录下或者jdkbin目录下解决,但是想要导出jar包供其它调用就不行了,而且这种解决方法也不适用,总不能每次调用都把dll文件复制到根目录下,这时该如何处理?

java JNI 调用 c++ 动态库.so 文件抛错,如何调试?

![图片说明](https://img-ask.csdn.net/upload/201711/01/1509499054_793886.png) # Problematic frame: # C [libc.so.6+0x7a451] 为什么抛错的是这个?C标准库libc.so.6是存在的,应该是yum gcc 的时候就已经装好了

Java调用JNI第一次成功返回结果,第二次程序直接挂死

有一个需求是用c++算法算得当前音频是否为异常音,大概会每3秒调用一次c++程序用来识别音频文件,其中c++和Java是用的JNI框架连接的。每当我运行测试,第一次识别能够正确返回值,第二次执行到调用JNI时程序直接挂死。不知道是什么原因 ``` //加载动态库 static { System.loadLibrary("onap"); } public native boolean AnomalyDetectionJNI(String audioPath); ``` 程序挂死打印出: ``` Process finished with exit code -1073740791 (0xC0000409) ```

linux下使用JNA调用libopencv_java2413.so报错

(。so放在linux/user/lib下,环境变量已配好) 测试代码 import com.sun.jna.Library; import com.sun.jna.Native; public class Main1 { public interface Clibrary extends Library { Clibrary INSTANTCE = (Clibrary) Native.loadLibrary("opencv_java2413", Clibrary.class); long n_eye(int rows, int cols, int type); } public static void main(String[] args) { System.out.println(Clibrary.INSTANTCE.n_eye(3, 3, 2)); } } linux命令: java -cp /home/jna.jar:/home Main1 报错信息 Exception in thread "main" java.lang.UnsatisfiedLinkError: Unable to load librar y 'opencv_java2413': libavcodec.so.54: cannot open shared object file: No such f ile or directory at com.sun.jna.NativeLibrary.loadLibrary(NativeLibrary.java:164) at com.sun.jna.NativeLibrary.getInstance(NativeLibrary.java:237) at com.sun.jna.Library$Handler.<init>(Library.java:140) at com.sun.jna.Native.loadLibrary(Native.java:374) at com.sun.jna.Native.loadLibrary(Native.java:359) at Main1$Clibrary.<clinit>(Main1.java:9) at Main1.main(Main1.java:19)

java项目使用jni出错NoClassDefFoundError

Caused by: java.lang.NoClassDefFoundError: com.yhty.service.impl.other.GetOweInfoByTuxedo (initialization failure) at java.lang.J9VMInternals.initialize(J9VMInternals.java:134) at com.yhty.service.impl.other.PhonePaymentManagerImpl.getOweInfo(PhonePaymentManagerImpl.java:46) at sun.reflect.GeneratedMethodAccessor2060.invoke(Unknown Source) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:618) at org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:304) at org.springframework.aop.framework.ReflectiveMethodInvocation.invokeJoinpoint(ReflectiveMethodInvocation.java:182) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:149) at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:106) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:171) at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:204) at $Proxy315.getOweInfo(Unknown Source) at com.yhty.ws.impl.IplatformServiceManagerImpl.getOweInfo(IplatformServiceManagerImpl.java:1254) at sun.reflect.GeneratedMethodAccessor2059.invoke(Unknown Source) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:618) GetOweInfoByTuxedo声明native方法的类,在调用时出现上面异常信息,说是初始化错误,那位大神知道原因吗?纠结好长时间了。

定量遥感中文版 梁顺林著 范闻捷译

这是梁顺林的定量遥感的中文版,由范闻捷等翻译的,是电子版PDF,解决了大家看英文费时费事的问题,希望大家下载看看,一定会有帮助的

Java 最常见的 200+ 面试题:面试必备

这份面试清单是从我 2015 年做了 TeamLeader 之后开始收集的,一方面是给公司招聘用,另一方面是想用它来挖掘在 Java 技术栈中,还有那些知识点是我不知道的,我想找到这些技术盲点,然后修复它,以此来提高自己的技术水平。虽然我是从 2009 年就开始参加编程工作了,但我依旧觉得自己现在要学的东西很多,并且学习这些知识,让我很有成就感和满足感,那所以何乐而不为呢? 说回面试的事,这份面试...

机器学习初学者必会的案例精讲

通过六个实际的编码项目,带领同学入门人工智能。这些项目涉及机器学习(回归,分类,聚类),深度学习(神经网络),底层数学算法,Weka数据挖掘,利用Git开源项目实战等。

远程工具,免费

远程工具,免费

java jdk 8 帮助文档 中文 文档 chm 谷歌翻译

JDK1.8 API 中文谷歌翻译版 java帮助文档 JDK API java 帮助文档 谷歌翻译 JDK1.8 API 中文 谷歌翻译版 java帮助文档 Java最新帮助文档 本帮助文档是使用谷

csma/ca和csma/cd的matlab仿真源代码带有详细的注释

csma/ca和csma/cd的matlab仿真源代码带有详细的注释,载波侦听,随意设置节点数,带有炫酷的图形展示效果。

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

软件测试入门、SQL、性能测试、测试管理工具

软件测试2小时入门,让您快速了解软件测试基本知识,有系统的了解; SQL一小时,让您快速理解和掌握SQL基本语法 jmeter性能测试 ,让您快速了解主流来源性能测试工具jmeter 测试管理工具-禅道,让您快速学会禅道的使用,学会测试项目、用例、缺陷的管理、

pokemmo的资源

pokemmo必须的4个rom 分别为绿宝石 火红 心金 黑白 还有汉化补丁 资源不错哦 记得下载

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

无线通信中的智能天线:IS-95和第3代CDMA应用_.pdf

无线通信中的智能天线:IS-95和第3代CDMA应用_.pdf

设计模式(JAVA语言实现)--20种设计模式附带源码

课程亮点: 课程培训详细的笔记以及实例代码,让学员开始掌握设计模式知识点 课程内容: 工厂模式、桥接模式、组合模式、装饰器模式、外观模式、享元模式、原型模型、代理模式、单例模式、适配器模式 策略模式、模板方法模式、观察者模式、迭代器模式、责任链模式、命令模式、备忘录模式、状态模式、访问者模式 课程特色: 笔记设计模式,用笔记串连所有知识点,让学员从一点一滴积累,学习过程无压力 笔记标题采用关键字标识法,帮助学员更加容易记住知识点 笔记以超链接形式让知识点关联起来,形式知识体系 采用先概念后实例再应用方式,知识点深入浅出 提供授课内容笔记作为课后复习以及工作备查工具 部分图表(电脑PC端查看):

Java8零基础入门视频教程

这门课程基于主流的java8平台,由浅入深的详细讲解了java SE的开发技术,可以使java方向的入门学员,快速扎实的掌握java开发技术!

玩转Linux:常用命令实例指南

人工智能、物联网、大数据时代,Linux正有着一统天下的趋势,几乎每个程序员岗位,都要求掌握Linux。本课程零基础也能轻松入门。 本课程以简洁易懂的语言手把手教你系统掌握日常所需的Linux知识,每个知识点都会配合案例实战让你融汇贯通。课程通俗易懂,简洁流畅,适合0基础以及对Linux掌握不熟练的人学习; 【限时福利】 1)购课后按提示添加小助手,进答疑群,还可获得价值300元的编程大礼包! 2)本月购买此套餐加入老师答疑交流群,可参加老师的免费分享活动,学习最新技术项目经验。 --------------------------------------------------------------- 29元=掌握Linux必修知识+社群答疑+讲师社群分享会+700元编程礼包。 &nbsp;

极简JAVA学习营第四期(报名以后加助教微信:eduxy-1)

想学好JAVA必须要报两万的培训班吗? Java大神勿入 如果你: 零基础想学JAVA却不知道从何入手 看了一堆书和视频却还是连JAVA的环境都搭建不起来 囊中羞涩面对两万起的JAVA培训班不忍直视 在职没有每天大块的时间专门学习JAVA 那么恭喜你找到组织了,在这里有: 1. 一群志同道合立志学好JAVA的同学一起学习讨论JAVA 2. 灵活机动的学习时间完成特定学习任务+每日编程实战练习 3. 热心助人的助教和讲师及时帮你解决问题,不按时完成作业小心助教老师的家访哦 上一张图看看前辈的感悟: &nbsp; &nbsp; 大家一定迫不及待想知道什么是极简JAVA学习营了吧,下面就来给大家说道说道: 什么是极简JAVA学习营? 1. 针对Java小白或者初级Java学习者; 2. 利用9天时间,每天1个小时时间; 3.通过 每日作业 / 组队PK / 助教答疑 / 实战编程 / 项目答辩 / 社群讨论 / 趣味知识抢答等方式让学员爱上学习编程 , 最终实现能独立开发一个基于控制台的‘库存管理系统’ 的学习模式 极简JAVA学习营是怎么学习的? &nbsp; 如何报名? 只要购买了极简JAVA一:JAVA入门就算报名成功! &nbsp;本期为第四期极简JAVA学习营,我们来看看往期学员的学习状态: 作业看这里~ &nbsp; 助教的作业报告是不是很专业 不交作业打屁屁 助教答疑是不是很用心 &nbsp; 有奖抢答大家玩的很嗨啊 &nbsp; &nbsp; 项目答辩终于开始啦 &nbsp; 优秀者的获奖感言 &nbsp; 这是答辩项目的效果 &nbsp; &nbsp; 这么细致的服务,这么好的氛围,这样的学习效果,需要多少钱呢? 不要1999,不要199,不要99,只要9.9 是的你没听错,只要9.9以上所有就都属于你了 如果你: 1、&nbsp;想学JAVA没有基础 2、&nbsp;想学JAVA没有整块的时间 3、&nbsp;想学JAVA没有足够的预算 还等什么?赶紧报名吧,抓紧抢位,本期只招300人,错过只有等时间待定的下一期了 &nbsp; 报名请加小助手微信:eduxy-1 &nbsp; &nbsp;

Python数据清洗实战入门

本次课程主要以真实的电商数据为基础,通过Python详细的介绍了数据分析中的数据清洗阶段各种技巧和方法。

董付国老师Python全栈学习优惠套餐

购买套餐的朋友可以关注微信公众号“Python小屋”,上传付款截图,然后领取董老师任意图书1本。

linux下利用/proc进行进程树的打印

在linux下利用c语言实现的进程树的打印,主要通过/proc下的目录中的进程文件,获取status中的进程信息内容,然后利用递归实现进程树的打印

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

HoloLens2开发入门教程

本课程为HoloLens2开发入门教程,讲解部署开发环境,安装VS2019,Unity版本,Windows SDK,创建Unity项目,讲解如何使用MRTK,编辑器模拟手势交互,打包VS工程并编译部署应用到HoloLens上等。

150讲轻松搞定Python网络爬虫

【为什么学爬虫?】 &nbsp; &nbsp; &nbsp; &nbsp;1、爬虫入手容易,但是深入较难,如何写出高效率的爬虫,如何写出灵活性高可扩展的爬虫都是一项技术活。另外在爬虫过程中,经常容易遇到被反爬虫,比如字体反爬、IP识别、验证码等,如何层层攻克难点拿到想要的数据,这门课程,你都能学到! &nbsp; &nbsp; &nbsp; &nbsp;2、如果是作为一个其他行业的开发者,比如app开发,web开发,学习爬虫能让你加强对技术的认知,能够开发出更加安全的软件和网站 【课程设计】 一个完整的爬虫程序,无论大小,总体来说可以分成三个步骤,分别是: 网络请求:模拟浏览器的行为从网上抓取数据。 数据解析:将请求下来的数据进行过滤,提取我们想要的数据。 数据存储:将提取到的数据存储到硬盘或者内存中。比如用mysql数据库或者redis等。 那么本课程也是按照这几个步骤循序渐进的进行讲解,带领学生完整的掌握每个步骤的技术。另外,因为爬虫的多样性,在爬取的过程中可能会发生被反爬、效率低下等。因此我们又增加了两个章节用来提高爬虫程序的灵活性,分别是: 爬虫进阶:包括IP代理,多线程爬虫,图形验证码识别、JS加密解密、动态网页爬虫、字体反爬识别等。 Scrapy和分布式爬虫:Scrapy框架、Scrapy-redis组件、分布式爬虫等。 通过爬虫进阶的知识点我们能应付大量的反爬网站,而Scrapy框架作为一个专业的爬虫框架,使用他可以快速提高我们编写爬虫程序的效率和速度。另外如果一台机器不能满足你的需求,我们可以用分布式爬虫让多台机器帮助你快速爬取数据。 &nbsp; 从基础爬虫到商业化应用爬虫,本套课程满足您的所有需求! 【课程服务】 专属付费社群+每周三讨论会+1v1答疑

MySQL 8.0.19安装教程(windows 64位)

话不多说直接开干 目录 1-先去官网下载点击的MySQL的下载​ 2-配置初始化的my.ini文件的文件 3-初始化MySQL 4-安装MySQL服务 + 启动MySQL 服务 5-连接MySQL + 修改密码 先去官网下载点击的MySQL的下载 下载完成后解压 解压完是这个样子 配置初始化的my.ini文件的文件 ...

Python数据挖掘简易入门

&nbsp; &nbsp; &nbsp; &nbsp; 本课程为Python数据挖掘方向的入门课程,课程主要以真实数据为基础,详细介绍数据挖掘入门的流程和使用Python实现pandas与numpy在数据挖掘方向的运用,并深入学习如何运用scikit-learn调用常用的数据挖掘算法解决数据挖掘问题,为进一步深入学习数据挖掘打下扎实的基础。

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

网络工程师小白入门--【思科CCNA、华为HCNA等网络工程师认证】

本课程适合CCNA或HCNA网络小白同志,高手请绕道,可以直接学习进价课程。通过本预科课程的学习,为学习网络工程师、思科CCNA、华为HCNA这些认证打下坚实的基础! 重要!思科认证2020年2月24日起,已启用新版认证和考试,包括题库都会更新,由于疫情原因,请关注官网和本地考点信息。题库网络上很容易下载到。

Ubuntu18.04安装教程

Ubuntu18.04.1安装一、准备工作1.下载Ubuntu18.04.1 LTS2.制作U盘启动盘3.准备 Ubuntu18.04.1 的硬盘空间二、安装Ubuntu18.04.1三、安装后的一些工作1.安装输入法2.更换软件源四、双系统如何卸载Ubuntu18.04.1新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列...

sql语句 异常 Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your

在我们开发的工程中,有时候会报 [Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ------ 这种异常 不用多想,肯定是我们的sql语句出现问题,下面...

西南交通大学新秀杯数学建模试题

题目比较难,如果符合大家的口味欢迎大家下载哈,提高你的思维想象能力

Windows版YOLOv4目标检测实战:训练自己的数据集

课程演示环境:Windows10; cuda 10.2; cudnn7.6.5; Python3.7; VisualStudio2019; OpenCV3.4 需要学习ubuntu系统上YOLOv4的同学请前往:《YOLOv4目标检测实战:训练自己的数据集》 课程链接:https://edu.csdn.net/course/detail/28745 YOLOv4来了!速度和精度双提升! 与 YOLOv3 相比,新版本的 AP (精度)和 FPS (每秒帧率)分别提高了 10% 和 12%。 YOLO系列是基于深度学习的端到端实时目标检测方法。本课程将手把手地教大家使用labelImg标注和使用YOLOv4训练自己的数据集。课程实战分为两个项目:单目标检测(足球目标检测)和多目标检测(足球和梅西同时检测)。 本课程的YOLOv4使用AlexyAB/darknet,在Windows系统上做项目演示。包括:安装软件环境、安装YOLOv4、标注自己的数据集、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算)和先验框聚类分析。还将介绍改善YOLOv4目标检测性能的技巧。 除本课程《Windows版YOLOv4目标检测实战:训练自己的数据集》外,本人将推出有关YOLOv4目标检测的系列课程。请持续关注该系列的其它视频课程,包括: 《Windows版YOLOv4目标检测实战:人脸口罩佩戴检测》 《Windows版YOLOv4目标检测实战:中国交通标志识别》 《Windows版YOLOv4目标检测:原理与源码解析》

Spring Boot -01- 快速入门篇(图文教程)

Spring Boot -01- 快速入门篇 今天开始不断整理 Spring Boot 2.0 版本学习笔记,大家可以在博客看到我的笔记,然后大家想看视频课程也可以到【慕课网】手机 app,去找【Spring Boot 2.0 深度实践】的课程,令人开心的是,课程完全免费! 什么是 Spring Boot? Spring Boot 是由 Pivotal 团队提供的全新框架。Spring Boot...

相关热词 c# 解析cad c#数字格式化万 c#int转byte c#格式化日期 c# wpf 表格 c# 实现ad域验证登录 c#心跳包机制 c#使用fmod.dll c#dll vb 调用 c# outlook
立即提问
相关内容推荐