首页 文章 精选 留言 我的

精选列表

搜索[Eclipse],共2962篇文章
优秀的个人博客,低调大师

Eclipse OpenJ9 v0.21.0 发布,Java 虚拟机

OpenJ9 v0.21.0 已发布,OpenJ9 是一款性能良好的 Java 虚拟机,并且有着强大的社区支持。与旧版本相比,此版本修复了不少问题并改进功能。 OpenJ9 v0.21 继续提供为 OpenJDK 8、11 和 14 而构建的二进制文件。此版本不仅修复了许多错误,而且还进行了许多性能方面的改进。性能方面,其 AArch64 JIT 编译器有望在各种应用程序上实现至少 20% 的吞吐量改进,此外还有部分改进使 OpenJ9 在容器中运行时表现得更加稳定。 自今年早些时候发布 OpenJ9 v0.20 以来,在 v0.21 中还看到了部分针对 POWER 的修复、和 x86 相关的工作以及常见的数百项其他更改。 下载地址和详细更新说明点此查看。

优秀的个人博客,低调大师

08.Eclipse下Ndk开发(使用fmod实现QQ变声功能)

(创建于2017/12/30) 1.编写native package org.fmod.example; public class EffectUtils { //音效的类型 public static final int MODE_NORMAL = 0; public static final int MODE_LUOLI = 1; public static final int MODE_DASHU = 2; public static final int MODE_JINGSONG = 3; public static final int MODE_GAOGUAI = 4; public static final int MODE_KONGLING = 5; /** * 音效处理 * @param path * @param type */ public native static void fix(String path,int type); static{ System.loadLibrary("fmodL"); System.loadLibrary("fmod"); System.loadLibrary("qq_voice"); } } 2.进入src目录下,使用命令行生成头文件 javah 包名+类名 3.创建项目根目录下jni文件夹,将头文件拷贝进去 4.下载fmod源码,复制api中lowlevel中的inc中的头文件到jni目录下 5.复制fmod jar包到根目录下libs文件夹并添加依赖 6.复制需要的api平台的so文件到jni目录下 7.修改报错的地方,比如头文件的路径等问题 8.Android Tools -> Add native support 添加本地支持(在此之前,确认你的项目中已经配置了ndk相关的头文件目录支持,参考前边的笔记),填写你要生成的 so库的文件名,确认和loadLibrary中加载的(如qq_voice)保持一致 9.配置mk文件: Android.mk LOCAL_PATH := $(call my-dir) //编译libfmod.so include $(CLEAR_VARS) LOCAL_MODULE := fmod LOCAL_SRC_FILES := libfmod.so include $(PREBUILT_SHARED_LIBRARY) //编译libfmodL.so include $(CLEAR_VARS) LOCAL_MODULE := fmodL LOCAL_SRC_FILES := libfmodL.so include $(PREBUILT_SHARED_LIBRARY) //编译我们自己写的c代码为so文件,并添加上边编译的so支持 include $(CLEAR_VARS) LOCAL_MODULE := qq_voice LOCAL_SRC_FILES := effect_fix.cpp LOCAL_SHARED_LIBRARIES := fmod fmodL //添加log支持 LOCAL_LDLIBS := -llog //添加c++异常类支持 LOCAL_CPP_FEATURES := exceptions include $(BUILD_SHARED_LIBRARY) Application.mk ##支持C++异常处理,标准莫板块(针对string.h等头文件的处理,去掉了common.c之后,这个不再需要了,但是保留也没问题) APP_STL := gnustl_static 10.不断的build project,直到所有异常解决编译成功 部分源码: effect_fix.cpp #include "org_fmod_example_EffectUtils.h" #include "inc/fmod.hpp" #include <stdlib.h> #include <unistd.h> #include <android/log.h> #define LOGI(FORMAT,...) __android_log_print(ANDROID_LOG_INFO,"renzhenming",FORMAT,##__VA_ARGS__) #define LOGE(FORMAT,...) __android_log_print(ANDROID_LOG_ERROR,"renzhenming",FORMAT,##__VA_ARGS__) #define MODE_NORMAL 0 #define MODE_LUOLI 1 #define MODE_DASHU 2 #define MODE_JINGSONG 3 #define MODE_GAOGUAI 4 #define MODE_KONGLING 5 using namespace FMOD; JNIEXPORT void JNICALL Java_org_fmod_example_EffectUtils_fix (JNIEnv *env, jclass jcls, jstring path_jstr, jint type){ System *system; FMOD_RESULT result; Sound *sound; Channel *channel; DSP *dsp; float frequency = 0; bool isPlaying = true; const char *media_path = env->GetStringUTFChars(path_jstr,NULL); try { //初始化 result = System_Create(&system); result = system->init(32, FMOD_INIT_NORMAL, NULL); //创建声音 //这里进坑了,写作下边的样子是无法播放的,正确的方式是第二行 因为sound如果是null,那么,播放的时候的sound也就是null,怎么播放呢 //result = system->createSound(media_path, FMOD_DEFAULT, 0, NULL); LOGI("%s",media_path); system->createSound(media_path, FMOD_DEFAULT, NULL, &sound); switch(type){ case MODE_NORMAL: //原生播放 result = system->playSound(sound, 0, false, &channel); break; case MODE_LUOLI: //dsp -- 音效 //FMOD_DSP_TYPE_PITCHSHIFT 提升或者降低音调用的一种音效 system->createDSPByType(FMOD_DSP_TYPE_PITCHSHIFT,&dsp); //设置音调的参数 dsp->setParameterFloat(FMOD_DSP_PITCHSHIFT_PITCH,2); //播放(播放和添加channel的顺序必须是先播放,再添加,否则音效无法生效) //猜测原因 //playSound之后并不是立即播放,而是在system->update();之后开始播放, //playSound的作用是创造了一个sound载体一个channel载体,然后在这个载体基础上添加一系列的效果,所以,只能现有载体 //效果才有放置的位置,所以需要先play再添加 result = system->playSound(sound, 0, false, &channel); //添加到channel channel->addDSP(0,dsp); break; case MODE_DASHU: //dsp -- 音效 //FMOD_DSP_TYPE_PITCHSHIFT 提升或者降低音调用的一种音效 system->createDSPByType(FMOD_DSP_TYPE_PITCHSHIFT,&dsp); //设置音调的参数 dsp->setParameterFloat(FMOD_DSP_PITCHSHIFT_PITCH,0.6); //播放(播放和添加channel的顺序必须是先播放,再添加,否则音效无法生效) result = system->playSound(sound, 0, false, &channel); //添加到channel channel->addDSP(0,dsp); break; case MODE_GAOGUAI: //提高说话的速度 result = system->playSound(sound, 0, false, &channel); channel->getFrequency(&frequency);\ frequency = frequency*1.5; channel->setFrequency(frequency); break; case MODE_KONGLING: system->createDSPByType(FMOD_DSP_TYPE_ECHO,&dsp); dsp->setParameterFloat(FMOD_DSP_ECHO_DELAY,300); dsp->setParameterFloat(FMOD_DSP_ECHO_FEEDBACK,2); result = system->playSound(sound, 0, false, &channel); channel->addDSP(0,dsp); break; case MODE_JINGSONG: //紧张 system->createDSPByType(FMOD_DSP_TYPE_ECHO,&dsp); dsp->setParameterFloat(FMOD_DSP_TREMOLO_SKEW,0.5); result = system->playSound(sound, 0, false, &channel); channel->addDSP(0,dsp); break; default: break; } while(isPlaying){ channel->isPlaying(&isPlaying); //<unistd.h> //单位微秒,不断的睡眠保证声音播放完成之后再释放资源 usleep(1000*1000); } LOGI("%s","播放完成"); system->update(); } catch(...){ LOGE("%s","发生异常"); goto end; } goto end; end: env->ReleaseStringUTFChars(path_jstr,media_path); result = sound->release(); system->close(); system->release(); } QQActivity.java package org.fmod.example; import java.io.File; import com.renzhenming.qq_voice.R; import android.app.Activity; import android.os.Bundle; import android.os.Environment; import android.util.Log; import android.view.View; public class QQActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); org.fmod.FMOD.init(this); setContentView(R.layout.activity_main); } public void mFix(View view){ String path = Environment.getExternalStorageDirectory().getAbsolutePath() + File.separatorChar + "singing.wav"; Log.d("renzhenming", path); switch (view.getId()) { case R.id.btn_record: EffectUtils.fix(path, EffectUtils.MODE_NORMAL); Log.d("renzhenming", "MODE_NORMAL"); break; case R.id.btn_luoli: EffectUtils.fix(path, EffectUtils.MODE_LUOLI); Log.d("renzhenming", "MODE_LUOLI"); break; case R.id.btn_dashu: EffectUtils.fix(path, EffectUtils.MODE_DASHU); Log.d("renzhenming", "MODE_DASHU"); break; case R.id.btn_jingsong: EffectUtils.fix(path, EffectUtils.MODE_JINGSONG); break; case R.id.btn_gaoguai: EffectUtils.fix(path, EffectUtils.MODE_GAOGUAI); break; case R.id.btn_kongling: EffectUtils.fix(path, EffectUtils.MODE_KONGLING); break; default: break; } } @Override protected void onDestroy(){ org.fmod.FMOD.close(); super.onDestroy(); } } EffectUtils.java package org.fmod.example; public class EffectUtils { //音效的类型 public static final int MODE_NORMAL = 0; public static final int MODE_LUOLI = 1; public static final int MODE_DASHU = 2; public static final int MODE_JINGSONG = 3; public static final int MODE_GAOGUAI = 4; public static final int MODE_KONGLING = 5; /** * 音效处理 * @param path * @param type */ public native static void fix(String path,int type); static{ System.loadLibrary("fmodL"); System.loadLibrary("fmod"); System.loadLibrary("qq_voice"); } } 程序运行界面 18404062.png

优秀的个人博客,低调大师

20.Eclipse下Ndk开发(pthread开启线程调用Java方法)

本项目最终的目的是在pthread线程中,调用Java一个工具类得到多个uuid,然后调用类中另一个方法弹出toast,实现在c中获取安卓上下文对象Context 编译native方法,生成头文件的一系列过程不再赘述,直接上代码,都在注释中 PosixUtils: package com.example.ndk_pthread; public class PosixUtils { static{ System.loadLibrary("ndk_pthread"); } /** * pthread开启子线程前的一些初始化操作,比如获取本类的jclass对象,生成需要的 * 全局引用等等,在子线程中无法获取到类的jclass对象,就是这行代码,获取class必须要在主线程中 * jclass uuidutils_class_tmp = (*env)->FindClass(env,"com/example/ndk_pthread/UUIDUtils"); */ public native void init(); /** * 执行一些善后的操作,比如init方法中生成的全局引用的销毁等等 */ public native void destroy(); /** * 子线程操作 */ public native void pthread(); } UUIDUtils: package com.example.ndk_pthread; import java.util.UUID; import android.content.Context; import android.widget.Toast; public class UUIDUtils { public static String get(){ return UUID.randomUUID().toString(); } public static void showToast(Context context){ Toast.makeText(context, "c端弹出了toast", 0).show(); } } 编译生成的头文件com_example_ndk_pthread_UUIDUtils.h: package com.example.ndk_pthread; import java.util.UUID; import android.content.Context; import android.widget.Toast; public class UUIDUtils { public static String get(){ return UUID.randomUUID().toString(); } public static void showToast(Context context){ Toast.makeText(context, "c端弹出了toast", 0).show(); } } MainActivity: package com.example.ndk_pthread; import android.app.Activity; import android.os.Bundle; import android.util.Log; import android.view.Menu; import android.view.MenuItem; import android.view.View; public class MainActivity extends Activity { private PosixUtils p; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); p = new PosixUtils(); p.init(); } public void start(View btn){ p.pthread(); } @Override protected void onDestroy() { super.onDestroy(); //页面销毁时同时销毁c端的一些东西 p.destroy(); } } ndk_pthread.c #include "com_example_ndk_pthread_PosixUtils.h" #include <stdio.h> #include <pthread.h> #include <android/log.h> #include <unistd.h> #define LOGI(FORMAT,...) __android_log_print(ANDROID_LOG_INFO,"renzhenming",FORMAT,##__VA_ARGS__); #define LOGE(FORMAT,...) __android_log_print(ANDROID_LOG_ERROR,"renzhenming",FORMAT,##__VA_ARGS__); JavaVM *javaVM; jobject uuidutils_jcls; jmethodID get_mid; jmethodID toastId; jobject jcontext; //动态库加载时会被调用执行,不需要我们手动调用 //兼容Android SDK 2.2之后,2.2没有这个函数 JNIEXPORT jint JNI_OnLoad(JavaVM* vm, void* reserved){ LOGI("%s","JNI_OnLoad"); javaVM = vm; return JNI_VERSION_1_4; } /** * 目标:调用UUIDUtils类中的方法得到一个uuid */ void thread_fun(void* arg){ //得到这个类UUIDUtils,需要用到JNIEnv,但是这是一个子线程,每个线程都有独立的JNIEnv,所以我们需要获取到 //这个线程的JNIEnv,通过JavaVM关联当前线程,获取当前线程的JNIEnv,(*javaVM)->AttachCurrentThread(javaVM,&env,NULL); //那么就需要先获取到JavaVM //如何获取JavaVM? //1.在JNI_OnLoad函数中获取 //2.(*env)->GetJavaVM(env,&javaVM); //的到JavaVM后,会得到env并赋值给变量 JNIEnv* env = NULL; (*javaVM)->AttachCurrentThread(javaVM,&env,NULL); char* no = (char*)arg; int i; for (i = 0; i < 5; ++i) { LOGI("thread %s, i:%d",no,i); jobject uuid = (*env)->CallStaticObjectMethod(env,uuidutils_jcls,get_mid); char* uuid_char = (*env)->GetStringUTFChars(env,uuid,NULL); LOGI("%s",uuid_char); if(i == 4){ goto end; } (*env)->ReleaseStringUTFChars(env,uuid,uuid_char); sleep(1); } end: //如果直接将这两行写在循环之后是有问题的,当i=4的时候,线程直接退出,导致没有执行DetachCurrentThread,报异常 (*javaVM)->DetachCurrentThread(javaVM); pthread_exit((void*)0); } /** * 当在JNI调用Android自带的类时,经常需要传入Context参数,那怎么在JNI层获取Context呢? * 我们知道Application和Activity是Context的子类,由于每个Activity对应的Context是不一样的, * 所以一般情况下我们使用Application的Context,它在整个程序中只有一个实例。所以现在问题就变成了 * 怎么在JNI中获取Application呢? * Android APP在启动时会创建一个Activity Thread作为主线程,只要程序存活,这个线程就一直存在, * 所以我们可以考虑从Activity Thread中获取Application,查看Activity Thread的源码发现, * 它提供了一个方法可以获取Application,如下: * * public Application getApplication() { * return mInitialApplication; * } * * 也就是说我们只需要获取到Activity Thread的对象即可,Activity Thread提供了一个静态方法用于获取其实例,如下: * * public static ActivityThread currentActivityThread() { * return sCurrentActivityThread; * } * * 至此获取Context的步骤已经很清晰了 */ JNIEXPORT void JNICALL Java_com_example_ndk_1pthread_PosixUtils_init (JNIEnv *env, jobject jobj){ /** * 打印uuid */ //获取class必须要在主线程中 jclass uuidutils_class_tmp = (*env)->FindClass(env,"com/example/ndk_pthread/UUIDUtils"); //创建全局引用 uuidutils_jcls = (*env)->NewGlobalRef(env,uuidutils_class_tmp); //获取jmethodId也可以在子线程中 get_mid = (*env)->GetStaticMethodID(env,uuidutils_jcls,"get","()Ljava/lang/String;"); /** * show toast */ //获取jmethodId也可以在子线程中 toastId = (*env)->GetStaticMethodID(env,uuidutils_jcls,"showToast","(Landroid/content/Context;)V"); //获取Activity Thread的实例对象 jclass activityThread = (*env)->FindClass(env,"android/app/ActivityThread"); jmethodID currentActivityThread = (*env)->GetStaticMethodID(env,activityThread, "currentActivityThread", "()Landroid/app/ActivityThread;"); jobject at = (*env)->CallStaticObjectMethod(env,activityThread, currentActivityThread); //获取Application,也就是全局的Context jmethodID getApplication = (*env)->GetMethodID(env,activityThread, "getApplication", "()Landroid/app/Application;"); jobject context = (*env)->CallObjectMethod(env,at, getApplication); jcontext = (*env)->NewGlobalRef(env,context); } JNIEXPORT void JNICALL Java_com_example_ndk_1pthread_PosixUtils_destroy (JNIEnv *env, jobject jobj){ //释放全局引用 (*env)->DeleteGlobalRef(env,uuidutils_jcls); } JNIEXPORT void JNICALL Java_com_example_ndk_1pthread_PosixUtils_pthread (JNIEnv *env, jobject jobj){ LOGI("%s","begin"); //获取JavaVM的第一种方式,本项目中我们采用在JNI_OnLoad中获取的方式 //(*env)->GetJavaVM(env,&javaVM); pthread_t tid; pthread_create(&tid,NULL,thread_fun,(void*)"NO1"); //调用Java函数show toast (*env)->CallStaticVoidMethod(env,uuidutils_jcls,toastId,jcontext); } Android.mk LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) LOCAL_MODULE := ndk_pthread LOCAL_SRC_FILES := ndk_pthread.c LOCAL_LDLIBS := -llog include $(BUILD_SHARED_LIBRARY)

优秀的个人博客,低调大师

eclipse使用hadoop插件出现java.lang.OutOfMemoryError: Java heap space

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 14 / 09 / 20 22 : 41 : 13 WARNutil.NativeCodeLoader:Unabletoload native -hadooplibrary for yourplatform...usingbuiltin-javaclasseswhereapplicable 14 / 09 / 20 22 : 41 : 13 WARNmapred.JobClient:UseGenericOptionsParser for parsingthearguments.ApplicationsshouldimplementTool for thesame. 14 / 09 / 20 22 : 41 : 13 INFOinput.FileInputFormat:Totalinputpathstoprocess: 2 14 / 09 / 20 22 : 41 : 14 WARNsnappy.LoadSnappy:Snappy native librarynotloaded 14 / 09 / 20 22 : 41 : 14 INFOmapred.JobClient:Runningjob:job_local911496586_0001 14 / 09 / 20 22 : 41 : 14 INFOmapred.LocalJobRunner:Waiting for maptasks 14 / 09 / 20 22 : 41 : 14 INFOmapred.LocalJobRunner:Startingtask:attempt_local911496586_0001_m_000000_0 14 / 09 / 20 22 : 41 : 14 INFOmapred.Task:UsingResourceCalculatorPlugin: null 14 / 09 / 20 22 : 41 : 14 INFOmapred.MapTask:Processingsplit:hdfs: //192.168.1.112:9000/txt/yw/mic.php:0+338124 14 / 09 / 20 22 : 41 : 14 INFOmapred.MapTask:io.sort.mb= 100 14 / 09 / 20 22 : 41 : 14 INFOmapred.LocalJobRunner:Startingtask:attempt_local911496586_0001_m_000001_0 14 / 09 / 20 22 : 41 : 14 INFOmapred.Task:UsingResourceCalculatorPlugin: null 14 / 09 / 20 22 : 41 : 14 INFOmapred.MapTask:Processingsplit:hdfs: //192.168.1.112:9000/txt/yw/pip.txt:0+96393 14 / 09 / 20 22 : 41 : 14 INFOmapred.MapTask:io.sort.mb= 100 14 / 09 / 20 22 : 41 : 14 INFOmapred.LocalJobRunner:Maptaskexecutorcomplete. 14 / 09 / 20 22 : 41 : 14 WARNmapred.LocalJobRunner:job_local911496586_0001 java.lang.Exception:java.lang.OutOfMemoryError:Javaheapspace atorg.apache.hadoop.mapred.LocalJobRunner$Job.run(LocalJobRunner.java: 354 ) Causedby:java.lang.OutOfMemoryError:Javaheapspace atorg.apache.hadoop.mapred.MapTask$MapOutputBuffer.<init>(MapTask.java: 954 ) atorg.apache.hadoop.mapred.MapTask$NewOutputCollector.<init>(MapTask.java: 673 ) atorg.apache.hadoop.mapred.MapTask.runNewMapper(MapTask.java: 756 ) atorg.apache.hadoop.mapred.MapTask.run(MapTask.java: 364 ) atorg.apache.hadoop.mapred.LocalJobRunner$Job$MapTaskRunnable.run(LocalJobRunner.java: 223 ) atjava.util.concurrent.Executors$RunnableAdapter.call(Executors.java: 441 ) atjava.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java: 303 ) atjava.util.concurrent.FutureTask.run(FutureTask.java: 138 ) atjava.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java: 886 ) atjava.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java: 908 ) atjava.lang.Thread.run(Thread.java: 619 ) 14 / 09 / 20 22 : 41 : 15 INFOmapred.JobClient:map 0 %reduce 0 % 14 / 09 / 20 22 : 41 : 15 INFOmapred.JobClient:Jobcomplete:job_local911496586_0001 14 / 09 / 20 22 : 41 : 15 INFOmapred.JobClient:Counters: 0 解决: 本文转自 梦朝思夕 51CTO博客,原文链接:http://blog.51cto.com/qiangmzsx/1556392

资源下载

更多资源
优质分享App

优质分享App

近一个月的开发和优化,本站点的第一个app全新上线。该app采用极致压缩,本体才4.36MB。系统里面做了大量数据访问、缓存优化。方便用户在手机上查看文章。后续会推出HarmonyOS的适配版本。

Mario

Mario

马里奥是站在游戏界顶峰的超人气多面角色。马里奥靠吃蘑菇成长,特征是大鼻子、头戴帽子、身穿背带裤,还留着胡子。与他的双胞胎兄弟路易基一起,长年担任任天堂的招牌角色。

Rocky Linux

Rocky Linux

Rocky Linux(中文名:洛基)是由Gregory Kurtzer于2020年12月发起的企业级Linux发行版,作为CentOS稳定版停止维护后与RHEL(Red Hat Enterprise Linux)完全兼容的开源替代方案,由社区拥有并管理,支持x86_64、aarch64等架构。其通过重新编译RHEL源代码提供长期稳定性,采用模块化包装和SELinux安全架构,默认包含GNOME桌面环境及XFS文件系统,支持十年生命周期更新。

Sublime Text

Sublime Text

Sublime Text具有漂亮的用户界面和强大的功能,例如代码缩略图,Python的插件,代码段等。还可自定义键绑定,菜单和工具栏。Sublime Text 的主要功能包括:拼写检查,书签,完整的 Python API , Goto 功能,即时项目切换,多选择,多窗口等等。Sublime Text 是一个跨平台的编辑器,同时支持Windows、Linux、Mac OS X等操作系统。