将工做中,或者看书的过程当中碰到的本身以前没有掌握的知识点进行概括,暂时就碰到什么写什么,后续有必定量的话进行整理;java
1. list实现程序员
相关文章:https://zhuanlan.zhihu.com/p/24730576?refer=dreawer编程
1 LinkedList<String> list = new LinkedList<String>(); 2 list.addFirst("aaa"); //将元素添加到链表集合最前面 3 list.pollFirst() ; //获取并移除此列表的第一个元素;若是此列表为空,则返回 null。 4 list.pollLast() ; //获取并移除此列表的最后一个元素;若是此列表为空,则返回 null。 5 list.remove(int index) ; //移除此列表中指定位置处的元素。 6 list.remove(Object o) ; //今后列表中移除首次出现的指定元素(若是存在)。 7 list.add("bbb"); //在链表末尾增长元素 8 list.add(int index, E element) ; //在此列表中指定的位置插入指定的元素。 9 list.set(int index, E element) ; // 将此列表中指定位置的元素替换为指定的元素。 10 11 12 13 重点:LinkedList 和List 是两个类,等号前面须要注意是LinkedList 不能是List
2. native关键字 以及在java中调用其余语言代码安全
native关键字说明其修饰的方法是一个原生态方法,方法对应的实现不是在当前文件,而是在用其余语言(如C和C++)实现的文件中。Java语言自己不能对操做系统底层进行访问和操做,可是能够经过JNI接口调用其余语言来实现对底层的访问。 JNI是Java本机接口(Java Native Interface),是一个本机编程接口,它是Java软件开发工具箱(Java Software Development Kit,SDK)的一部分。JNI容许Java代码使用以其余语言编写的代码和代码库。Invocation API(JNI的一部分)能够用来将Java虚拟机(JVM)嵌入到本机应用程序中,从而容许程序员从本机代码内部调用Java代码。 不过,对Java外部的调用一般不能移植到其余平台,在applet中还可能引起安全异常。实现本地代码将使您的Java应用程序没法经过100%纯Java测试。可是,若是必须执行本地调用,则要考虑几个准则: 1.将您的全部本地方法都封装到一个类中,这个类调用单个的DLL。对每一种目标操做系统平台,均可以用特定于适当平台的版本的DLL。这样能够将本地代码的影响减小到最小,并有助于将之后所须要的移植问题考虑在内。 2.本地方法尽可能简单。尽可能使您的本地方法对第三方(包括Microsoft)运行时DLL的依赖减小到最小。使您的本地方法尽可能独立,以将加载您的DLL和应用程序所需的开销减小到最小。若是须要运行时DLL,必须随应用程序一块儿提供。 JNI的书写步骤以下: a.编写带有native声明的方法的Java类 b.使用javac命令编译编写的Java类 c.使用java -jni ****来生成后缀名为.h的头文件 d.使用其余语言(C、C++)实现本地方法 e.将本地方法编写的文件生成动态连接库 如下是一个在Java中调用本地C程序的简单的例子: a.编写HelloWorld.java类 class HelloWorld{ public native void hello(); static{ System.loadLibrary("hello"); } public static void main(String[] args){ new HelloWorld().hello(); } } b.编译 javac HelloWorld.java c.生成.h文件 javah -jni HelloWorld 生成内容以下: /* 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: hello * Signature: ()V */ JNIEXPORT void JNICALL Java_HelloWorld_hello (JNIEnv *, jobject); #ifdef __cplusplus } #endif #endif 第一个参数是调用JNI方法时使用的JNI Environment指针。第二个参数是指向在此Java代码中实例化的Java对象HelloWorld的一个句柄。其余参数是方法自己的参数 d.c实现 #include <jni.h> #include "HelloWorld.h" #include <stdio.h> JNIEXPORT void JNICALL Java_HelloWorld_hello(JNIEnv *env,jobject obj){ printf("Hello World!\n"); return; } 其中,第一行是将jni.h文件引入(在%JAVA_HOME%\include目录下),里边有JNIEnv和jobject的定义。 e.编译c实现 这里以在Windows中为例,须要生成dll文件。在保存HelloWorldImpl.c文件夹下面,使用VC的编译器cl成。 cl -I%java_home%\include -I%java_home%\include\win32 -LD HelloWorldImp.c -Fehello.dll 注意:生成的dll文件名在选项-Fe后面配置,这里是hello,由于在HelloWorld.java文件中咱们loadLibary的时候使用的名字是hello。固然这里修改以后那里也须要修改。另外须要将-I%java_home%\include -I%java_home%\include\win32参数加上,由于在第四步里面编写本地方法的时候引入了jni.h文件。 6) 运行程序 java HelloWorld就ok了!
3.查看JVM可优化参数 《LINUX下使用》app
java -server -Xmx1024m -Xms1024m -XX:+UseConcMarkSweepGC -XX:+PrintFlagsFinal -version| grep ParallelGCThreads
结果:
Java HotSpot(TM) 64-Bit Server VM warning: INFO: os::commit_memory(0x00000000c5330000, 986513408, 0) failed; error='Cannot allocate memory' (errno=12)工具
4.研究【阿里巴巴开发手册】以后看到的开发工具
对于 Integer var=?在-128 至 127 之间的赋值,Integer 对象是在 IntegerCache.cache 产生,会复用已有对象,这个区间内的 Integer 值能够直接使用==进行判断,可是这个区间之 外的全部数据,都会在堆上产生,并不会复用已有对象,这是一个大坑,推荐使用 equals 方 法进行判断。