JVM 命令行监控及诊断工具

news2024/10/2 22:14:15

面试题

        你使用过Java虚拟机性能监控和故障处理工具吗?(美图)
        怎么打出线程栈信息。(字节跳动)
        JVM诊断调优工具用过哪些? (京东)
        怎么获取 Java 程序使用的内存?堆使用的百分比?(国美)
        几种常用的内存调试工具你知道哪些?(搜狐)
        JVM诊断调优工具用过哪些? (蚂蚁金服)

概述

        性能诊断是软件工程师在日常工作中需要经常面对和解决的问题,在用户体验至上的今天,解决好应用的性能问题能带来非常大的收益。

        Java 作为最流行的编程语言之一,其应用性能诊断一直受到业界广泛关注。可能造成 Java 应用出现性能问题的因素非常多,例如线程控制、磁盘读写、数据库访问、网络I/O、垃圾收集等。想要定位这些问题,一款优秀的性能诊断工具必不可少。

        体会1:使用数据说明问题,使用知识分析问题,使用工具处理问题。

        体会2:无监控、不调优!

简单命令行工具

        在我们刚接触java学习的时候,大家肯定最先了解的两个命令就是javac,java,那么除此之外,还有没有其他的命令可以供我们使用呢?我们进入到安装jdk的bin目录,发现还有一系列辅助工具。这些辅助工具用来获取目标 JVM 不同方面、不同层次的信息,帮助开发人员很好地解决Java应用程序的一些疑难杂症。

mac系统下:

windows系统下:

源码:jdk/jdk11: 1ddf9a99e4ad /src/jdk.jcmd/share/classes/sun/tools/

jps:查看正在运行的ava进程

jps(Java Process Status):显示指定系统内所有的HotSpot虚拟机进程(查看虚拟机进程信息),可用于查询正在运行的虚拟机进程。

说明:对于本地虚拟机进程来说,进程的本地虚拟机ID与操作系统的进程ID是一致的,是唯一的。

测试:

public class JPSTest {
    public static void main(String[] args) {
        try {
            Thread.sleep(100000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}

它的基本使用语法为:

jps [options] [hostid]

我们还可以通过追加参数,来打印额外的信息。

options参数:

        -q :仅仅显示LVMID (local virtual machine id),即本地虚拟机唯一id。不显示主类的名称等

        -l: 输出应用程序主类的全类名 或 如果进程执行的是jar包,则输出jar完整路径

        -m: 输出虚拟机进程启动时传递给主类main()的参数

        -v: 列出虚拟机进程启动时的JVM参数。 比如:-Xms20m -Xmx50m是启动程序指定的jvm参数。

        说明:以上参数可以综合使用。

        补充:如果某 Java 进程关闭了默认开启的UsePerfData参数(即使用参数-XX:-UsePerfData),那么jps命令(以及下面介绍的jstat)将无法探知该 Java 进程。

hostid参数:

        RMI注册表中注册的主机名。如果想要远程监控主机上的 java 程序,需要安装 jstatd。对于具有更严格的安全实践的网络场所而言,可能使用一个自定义的策略文件来显示对特定的可信主机或网络的访问,尽管这种技术容易受到IP地址欺诈攻击。如果安全问题无法使用一个定制的策略文件来处理,那么最安全的操作是不运行jstatd服务器,而是在本地使用jstat和jps工具。

jstat:查看VM统计信息

jstat(JVM Statistics Monitoring Tool):用于监视虚拟机各种运行状态信息的命令行工具。它可以显示本地或者远程虚拟机进程中的类装载、内存、垃圾收集、JIT编译等运行数据。

在没有GUI图形界面,只提供了纯文本控制台环境的服务器上,它将是运行期定位虚拟机性能问题的首选工具。常用于检测垃圾回收问题以及内存泄漏问题。

官方文档:https://docs.oracle.com/javase/8/docs/technotes/tools/unix/jstat.html

它的基本使用语法为:

jstat -<option> [-t] [-h<lines>] <vmid> [<interval> [<count>]]

查看命令相关参数:jstat -h 或 jstat -help

option参数:

        选项option可以由以下值构成。
        类装载相关的:

  • -class:显示ClassLoader的相关信息:类的装载、卸载数量、总空间、类装载所消耗的时间等。

        垃圾回收相关的:

  • -gc:显示与GC相关的堆信息。包括Eden区、两个Survivor区、老年代、永久代等的容量、已用空间、GC时间合计等信息。
  • -gccapacity:显示内容与-gc基本相同,但输出主要关注Java堆各个区域使用到的最大、最小空间。
  • -gcutil:显示内容与-gc基本相同,但输出主要关注已使用空间占总空间的百分比。
  • -gccause:与-gcutil功能一样,但是会额外输出导致最后一次或当前正在发生的GC产生的原因。
  • -gcnew:显示新生代GC状况
  • -gcnewcapacity:显示内容与-gcnew基本相同,输出主要关注使用到的最大、最小空间
  • -geold:显示老年代GC状况
  • -gcoldcapacity:显示内容与-gcold基本相同,输出主要关注使用到的最大、最小空间
  • -gcpermcapacity:显示永久代使用到的最大、最小空间。

        JIT相关的:

  • -compiler:显示JIT编译器编译过的方法、耗时等信息
  • -printcompilation:输出已经被JIT编译的方法 

-gc说明

1、新生代相关

  • S0C是第一个幸存者区的大小(字节)
  • S1C是第二个幸存者区的大小(字节)
  • S0U是第一个幸存者区已使用的大小(字节)
  • S1U是第二个幸存者区已使用的大小(字节)
  • EC是Eden空间的大小(字节)
  • EU是Eden空间已使用大小(字节)

2、老年代相关

  • OC是老年代的大小(字节)
  • OU是老年代已使用的大小(字节)

3、方法区(元空间)相关

  • MC是方法区的大小
  • MU是方法区已使用的大小
  • CCSC是压缩类空间的大小
  • CCSU是压缩类空间已使用的大小

4、其它

  • YGC是指从应用程序启动到采样时young gc次数
  • YGCT是指从应用程序启动到采样时young gc消耗的时间(秒)
  • FGC是指从应用程序启动到采样时full gc次数
  • FGCT是指从应用程序启动到采样时full gc消耗的时间(秒)
  • GCT是指从应用程序启动到采样时gc的总时间

interval参数:

        用于指定输出统计数据的周期,单位为毫秒。即:查询间隔

count参数:

        用于指定查询的总次数

-t参数:

        可以在输出信息前加上一个Timestamp列,显示程序的运行时间。单位:秒

        经验:我们可以比较 Java 进程的启动时间以及总 GC 时间(GCT 列),或者两次测量的间隔时间以及总 GC 时间的增量,来得出 GC 时间占运行时间的比例。如果该比例超过 20%,则说明目前堆的压力较大;如果该比例超过 90%,则说明堆里几乎没有可用空间,随时都可能抛出 OOM 异常。

-h参数:

        可以在周期性数据输出时,输出多少行数据后输出一个表头信息

补充:

        jstat还可以用来判断是否出现内存泄漏。

        第1步:在长时间运行的 Java 程序中,我们可以运行jstat命令连续获取多行性能数据,并取这几行数据中 OU 列(即已占用的老年代内存)的最小值。

        第2步:然后,我们每隔一段较长的时间重复一次上述操作,来获得多组 OU 最小值。如果这些值呈上涨趋势,则说明该 Java 程序的老年代内存已使用量在不断上涨,这意味着无法回收的对象在不断增加,因此很有可能存在内存泄漏。

jinfo:实时查看和修改VM配置参数

jinfo(Configuration Info for Java):查看虚拟机配置参数信息,也可用于调整虚拟机的配置参数。

在很多情况下,Java应用程序不会指定所有的Java虚拟机参数。而此时,开发人员可能不知道某一个具体的Java虚拟机参数的默认值。在这种情况下,可能需要通过查找文档获取某个参数的默认值。这个査找过程可能是非常艰难的。但有了jinfo工具,开发人员可以很方便地找到Java虚拟机参数的当前值。

官方帮助文档:jinfo

它的基本使用语法为:

jinfo  [ options ] pid

说明:java 进程ID 必须要加上

查看示例:

        示例1:jinfo -sysprops PID

                可以查看由System.getProperties0取得的参数

        示例2:jinfo -flags PID

                查看曾经赋过值的一些参数

        示例3:jinfo -flag 具体参数 PID

                查看某个java进程的具体参数的值

修改示例:

        jinfo不仅可以查看运行时某一个Java虚拟机参数的实际取值,甚至可以在运行时修改部分参数,并使之立即生效。但是,并非所有参数都支持动态修改。参数只有被标记为manageable的flag可以被实时修改。其实,这个修改能力是极其有限的。

        #  可以查看被标记为manageable的参数

        java -XX:+PrintFlagsFinal -version | grep manageable

  • intx CMSAbortablePrecleanWaitMillis            = 100             {manageable}        
  • intx CMSWaitDuration                           = 2000            {manageable}        
  • bool HeapDumpAfterFullGC                       = false           {manageable}        
  • bool HeapDumpBeforeFullGC                      = false           {manageable}        
  • bool HeapDumpOnOutOfMemoryError                = false           {manageable}        
  • ccstr HeapDumpPath                              =                 {manageable}        
  • uintx MaxHeapFreeRatio                          = 100             {manageable}        
  • uintx MinHeapFreeRatio                          = 0               {manageable}        
  • bool PrintClassHistogram                       = false           {manageable}        
  • bool PrintClassHistogramAfterFullGC            = false           {manageable}        
  • bool PrintClassHistogramBeforeFullGC           = false           {manageable}        
  • bool PrintConcurrentLocks                      = false           {manageable}        
  • bool PrintGC                                   = false           {manageable}        
  • bool PrintGCDateStamps                         = false           {manageable}        
  • bool PrintGCDetails                            = false           {manageable}        
  • bool PrintGCTimeStamps                         = false           {manageable} 

        针对boolean类型:jinfo -flag [+|-]具体参数 PID

        针对非boolean类型:jinfo -flag 具体参数=具体参数值 PlD

拓展:

        java -XX:+PrintFlagsInitial 

                查看所有VM参数启动的初始值

        java -XX:+PrintFlagsFinal

                查看所有VM参数的最终值

        java -XX:+PrintCommandLineFlags

                查看那些已经被用户或者JVM设置过的详细的XX参数的名称和值

jmap:导出内存映像文件&内存使用情况

jmap(JVM Memory Map):作用一方面是获取dump文件(堆转储快照文件,二进制文件),它还可以获取目标Java进程的内存相关信息,包括Java堆各区域的使用情况、堆中对象的统计信息、类加载信息等。

开发人员可以在控制台中输入命令“jmap -help”查阅jmap工具的具体使用方式和一些标准选项配置。

官方帮助文档:jmap

它的基本使用语法为:

jmap [option] <pid>
jmap [option] <executable <core>
jmap [option] [server_id@]<remote server IP or hostname>

其中option包括:

说明:这些参数和linux下输入显示的命令多少会有不同,包括也受jdk版本的影响。

-dump

        生成Java堆转储快照:dump文件;特别的:-dump:live只保存堆中的存活对象

-heap

        输出整个堆空间的详细信息,包括GC的使用、堆配置信息,以及内存的使用信息等

-histo

        输出堆中对象的统计信息,包括类、实例数量和合计容量;特别的:-histo:live只统计堆中的存活对象

-permstat

        以ClassLoader为统计口径输出永久代的内存状态信息;仅linux/solaris平台有效

-finalizerinfo

        显示在F-Queue中等待Finalizer线程执行finalize方法的对象;仅linux/solaris平台有效

-F

        当虚拟机进程对-dump选项没有任何响应时,可使用此选项强制执行生成dump文件;仅linux/solaris平台有效

-h | -help

        jmap工具使用的帮助命令

-J <flag>

        传递参数给jmap启动的jvm

基本使用:

        使用1:导出内存映像文件

                一般来说,使用jmap指令生成dump文件的操作算得上是最常用的jmap命令之一,将堆中所有存活对象导出至一个文件之中。

                Heap Dump又叫做堆存储文件,指一个Java进程在某个时间点的内存快照。Heap Dump在触发内存快照的时候会保存此刻的信息如下:

  • All Objects:Class,fields,primitive values and references
  • All Classes:ClassLoader,name,super class,static fields
  • Garbage Collection Roots:Objects defined to be reachable by the JVM
  • Thread Stacks and Local Variables:The call-stacks of threads at the moment of the snapshot,and per-frame information about local objects

                说明:1. 通常在写Heap Dump文件前会触发一次Full GC,所以heap dump文件里保存的都是FullGC后留下的对象信息。2. 由于生成dump文件比较耗时,因此大家需要耐心等待,尤其是大内存镜像生成dump文件则需要耗费更长的时间来完成。

                手动的方式:

                        jmap -dump:format=b,file=<filename.hprof> <pid>
                        jmap -dump:live,format=b,file=<filename.hprof> <pid>

                自动的方式:当程序发生OOM退出系统时,一些瞬时信息都随着程序的终止而消失,而重现OOM问题往往比较困难或者耗时。此时若能在OOM时,自动导出dump文件就显得非常迫切。

                        -XX:+HeapDumpOnOutOfMemoryError:在程序发生OOM时,导出应用程序的当前堆快照。
                        -XX:HeapDumpPath=<filename.hprof>:可以指定堆快照的保存位置。

                示例:-Xmx100m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:\m.hprof

        使用2:显示堆内存相关信息

                jmap -heap pid

                -jmap -histo pid

        使用3:其它作用

                jmap -permstat pid:查看系统的ClassLoadert信息

                jmap -finalizerinfo:查看堆积在finalizer队列中的对象

小结:

        由于jmap将访问堆中的所有对象,为了保证在此过程中不被应用线程干扰,jmap需要借助安全点机制,让所有线程停留在不改变堆中数据的状态。也就是说,由jmap导出的堆快照必定是安全点位置的。这可能导致基于该堆快照的分析结果存在偏差。

        举个例子,假设在编译生成的机器码中,某些对象的生命周期在两个安全点之间,那么:live选项将无法探知到这些对象。

        另外,如果某个线程长时间无法跑到安全点,jmap将一直等下去。

        与前面讲的jstat则不同,垃圾回收器会主动将jstat所需要的摘要数据保存至固定位置之中,而jstat只需直接读取即可。

jhat:JDK自带堆分析工具

jhat(JVM Heap Analysis Tool):Sun JDK提供的jhat命令与jmap命令搭配使用,用于分析jmap生成的heap dump文件(堆转储快照)。jhat内置了一个微型的HTTP/HTML服务器, 生成dump文件的分析结果后, 用户可以在浏览器中查看分析结果(分析虚拟机转储快照信息)。

使用了jhat命令,就启动了一个http服务,端口是7000,即http://localhost:7000/,就可以在浏览器里分析。

说明:jhat命令在JDK9、JDK10中已经被删除,官方建议用VisualVM代替。

它的基本使用语法为:

jhat [option] [dumpfile]

option参数:-stack false|true

        关闭 | 打开对象分配调用栈跟踪

option参数:-refs false|true

        关闭 | 打开对象引用跟踪

option参数:-port port-number

        设置jhat HTTP Server的端口号,默认7000

option参数:-exclude exclude-file

        执行对象查询时需要排除的数据成员列表文件

option参数:-baseline exclude-file

        指定一个基准堆转储

option参数:-debug int

        设置debug级别

option参数:-version

        启动后显示版本信息就退出

option参数:-J <flag>

        传入启动参数,比如 -J -Xmx512m

jstack:打印VM中线程快照

面试题

        JVM的进程有哪些线程启动,有了解吗?(神州租车)

面试题解释:

        每当使用java命令执行一个带main方法的类时,就会启动JVM(应用程序),实际上就是在操作系统中启动一个JVM进程,JVM启动时,必然会创建以下5个线程:

        1-main                               主线程,执行我们指定的启动类的main方法

        2-Reference Handler        处理引用的线程 

        3-Finalizer                         调用对象的finalize方法的线程,就是垃圾回收的线程 

        4-Signal Dispatcher          分发处理发送给JVM信号的线程  

        5-Attach Listener              负责接收外部的命令的线程

        Attach Listener :该线程是负责接收到外部的命令,执行该命令,并且把结果返回给发送者。通常我们会用一些命令去要求jvm给我们一些反馈信息,如:java -version、jmap、jstack等等。如果该线程在jvm启动的时候没有初始化,那么,则会在用户第一次执行jvm命令时,得到启动。

        signal dispather: 前面我们提到第一个Attach Listener线程的职责是接收外部jvm命令,当命令接收成功后,会交给signal dispather线程去进行分发到各个不同的模块处理命令,并且返回处理结果。signal dispather线程也是在第一次接收外部jvm命令时,进行初始化工作。

        Finalizer:JVM在垃圾收集时会将失去引用的对象包装成Finalizer对象(Reference的实现),并放入ReferenceQueue,由Finalizer线程来处理;最后将该Finalizer对象的引用置为null,由垃圾收集器来回收。

        Reference Handler :它主要用于处理引用对象本身(软引用、弱引用、虚引用)的垃圾回收问题。

        main:主线程,用于执行我们编写的java程序的main方法。

        编写java应用程序查看JVM启动时创建的所有线程,代码如下:

import java.lang.management.ManagementFactory;
import java.lang.management.ThreadInfo;
import java.lang.management.ThreadMXBean;

public class JVMTest {
  public static void main(String[] args) throws Exception {
    ThreadMXBean threadMXBean = ManagementFactory.getThreadMXBean();
    ThreadInfo[] threadInfos = threadMXBean.dumpAllThreads(false, false);
    for(ThreadInfo threadInfo : threadInfos) {
      System.out.println(threadInfo.getThreadId() + "-" + threadInfo.getThreadName());
    }
  }
}
//输出如下:
//5-Attach Listener
//4-Signal Dispatcher
//3-Finalizer
//2-Reference Handler
//1-main

jstack(JVM Stack Trace):用于生成虚拟机指定进程当前时刻的线程快照(虚拟机堆栈跟踪)。 线程快照就是当前虚拟机内指定进程的每一条线程正在执行的方法堆栈的集合。

生成线程快照的作用:可用于定位线程出现长时间停顿的原因,如线程间死锁、死循环、请求外部资源导致的长时间等待等问题。这些都是导致线程长时间停顿的常见原因。当线程出现停顿时,就可以用jstack显示各个线程调用的堆栈情况。

官方帮助文档:jstack

在thread dump中,要留意下面几种状态 :

  • 死锁,Deadlock(重点关注) 
  • 等待资源,Waiting on condition(重点关注) 
  • 等待获取监视器,Waiting on monitor entry(重点关注) 
  • 阻塞,Blocked(重点关注) 
  • 执行中,Runnable
  • 暂停,Suspended
  • 对象等待中,Object.wait() 或 TIMED_WAITING 
  • 停止,Parked 

它的基本使用语法为:

jstack option pid

jstack管理远程进程的话,需要在远程程序的启动参数中增加:

  • -Djava.rmi.server.hostname=…..
  • -Dcom.sun.management.jmxremote
  • -Dcom.sun.management.jmxremote.port=8888
  • -Dcom.sun.management.jmxremote.authenticate=false
  • -Dcom.sun.management.jmxremote.ssl=false

option参数:-F

        当正常输出的请球不被响应时,强制输出线程堆栈

option参数:-l

        除堆栈外,显示关于锁的附加信息

option参数:-m

        如果调用到本地方法的话,可以显示C/C++的堆栈

option参数:-h

        帮助操作

jcmd:多功能命令行

在JDK 1.7以后,新增了一个命令行工具jcmd。它是一个多功能的工具,可以用来实现前面除了jstat之外所有命令的功能。比如:用它来导出堆、内存使用、查看Java进程、导出线程信息、执行GC、JVM运行时间等。

官方帮助文档:jcmd

jcmd拥有jmap的大部分功能,并且在Oracle的官方网站上也推荐使用jcmd命令代jmap命令。

基本使用语法:

jcmd -I

        列出所有的VM进程

jcmd pid help

        针对指定的进程,列出支持的所有命令

jcmd pid 具体命令

        显示指定进程的指令命令的数据

        你可以探索jcmd中的下述功能,看看有没有适合你项目的监控项:

  • Compiler.CodeHeap_Analytics
  • Compiler.codecache
  • Compiler.codelist
  • Compiler.directives_add
  • Compiler.directives_clear
  • Compiler.directives_print
  • Compiler.directives_remove
  • Compiler.queue
  • GC.class_histogram
  • GC.class_stats
  • GC.finalizer_info
  • GC.heap_dump
  • GC.heap_info
  • GC.run
  • GC.run_finalization
  • VM.class_hierarchy
  • VM.classloader_stats
  • VM.classloaders
  • VM.command_line
  • VM.dynlibs
  • VM.flags
  • VM.info
  • VM.log
  • VM.metaspace
  • VM.native_memory
  • VM.print_touched_methods
  • VM.set_flag
  • VM.stringtable
  • VM.symboltable
  • VM.system_properties
  • VM.systemdictionary
  • VM.unlock_commercial_features
  • VM.uptime
  • VM.version

jstatd:远程主机信息收集

之前的指令只涉及到监控本机的Java应用程序,而在这些工具中,一些监控工具也支持对远程计算机的监控(如jps、jstat)。为了启用远程监控,则需要配合使用jstatd 工具。

命令jstatd是一个RMI服务端程序,它的作用相当于代理服务器,建立本地计算机与远程监控工具的通信。 jstatd服务器将本机的Java应用程序信息传递到远程计算机。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1293454.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Django模板,Django中间件,ORM操作(pymysql + SQL语句),连接池,session和cookie, 缓存

day04 django进阶-知识点 今日概要&#xff1a; 模板中间件ORM操作&#xff08;pymysql SQL语句&#xff09;session和cookie缓存&#xff08;很多种方式&#xff09; 内容回顾 请求周期 路由系统 最基本路由关系动态路由&#xff08;含正则&#xff09;路由分发不同的app中…

ssh安装和Gitee(码云)源码拉取

文章目录 安装ssh服务注册码云公钥设置码云账户SSH公钥安装git客户端和git-lfs源码获取 安装ssh服务 更新软件源&#xff1a; sudo apt-get update安装ssh服务 sudo apt-get install openssh-server检查ssh是否安装成功 which ssh输出&#xff1a; /usr/bin/ssh启动ssh 服…

『亚马逊云科技产品测评』活动征文|基于亚马逊云EC2搭建PG开源数据库

授权声明&#xff1a;本篇文章授权活动官方亚马逊云科技文章转发、改写权&#xff0c;包括不限于在 Developer Centre, 知乎&#xff0c;自媒体平台&#xff0c;第三方开发者媒体等亚马逊云科技官方渠道 亚马逊EC2云服务器&#xff08;Elastic Compute Cloud&#xff09;是亚马…

conda配置不同版本的python及依赖库--conda conda conda

一、conda介绍 Conda 是一个开源的软件包管理系统和环境管理系统&#xff0c;用于安装多个不同版本的软件包及其依赖关系&#xff0c;并在它们之间轻松切换。 Conda 是为 Python 程序创建的&#xff0c;适用于 Linux&#xff0c;OS X 和Windows Conda可以构建不同的环境&#…

时间序列预测实战(二十四)PyTorch实现RNN进行多元和单元预测(附代码+数据集+完整解析)

一、本文介绍 本篇文章给大家带来的是利用我个人编写的架构进行RNN时间序列卷积进行时间序列建模&#xff08;专门为了时间序列领域新人编写的架构&#xff0c;简单且不同于市面上大家用GPT写的代码&#xff09;&#xff0c;包括结果可视化、支持单元预测、多元预测、模型拟合…

Ubuntu安装nvidia GPU显卡驱动教程

Ubuntu安装nvidia显卡驱动 1.安装前安装必要的依赖 sudo apt-get install build-essential sudo apt-get install g sudo apt-get install make2.到官网下载对应驱动 https://www.nvidia.cn/Download/index.aspx?langcn 3.卸载原有驱动 sudo apt-get remove --purge nvidi…

Attack Lab 【深入理解计算机组成与系统实验】(更新ing)

前情提要&#xff1a;因为图片都很长的原因&#xff0c;up不会调&#xff0c;所以可能看的不舒服&#xff0c;请原谅up&#xff0c;电脑可以缩小至80或者90看会舒服一点&#xff0c;实在抱歉了 实验原理&#xff1a; 本次实验用到的基本上是缓冲区越界&#xff0c;学过c语言的可…

AR + 通信,虚实结合让工作协同从线上到「现场」

在数字经济无所不在的当下&#xff0c;千行百业都与数智化办公接轨并因其实现转型升级。关注【融云 RongCloud】&#xff0c;了解协同办公平台更多干货。 升级的背后&#xff0c;是利用技术把工作用更自然的方式连接起来&#xff0c;让整个工作流协同更顺、体验更好。 而其中…

龙良曲PyTorch入门到实战 深度学习

文章目录 笔记激活函数与Loss的梯度lesson5 手写数字识别问题lesson6 基本数据类型lesson7 创建tensorlesson8 索引和切片lesson9 维度变换lesson10 broadcastinglesson11 分割和合并lesson12 数学运算lesson13 Tensor统计lesson14 Tensor高阶lesson16 什么是梯度lesson17 常见…

postcss-pxtorem实现页面自适应的原理

先声明一点这玩意本身不能实现哈&#xff0c;他只是一个工具&#xff0c;更是一个postcss的插件 帮助我们从px转化成为rem比如我们的代码 div {height: 100px;width: 100px; }经过这个插件转化之后变成 假设变成下面这样哈 div {height: 1rem;width: 1rem; }其他没啥子太大作…

WMMSE方法的使用笔记

标题很帅 原论文的描述WMMSE的简单应用 无线蜂窝通信系统的预编码设计问题中&#xff0c;经常提到用WMMSE方法设计多用户和速率最大化的预编码&#xff0c;其中最为关键的一步是将原和速率最大化问题转化为均方误差最小化问题&#xff0c;从而将问题由非凸变为关于三个新变量的…

【计算机组成体系结构】SRAM和DRAM

RAM — Random Access Memory 随机访问存储器 —指定某一存储单元地址的时候&#xff0c;存储单元的读取速度并不会因为存储单元的物理位置改变 SRAM即为 Static RAM 静态随机访问存储器 — 用于主存DRAM即为 Dynamic RAM 动态随机访问存储器 — 用于Cache 一、SRAM和DRAM的特…

Elasticsearch 8.9 flush刷新缓存中的数据到磁盘源码

一、相关API的handler1、接收HTTP请求的hander2、每一个数据节点(node)执行分片刷新的action是TransportShardFlushAction 二、对indexShard执行刷新请求1、首先获取读锁&#xff0c;再获取刷新锁&#xff0c;如果获取不到根据参数决定是否直接返回还是等待2、在刷新之后transl…

Jquery easyui异步提交表单的两种方式

这篇文章分享一下easyui常用的两种表单异步提交的方式。 目录 第一种&#xff1a;利用ajax提交 $.post() $.ajax() 第二种&#xff1a;使用easyui提供的表单提交方式 首先&#xff0c;准备一个简单的表单&#xff0c;包含三个输入框&#xff0c;在页面引入easyui的js文件。…

使用智能AI文心一言处理采集数据

简数采集器支持调用百度智能AI文心一言大模型API接口&#xff0c;可对采集的数据进行研究分析&#xff0c;内容创作。 文心一言API使用方法如下&#xff1a; 目录 1. 采集数据 2. 申请API 3. 对接文心一言API 4. 设置文心一言API的执行指令 5. 使用文心一言API处理采集数…

苹果mac电脑如何彻底删除卸载软件?

在苹果电脑上安装和使用软件非常容易&#xff0c;但是卸载软件却可能会变得复杂和困难。不像在Windows上&#xff0c;你不能简单地在控制面板中找到已安装的程序并卸载它们。因此&#xff0c;在这篇文章中&#xff0c;我们将讨论苹果电脑怎么彻底删除软件。 CleanMyMac X全新版…

『 C++ 』BinarySearchTree搜索二叉树

文章目录 前言 &#x1f995;二叉搜索树的概念 &#x1f995;搜索二叉树的初始化 &#x1f995;Insert( )插入函数 &#x1f995;&#x1f47e; InsertR( ) 插入函数(递归) InOrder( ) 中序遍历打印 &#x1f995;Find( ) 查找函数 &#x1f995;&#x1f47e; Find( ) 查找函数…

系列学习前端之第 2 章:一文精通 HTML

全套学习 HTMLCSSJavaScript 代码和笔记请下载网盘的资料&#xff1a; 链接: https://pan.baidu.com/s/1-vY2anBdrsBSwDZfALZ6FQ 提取码: 6666 HTML 全称&#xff1a;HyperText Markup Language&#xff08;超文本标记语言&#xff09; 1、 HTML 标签 1. 标签又称元素&#…

第二十一章总结博客

网络程序设计基础 局域网与互联网 为了实现两台计算机的通信&#xff0c;必须用一个网络线路连接两台计算机。如下图所示 网络协议 1.IP协议 IP是Internet Protocol的简称&#xff0c;是一种网络协议。Internet 网络采用的协议是TCP/IP协议&#xff0c;其全称是Transmission …

区块链媒体:Web3.0时代的推广创新10爆款策略概览-华媒舍

随着Web3.0时代的到来&#xff0c;互联网推广正经历着一场创新的革命。在这个新的时代背景下&#xff0c;一系列全新的推广策略正在兴起&#xff0c;引领着市场的变革。本文将基于这一背景&#xff0c;为大家介绍Web3.0时代中的10大爆款推广策略概览。 1. 个性化推广 在Web3.0…