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

在spring boot中使用JNI集成第三方so文件,通过
java -XX:+UnlockDiagnosticVMOptions -XX:+VerifyBeforeGC -XX:+VerifyAfterGC -jar xxxxx.jar运行,在调用第三方so文件时出现crash,导致程序退出
图片说明
下面是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

8个回答

 ---------------  P R O C E S S  ---------------

Java Threads: ( => current thread )
  0x00007ff1300d7800 JavaThread "I/O dispatcher 32" [_thread_in_native, id=17603, stack(0x00007ff0ffbfc000,0x00007ff0ffcfd000)]
  0x00007ff1300d5800 JavaThread "I/O dispatcher 31" [_thread_in_native, id=17602, stack(0x00007ff0ffcfd000,0x00007ff0ffdfe000)]
  0x00007ff1300d3800 JavaThread "I/O dispatcher 30" [_thread_in_native, id=17601, stack(0x00007ff0ffdfe000,0x00007ff0ffeff000)]
  0x00007ff1300d1800 JavaThread "I/O dispatcher 29" [_thread_in_native, id=17600, stack(0x00007ff0ffeff000,0x00007ff100000000)]
  0x00007ff1300cf800 JavaThread "I/O dispatcher 28" [_thread_in_native, id=17599, stack(0x00007ff1740d4000,0x00007ff1741d5000)]
  0x00007ff1300ce000 JavaThread "I/O dispatcher 27" [_thread_in_native, id=17598, stack(0x00007ff1741d5000,0x00007ff1742d6000)]
  0x00007ff1300cc000 JavaThread "I/O dispatcher 26" [_thread_in_native, id=17597, stack(0x00007ff1742d6000,0x00007ff1743d7000)]
  0x00007ff1300ca800 JavaThread "I/O dispatcher 25" [_thread_in_native, id=17596, stack(0x00007ff1743d7000,0x00007ff1744d8000)]
  0x00007ff1282f0000 JavaThread "Thread-12" daemon [_thread_blocked, id=17595, stack(0x00007ff1744d8000,0x00007ff1745d9000)]
  0x00007ff1282ef800 JavaThread "pool-8-thread-1" [_thread_in_native, id=17594, stack(0x00007ff1745d9000,0x00007ff1746da000)]
  0x00007ff128004000 JavaThread "process reaper" daemon [_thread_blocked, id=17500, stack(0x00007ff21c02b000,0x00007ff21c064000)]
  0x00007ff128001000 JavaThread "Thread-11" [_thread_blocked, id=17489, stack(0x00007ff1749db000,0x00007ff1753dc000)]
  0x00007ff158004800 JavaThread "pool-2-thread-2" [_thread_in_native, id=17467, stack(0x00007ff1746da000,0x00007ff1747db000)]
  0x00007ff164a34000 JavaThread "pool-2-thread-1" [_thread_blocked, id=17411, stack(0x00007ff1753dc000,0x00007ff1754dd000)]
  0x00007ff10c0d5800 JavaThread "I/O dispatcher 24" [_thread_in_native, id=17410, stack(0x00007ff1754dd000,0x00007ff1755de000)]
  0x00007ff10c0d4000 JavaThread "I/O dispatcher 23" [_thread_in_native, id=17409, stack(0x00007ff1755de000,0x00007ff1756df000)]
  0x00007ff10c0d2000 JavaThread "I/O dispatcher 22" [_thread_in_native, id=17408, stack(0x00007ff1756df000,0x00007ff1757e0000)]
  0x00007ff10c0d0000 JavaThread "I/O dispatcher 21" [_thread_in_native, id=17407, stack(0x00007ff1757e0000,0x00007ff1758e1000)]
  0x00007ff10c0ce800 JavaThread "I/O dispatcher 20" [_thread_in_native, id=17406, stack(0x00007ff1758e1000,0x00007ff1759e2000)]
  0x00007ff10c0cc800 JavaThread "I/O dispatcher 19" [_thread_in_native, id=17405, stack(0x00007ff1759e2000,0x00007ff175ae3000)]
  0x00007ff10c0cb000 JavaThread "I/O dispatcher 18" [_thread_in_native, id=17404, stack(0x00007ff175ae3000,0x00007ff175be4000)]
  0x00007ff10c0c9000 JavaThread "I/O dispatcher 17" [_thread_in_native, id=17403, stack(0x00007ff175be4000,0x00007ff175ce5000)]
  0x00007ff164975000 JavaThread "Thread-9" daemon [_thread_blocked, id=17402, stack(0x00007ff175ce5000,0x00007ff175de6000)]
  0x00007ff164974000 JavaThread "pool-7-thread-1" [_thread_in_native, id=17401, stack(0x00007ff175de6000,0x00007ff175ee7000)]
  0x00007ff22c008800 JavaThread "DestroyJavaVM" [_thread_blocked, id=17315, stack(0x00007ff235bea000,0x00007ff235ceb000)]
  0x00007ff22d723800 JavaThread "Thread-8" [_thread_blocked, id=17387, stack(0x00007ff1760e7000,0x00007ff1761e8000)]
  0x00007ff22ce20000 JavaThread "grpc-default-boss-ELG-1-1" daemon [_thread_in_native, id=17386, stack(0x00007ff1761e8000,0x00007ff1762e9000)]
  0x00007ff13c0d7000 JavaThread "I/O dispatcher 16" [_thread_in_native, id=17385, stack(0x00007ff1766e9000,0x00007ff1767ea000)]
  0x00007ff13c0d5000 JavaThread "I/O dispatcher 15" [_thread_in_native, id=17384, stack(0x00007ff1767ea000,0x00007ff1768eb000)]
  0x00007ff13c0d3800 JavaThread "I/O dispatcher 14" [_thread_in_native, id=17383, stack(0x00007ff1768eb000,0x00007ff1769ec000)]
  0x00007ff13c0d1800 JavaThread "I/O dispatcher 13" [_thread_in_native, id=17382, stack(0x00007ff1769ec000,0x00007ff176aed000)]
  0x00007ff13c0d0000 JavaThread "I/O dispatcher 12" [_thread_in_native, id=17381, stack(0x00007ff176aed000,0x00007ff176bee000)]
  0x00007ff13c0ce000 JavaThread "I/O dispatcher 11" [_thread_in_native, id=17380, stack(0x00007ff176bee000,0x00007ff176cef000)]
  0x00007ff13c0cc000 JavaThread "I/O dispatcher 10" [_thread_in_native, id=17379, stack(0x00007ff176cef000,0x00007ff176df0000)]
  0x00007ff13c001800 JavaThread "I/O dispatcher 9" [_thread_in_native, id=17378, stack(0x00007ff176df0000,0x00007ff176ef1000)]
  0x00007ff18c32a000 JavaThread "Thread-7" daemon [_thread_blocked, id=17377, stack(0x00007ff176ef1000,0x00007ff176ff2000)]
  0x00007ff18c359800 JavaThread "pool-4-thread-1" [_thread_in_native, id=17376, stack(0x00007ff176ff2000,0x00007ff1770f3000)]
  0x00007ff22ca79800 JavaThread "http-nio-50000-AsyncTimeout" daemon [_thread_blocked, id=17375, stack(0x00007ff1770f3000,0x00007ff1771f4000)]
  0x00007ff22ca78000 JavaThread "http-nio-50000-Acceptor-0" daemon [_thread_in_native, id=17374, stack(0x00007ff1771f4000,0x00007ff1772f5000)]
  0x00007ff22de8a800 JavaThread "http-nio-50000-ClientPoller-1" daemon [_thread_in_native, id=17373, stack(0x00007ff1772f5000,0x00007ff1773f6000)]
  0x00007ff22c2b7000 JavaThread "http-nio-50000-ClientPoller-0" daemon [_thread_in_native, id=17372, stack(0x00007ff1773f6000,0x00007ff1774f7000)]
  0x00007ff22e2f8800 JavaThread "http-nio-50000-exec-10" daemon [_thread_blocked, id=17371, stack(0x00007ff1774f7000,0x00007ff1775f8000)]
  0x00007ff22e2f7000 JavaThread "http-nio-50000-exec-9" daemon [_thread_blocked, id=17370, stack(0x00007ff1775f8000,0x00007ff1776f9000)]
  0x00007ff22da0e800 JavaThread "http-nio-50000-exec-8" daemon [_thread_blocked, id=17369, stack(0x00007ff1776f9000,0x00007ff1777fa000)]
  0x00007ff22ce58000 JavaThread "http-nio-50000-exec-7" daemon [_thread_blocked, id=17368, stack(0x00007ff1777fa000,0x00007ff1778fb000)]
  0x00007ff22ccb7000 JavaThread "http-nio-50000-exec-6" daemon [_thread_blocked, id=17367, stack(0x00007ff1778fb000,0x00007ff1779fc000)]
  0x00007ff22d4b9000 JavaThread "http-nio-50000-exec-5" daemon [_thread_blocked, id=17366, stack(0x00007ff1779fc000,0x00007ff177afd000)]
  0x00007ff22e91d000 JavaThread "http-nio-50000-exec-4" daemon [_thread_blocked, id=17365, stack(0x00007ff177afd000,0x00007ff177bfe000)]
  0x00007ff22c9e2000 JavaThread "http-nio-50000-exec-3" daemon [_thread_blocked, id=17364, stack(0x00007ff177bfe000,0x00007ff177cff000)]
  0x00007ff22cc0f800 JavaThread "http-nio-50000-exec-2" daemon [_thread_blocked, id=17363, stack(0x00007ff177cff000,0x00007ff177e00000)]
  0x00007ff22e077000 JavaThread "http-nio-50000-exec-1" daemon [_thread_blocked, id=17362, stack(0x00007ff1b4033000,0x00007ff1b4134000)]
  0x00007ff22cf0e000 JavaThread "NioBlockingSelector.BlockPoller-1" daemon [_thread_in_native, id=17361, stack(0x00007ff1b4a37000,0x00007ff1b4b38000)]
  0x00007ff22d0de800 JavaThread "pool-3-thread-1" [_thread_blocked, id=17360, stack(0x00007ff1b4b38000,0x00007ff1b4c39000)]
  0x00007ff22e750800 JavaThread "commons-pool-EvictionTimer" daemon [_thread_blocked, id=17355, stack(0x00007ff1b4534000,0x00007ff1b4635000)]
  0x00007ff22d70c000 JavaThread "container-0" [_thread_blocked, id=17353, stack(0x00007ff1b4635000,0x00007ff1b4736000)]
  0x00007ff22cf8f000 JavaThread "ContainerBackgroundProcessor[StandardEngine[Tomcat]]" daemon [_thread_blocked, id=17352, stack(0x00007ff1b4736000,0x00007ff1b4837000)]
  0x00007ff1b0c44000 JavaThread "I/O dispatcher 8" [_thread_in_native, id=17349, stack(0x00007ff1d4672000,0x00007ff1d4773000)]
  0x00007ff1b0bd2000 JavaThread "I/O dispatcher 7" [_thread_in_native, id=17348, stack(0x00007ff1d4773000,0x00007ff1d4874000)]
  0x00007ff1b035f000 JavaThread "I/O dispatcher 6" [_thread_in_native, id=17347, stack(0x00007ff1d4874000,0x00007ff1d4975000)]
  0x00007ff1b007c000 JavaThread "I/O dispatcher 5" [_thread_in_native, id=17346, stack(0x00007ff1d4975000,0x00007ff1d4a76000)]
  0x00007ff1b0309800 JavaThread "I/O dispatcher 4" [_thread_in_native, id=17345, stack(0x00007ff1d4a76000,0x00007ff1d4b77000)]
  0x00007ff1b076e000 JavaThread "I/O dispatcher 3" [_thread_in_native, id=17344, stack(0x00007ff1d4b77000,0x00007ff1d4c78000)]
  0x00007ff1b01cc800 JavaThread "I/O dispatcher 2" [_thread_in_native, id=17343, stack(0x00007ff1d4c78000,0x00007ff1d4d79000)]
  0x00007ff1b0d72000 JavaThread "I/O dispatcher 1" [_thread_in_native, id=17342, stack(0x00007ff1d4d79000,0x00007ff1d4e7a000)]
  0x00007ff22e79b000 JavaThread "Thread-2" daemon [_thread_blocked, id=17341, stack(0x00007ff1fc08a000,0x00007ff1fc18b000)]
  0x00007ff22e73a000 JavaThread "pool-1-thread-1" [_thread_in_native, id=17340, stack(0x00007ff1fcd9c000,0x00007ff1fce9d000)]
  0x00007ff22c218000 JavaThread "Service Thread" daemon [_thread_blocked, id=17332, stack(0x00007ff1fddde000,0x00007ff1fdedf000)]
  0x00007ff22c20e000 JavaThread "C1 CompilerThread3" daemon [_thread_blocked, id=17331, stack(0x00007ff1fdedf000,0x00007ff1fdfe0000)]
  0x00007ff22c20c000 JavaThread "C2 CompilerThread2" daemon [_thread_blocked, id=17330, stack(0x00007ff1fdfe0000,0x00007ff1fe0e1000)]
  0x00007ff22c20a000 JavaThread "C2 CompilerThread1" daemon [_thread_blocked, id=17329, stack(0x00007ff1fe0e1000,0x00007ff1fe1e2000)]
  0x00007ff22c207000 JavaThread "C2 CompilerThread0" daemon [_thread_blocked, id=17328, stack(0x00007ff1fe1e2000,0x00007ff1fe2e3000)]
  0x00007ff22c205800 JavaThread "Signal Dispatcher" daemon [_thread_blocked, id=17327, stack(0x00007ff1fe2e3000,0x00007ff1fe3e4000)]
  0x00007ff22c1d2800 JavaThread "Finalizer" daemon [_thread_blocked, id=17326, stack(0x00007ff1fe3e4000,0x00007ff1fe4e5000)]
  0x00007ff22c1ce000 JavaThread "Reference Handler" daemon [_thread_blocked, id=17325, stack(0x00007ff1fe4e5000,0x00007ff1fe5e6000)]

Other Threads:
=>0x00007ff22c1c6000 VMThread [stack: 0x00007ff1fe5e6000,0x00007ff1fe6e7000] [id=17324]
  0x00007ff22c213800 WatcherThread [stack: 0x00007ff1fdcdd000,0x00007ff1fddde000] [id=17333]

VM state:at safepoint (normal execution)

VM Mutex/Monitor currently owned by a thread:  ([mutex/lock_event])
[0x00007ff22c005e50] Threads_lock - owner thread: 0x00007ff22c1c6000
[0x00007ff22c006350] Heap_lock - owner thread: 0x00007ff128001000

Heap:
 PSYoungGen      total 466944K, used 454656K [0x0000000719800000, 0x0000000736d00000, 0x00000007c0000000)
  eden space 454656K, 100% used [0x0000000719800000,0x0000000735400000,0x0000000735400000)
  from space 12288K, 0% used [0x0000000736080000,0x0000000736080000,0x0000000736c80000)
  to   space 12800K, 0% used [0x0000000735400000,0x0000000735400000,0x0000000736080000)
 ParOldGen       total 225280K, used 34933K [0x00000005cc800000, 0x00000005da400000, 0x0000000719800000)
  object space 225280K, 15% used [0x00000005cc800000,0x00000005cea1d580,0x00000005da400000)
 Metaspace       used 66039K, capacity 67058K, committed 67456K, reserved 1110016K
  class space    used 6509K, capacity 6683K, committed 6784K, reserved 1048576K

Card table byte_map: [0x00007ff232022000,0x00007ff232fbf000] byte_map_base: 0x00007ff22f1be000

failed_mem_allocate 看上去是so中分配内存等失败了,so的接口代码中增加一些输出,进一步定位

F7ANTY
f7anty so文件是第三方的,不能增加输出
一年多之前 回复

太多了,难道不能捡重要的错误吗

F7ANTY
f7anty 显示的错误是 Internal Error (instanceKlass.cpp:3358), pid=17314, tid=0x00007ff1fe6e6700,导致出错的线程类型是VMThread(jvm的内部线程)
一年多之前 回复

上图中在crash的时候有输出 Failed: 0x0000000724e62b08 -> 0x0000000324c18200,通过hsdb分析附近的栈信息,如下

图片说明

图片说明

上图中标识的红框是不是表明yuv: ** BAD OOP 是一个坏的指针

先根据接口文档检查数据类型,如果没错的话可能是so问题,让其他人给个测试的函数再试试吧。

先根据接口文档检查数据类型,如果没错的话可能是so问题

你java类名要和so名称一致

第一步 建立一个监听类

建立监听类的作用是在应用中间件启动时自动执行加载程序。

1)创建一个类实现ServletContextListener 接口

2)实现contextInitialized方法

3)在项目的web.xml 文件中配置此监听类
第二步 添加动态库到系统变量

将dll/so文件所在的路径添加到系统环境java.library.path 中

添加过程需要使用到反射机制来进行,不能使用System.setProperty()进行设置,设置了也无效。直接看代码:
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20

private void addDirToPath(String s){
try {
//获取系统path变量对象
Field field=ClassLoader.class.getDeclaredField("sys_paths");
//设置此变量对象可访问
field.setAccessible(true);
//获取此变量对象的值
String[] path=(String[])field.get(null);
//创建字符串数组,在原来的数组长度上增加一个,用于存放增加的目录
String[] tem=new String[path.length+1];
//将原来的path变量复制到tem中
System.arraycopy(path,0,tem,0,path.length);
//将增加的目录存入新的变量数组中
tem[path.length]=s;
//将增加目录后的数组赋给path变量对象
field.set(null,tem);
} catch (Exception e) {
e.printStackTrace();
}
}
第三步 加载动态库文件

接下来就可以写上下文初始化的方法了:
?
1
2
3
4
5
6
7
8

public void contextInitialized(ServletContextEvent arg0) {
//获取存放dll文件的绝对路径(假设将dll文件放在系统根目录下的WEB-INF文件夹中)
String path=arg0.getServletContext().getRealPath("WEB-INF");
//将此目录添加到系统环境变量中
addDirToPath(path);
//加载相应的dll/so文件,注意要将'\'替换为'/'
System.load(path.replaceAll("\\","/")+"/XXXX.dll");
}
第四步 重启启动应用中间件(Tomcat|Weblogic)

至此就可以在你的java程序中使用dll/so文件的方法了。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
Java通过JNI调用第三方dll文件问题
-
安卓写so库调用第三方so库中非JNI接口函数
-
java用JNI调用第三方库的时候,出现 java.lang.UnsatisfiedLinkError
-
菜鸟请教,Java项目中如何使用JNI调用.so文件,已有现成的.so文件
-
【求助】有没有大佬做过AndroidStudio通过JNI NDK调用第三方so库?
-
Android JNI 调用非JNI规范的so文件
-
<急>关于jni调用第三方动态库不成功
-
jni调用C#Dll,被调用DLL依赖的第三方DLL该放哪里?提示找不到
-
初学jni,android调用so,运行出错
-
Java调用JNI第一次成功返回结果,第二次程序直接挂死
-
在JNI中调用第三方开源库的问题
-
使用IDEA是报错Error: A JNI error has occurred, please check your installation and try again?
-
安卓jni调用传入参数问题
-
jni调用java方法报错!!!
-
c通过jni调用 HBASE JAVA API
-
使用JNA或者JNI调用dll的问题
-
jni调用的函数和native函数不在一个java文件内,调用出错
-
java调用JNI的时候老是抛异常,求帮助
-
紧急求助,java访问串口出现项目崩溃问题,求大神指导
-
程序员那些必须掌握的排序算法(下)
接着上一篇的排序算法,我们废话不多,直接进入主题。 1.快速排序 快速排序(Quicksort)是对冒泡排序的一种改进。 快速排序由C. A. R. Hoare在1960年提出。它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。 演示...
学会了这些技术,你离BAT大厂不远了
每一个程序员都有一个梦想,梦想着能够进入阿里、腾讯、字节跳动、百度等一线互联网公司,由于身边的环境等原因,不知道 BAT 等一线互联网公司使用哪些技术?或者该如何去学习这些技术?或者我该去哪些获取这些技术资料?没关系,平头哥一站式服务,上面统统不是问题。平头哥整理了 BAT 等一线大厂的必备技能,并且帮你准备了对应的资料。对于整理出来的技术,如果你掌握的不牢固,那就赶快巩固,如果你还没有涉及,现在...
程序员真是太太太太太有趣了!!!
网络上虽然已经有了很多关于程序员的话题,但大部分人对这个群体还是很陌生。我们在谈论程序员的时候,究竟该聊些什么呢?各位程序员大佬们,请让我听到你们的声音!不管你是前端开发...
史上最详细的IDEA优雅整合Maven+SSM框架(详细思路+附带源码)
网上很多整合SSM博客文章并不能让初探ssm的同学思路完全的清晰,可以试着关掉整合教程,摇两下头骨,哈一大口气,就在万事具备的时候,开整,这个时候你可能思路全无 ~中招了咩~ ,还有一些同学依旧在使用eclipse或者Myeclipse开发,我想对这些朋友说IDEA 的编译速度很快,人生苦短,来不及解释了,直接上手idea吧。这篇文章每一步搭建过程都测试过了,应该不会有什么差错。本文章还有个比较优秀的特点,就是idea的使用,基本上关于idea的操作都算是比较详细的,所以不用太担心不会撸idea!最后,本文
知乎上 40 个有趣回复,很精辟很提神
点击蓝色“五分钟学算法”关注我哟加个“星标”,天天中午 12:15,一起学算法作者 |佚名来源 |网络整理,版权归原作者所有,侵删。1交朋友的标准是什么?- Ques...
从入门到精通,Java学习路线导航
引言 最近也有很多人来向我"请教",他们大都是一些刚入门的新手,还不了解这个行业,也不知道从何学起,开始的时候非常迷茫,实在是每天回复很多人也很麻烦,所以在这里统一作个回复吧。 Java学习路线 当然,这里我只是说Java学习路线,因为自己就是学Java的,对Java理当很熟悉,对于其它方面,我也不是很了解。 基础阶段 首先是基础阶段,在基础阶段,我们必须掌握Java基础,Mysql数据库,Ora...
我花了一夜用数据结构给女朋友写个H5走迷宫游戏
起因 又到深夜了,我按照以往在csdn和公众号写着数据结构!这占用了我大量的时间!我的超越妹妹严重缺乏陪伴而 怨气满满! 而女朋友时常埋怨,认为数据结构这么抽象难懂的东西没啥作用,常会问道:天天写这玩意,有啥作用。而我答道:能干事情多了,比如写个迷宫小游戏啥的! 当我码完字准备睡觉时:写不好别睡觉! 分析 如果用数据结构与算法造出东西来呢? ...
实现 Java 本地缓存,该从这几点开始
缓存,我相信大家对它一定不陌生,在项目中,缓存肯定是必不可少的。市面上有非常多的缓存工具,比如 Redis、Guava Cache 或者 EHcache。对于这些工具,我想大家肯定都非常熟悉,所以今天我们不聊它们,我们来聊一聊如何实现本地缓存。参考上面几种工具,要实现一个较好的本地缓存,平头哥认为要从以下三个方面开始。 1、存储集合的选择 实现本地缓存,存储容器肯定是 key/value 形式的数...
揭开 Python 内存分配时的小秘密!
作者 | 豌豆花下猫 责编 | 胡巍巍 Python 中的sys模块极为基础而重要,它主要提供了一些给解释器使用(或由它维护)的变量,以及一些与解释器强交互的函数。 本文将会频繁地使用该模块的getsizeof()方法,因此,我先简要介绍一下: 该方法用于获取一个对象的字节大小(bytes) 它只计算直接占用的内存,而不计算对象内所引用对象的内存 这里有个直观的例...
让程序员崩溃的瞬间(非程序员勿入)
今天给大家带来点快乐,程序员才能看懂。 来源:https://zhuanlan.zhihu.com/p/47066521 1. 公司实习生找 Bug 2.在调试时,将断点设置在错误的位置 3.当我有一个很棒的调试想法时 4.偶然间看到自己多年前写的代码 5.当我第一次启动我的单元测试时 ...
用Python分析2000款避孕套,得出这些有趣的结论
到现在为止,我们的淘宝教程已经写到了第四篇,前三篇分别是: 第一篇:Python模拟登录淘宝,详细讲解如何使用requests库登录淘宝pc端。 第二篇:淘宝自动登录2.0,新增Cookies序列化,教大家如何将cookies保存起来。 第三篇:Python爬取淘宝商品避孕套,教大家如何爬取淘宝pc端商品信息。 今天,我们来看看淘宝系列的第四篇 我们在上一篇的时候已经将淘宝数据爬取下来了,...
做好以下四点,拒做 “ 空心 ” 程序员
01、注重原理性知识 现在的互联网环境下,注重原理性知识学习的程序员越来越少,特别是在这种培训机构大爆炸的环境下,在网上你会经常看到类似三个月从入门到精通高并发、分布式的广告,我相信培训机构有这套技术的能力,但是我不相信一个初学者有这么好的接收能力。甚至某个培训机构的讲师里,有一个1997年出生的架构师,20岁出头就当上了架构师,真的是后生可畏呀。在我的思维里,架构师不是学出来的,架构师是...
分享靠写代码赚钱的一些门路
作者 mezod,译者 josephchang10如今,通过自己的代码去赚钱变得越来越简单,不过对很多人来说依然还是很难,因为他们不知道有哪些门路。今天给大家分享一个精彩...
技术人员要拿百万年薪,必须要经历这9个段位
很多人都问,技术人员如何成长,每个阶段又是怎样的,如何才能走出当前的迷茫,实现自我的突破。所以我结合我自己10多年的从业经验,总结了技术人员成长的9个段位,希望对大家的职...
面试官:兄弟,说说基本类型和包装类型的区别吧
Java 的每个基本类型都对应了一个包装类型,比如说 int 的包装类型为 Integer,double 的包装类型为 Double。基本类型和包装类型的区别主要有以下 4 点。
进程和线程的区别(超详细)
进程和线程 进程 一个在内存中运行的应用程序。每个进程都有自己独立的一块内存空间,一个进程可以有多个线程,比如在Windows系统中,一个运行的xx.exe就是一个进程。 线程 进程中的一个执行任务(控制单元),负责当前进程中程序的执行。一个进程至少有一个线程,一个进程可以运行多个线程,多个线程可共享数据。 与进程不同的是同类的多个线程共享进程的堆和方法区资源,但每个线程有自己的程序计数器、虚拟...
第二弹!python爬虫批量下载高清大图
文章目录前言下载免费高清大图下载带水印的精选图代码与总结 前言 在上一篇写文章没高质量配图?python爬虫绕过限制一键搜索下载图虫创意图片!中,我们在未登录的情况下实现了图虫创意无水印高清小图的批量下载。虽然小图能够在一些移动端可能展示的还行,但是放到pc端展示图片太小效果真的是很一般!建议阅读本文查看上一篇文章,在具体实现不做太多介绍,只讲个分析思路。 当然,本文可能技术要求不是特别高,但可以...
面试官,不要再问我三次握手和四次挥手
三次握手和四次挥手是各个公司常见的考点,也具有一定的水平区分度,也被一些面试官作为热身题。很多小伙伴说这个问题刚开始回答的挺好,但是后面越回答越冒冷汗,最后就歇菜了。 见过比较典型的面试场景是这样的: 面试官:请介绍下三次握手 求职者:第一次握手就是客户端给服务器端发送一个报文,第二次就是服务器收到报文之后,会应答一个报文给客户端,第三次握手就是客户端收到报文后再给服务器发送一个报文,三次握手就...
为什么说 Web 开发永远不会退出历史舞台?
早在 PC 崛起之际,Web 从蹒跚学步一路走到了主导市场的地位,但是随着移动互联网时代的来临,业界曾有不少人猜测,“Web 应该被杀死,App 才是未来”。不过时间是检...
Java 爬虫遇到需要登录的网站,该怎么办?
这是 Java 网络爬虫系列博文的第二篇,在上一篇 Java 网络爬虫,就是这么的简单 中,我们简单的学习了一下如何利用 Java 进行网络爬虫。在这一篇中我们将简单的聊一聊在网络爬虫时,遇到需要登录的网站,我们该怎么办? 在做爬虫时,遇到需要登陆的问题也比较常见,比如写脚本抢票之类的,但凡需要个人信息的都需要登陆,对于这类问题主要有两种解决方式:一种方式是手动设置 cookie ,就是先在网站上...
nginx学习,看这一篇就够了:下载、安装。使用:正向代理、反向代理、负载均衡。常用命令和配置文件
文章目录前言一、nginx简介1. 什么是 nginx 和可以做什么事情2.Nginx 作为 web 服务器3. 正向代理4. 反向代理5. 动静分离6.动静分离二、Nginx 的安装三、 Nginx 的常用命令和配置文件四、 Nginx 配置实例 1 反向代理五、 Nginx 配置实例 2 负载均衡六、 Nginx 配置实例 3 动静分离七、 Nginx 的高可用集群 前言 一、nginx简介...
相关热词 c#二进制字符转字节 c# rc4 c#中md5加密 c# 新建mvc项目 c# 引用mysql c#动态加载非托管dll c# 两个表数据同步 c# 返回浮点json c# imap 链接状态 c# 漂亮字