10万字208道Java经典面试题总结(2024修订版)- JavaWeb篇

🍅 作者简介:哪吒,CSDN2021博客之星亚军🏆、新星计划导师✌、博客专家💪

🍅 哪吒多年工作总结:Java学习路线总结,搬砖工逆袭Java架构师

🍅 技术交流:定期更新Java硬核干货,不定期送书活动

🍅 关注公众号【哪吒编程】,回复 1024 ,获取《10万字208道Java经典面试题总结(附答案)》2024修订版pdf,背题更方便,一文在手,面试我有

目录

      • 1、说说 Servlet 的基本架构
      • 2、说一说 Servlet 的生命周期?
      • 3、如何实现一个自定义的 servlet?
      • 4、servlet中有哪些核心类?都有什么特点?
      • 5、什么情况下调用 doGet()和 doPost()?
      • 6、request.getAttribute() 和 request.getParameter() 有何区别?
      • 7、forward 和 redirect 的区别?
      • 8、jsp 有哪些内置对象?作用分别是什么?
      • 9、jsp 有哪些动作?作用分别是什么?
      • 10、JSP 中动态 INCLUDE 与静态 INCLUDE 的区别?
      • 11、jsp 和 servlet 有什么区别?
      • 12、说一下 jsp 的 4 种作用域?
      • 13、session 和 cookie 有什么区别?
      • 14、如果客户端禁止 cookie 能实现 session 还能用吗?
      • 15、Token、Cookie、Session的区别?
      • 16、说一下 session 的工作原理?
      • 17、http 响应码 301 和 302 代表的是什么?有什么区别?
      • 18、tomcat 如何调优?
      • 19、如何增加 tomcat 的连接数?
      • 20、如何增加Tomcat的内存?
      • 21、Tomcat 有几种部署方式?

1、说说 Servlet 的基本架构

Servlet 是 Java Web 应用程序中处理客户端请求并生成响应的重要组件,它的基本架构可以分为以下几个部分:

(1)Servlet 接口

Servlet 接口是所有 Servlet 类必须实现的接口,它定义了处理客户端请求的常见方法,包括初始化、请求处理和销毁等。在 Servlet 接口中,最常见的方法包括 init()、service() 和 destroy()。

(2)Servlet 容器

Servlet 容器是负责管理和运行 Servlet 的环境,可以理解为一个 Web 服务器或者应用服务器。Servlet 容器负责加载、实例化、初始化、调用服务方法和销毁 Servlet 实例。在 Java 中,常见的 Servlet 容器包括 Tomcat、Jetty、Undertow 等。

(3)部署描述符

部署描述符是一个 XML 文件,它包含了关于 Servlet 的配置信息,包括 Servlet 名称、URL 映射、初始化参数、引入其他 Servlet 或过滤器等。在 Java Web 应用中,典型的部署描述符是 web.xml 文件。

(4)Servlet 类

Servlet 类是实现 Servlet 接口的具体类,它负责处理客户端请求并生成响应。在 Servlet 类中,通常实现了 init()、service() 和 destroy() 方法,也可以覆盖 doGet()、doPost() 等方法来处理不同类型的请求。

(5)请求和响应对象

在 Servlet 中,可以通过请求对象 HttpServletRequest 和响应对象 HttpServletResponse 来与客户端进行通信。请求对象封装了客户端发送的请求信息,而响应对象负责生成服务器返回的响应内容。

当客户端发送请求时,Servlet 容器会根据部署描述符中的映射信息选择合适的 Servlet 实例来处理请求。Servlet 实例接收到请求后,调用其 service() 方法来处理请求并生成响应。然后响应会被发回客户端。

这就是 Servlet 的基本架构,它提供了一个在 Java Web 应用程序中处理客户端请求的标准化方式,并且可以通过实现不同的 Servlet 类来实现特定的业务逻辑。

2、说一说 Servlet 的生命周期?

Servlet 的生命周期包括的阶段:

加载和实例化:当容器启动时,会根据部署描述符(web.xml)或注解等配置信息加载并实例化 Servlet。容器会创建 ServletConfig 对象,并将部署描述符中的初始化参数传递给 Servlet 实例。

初始化:在 Servlet 实例化后,容器会调用其 init() 方法来执行一些初始化任务。通常可以在 init() 方法中进行一些初始化操作,比如建立数据库连接、加载配置文件等。init() 方法只会在 Servlet 实例第一次被创建时执行一次。

服务请求:一旦初始化完成,Servlet 就可以响应客户端的请求。当客户端发送请求时,Servlet 容器会调用 Servlet 的 service() 方法来处理请求。service() 方法会根据请求类型(GET、POST 等)来调用相应的
doGet()、doPost() 等方法。这是 Servlet 生命周期中最频繁调用的阶段,用来处理客户端的请求并生成响应。

销毁:当 Servlet 容器决定将 Servlet 实例销毁时,会调用其 destroy() 方法。在 destroy() 方法中可以清理资源,比如关闭数据库连接、释放内存等。Servlet 实例销毁时会执行 destroy() 方法,代表 Servlet 生命周期的结束。

3、如何实现一个自定义的 servlet?

① 创建一个新的 Java 类,并让它继承 HttpServlet 类。这样可以确保你的类成为一个 Servlet;

② 在你的自定义类中,你需要重写 doGet 或 doPost 方法。这些方法将定义你的 Servlet 处理请求的行为;

③ 将你的自定义 Servlet 编译成 .class 文件,并将它放在 WEB-INF/classes 目录下(或者将 .class 文件打包成 .war 文件放在 webapps 目录下)。你还需要在 web.xml 文件中配置你的 Servlet。

如下所示:

<servlet>
    <servlet-name>MyServlet</servlet-name>
    <servlet-class>com.nezha.MyServlet</servlet-class>
</servlet>

<servlet-mapping>
    <servlet-name>MyServlet</servlet-name>
    <url-pattern>/myservlet</url-pattern>
</servlet-mapping>

根据实际需求,你可能需要处理初始化、销毁等其他方法。另外,你也可以使用注解来代替 web.xml 的配置。

4、servlet中有哪些核心类?都有什么特点?

(1)Servlet 接口

Servlet 接口是所有 servlet 类的基础接口。所有的 Servlet 类都必须实现这个接口,并且提供处理客户端请求的逻辑。在 Servlet 接口中定义了一系列的生命周期方法,包括 init、service 和 destroy。通过实现这些方法,可以在 servlet 实例的生命周期中执行初始化、处理请求和资源销毁等操作。

(2)HttpServlet

HttpServlet 是 Servlet 的抽象子类,它提供了专门用于处理 HTTP 请求的方法。它进一步扩展了 GenericServlet,并增加了处理 HTTP GET、POST、PUT、DELETE 等请求的方法。大多数 Web 应用程序中的 Servlet 都是继承自 HttpServlet。

(3)HttpServletRequest

代表客户端的请求信息,包含了请求行、请求头和请求体等信息,提供了获取参数、请求头数据、请求属性等方法。

(4)HttpServletResponse

代表服务器的响应信息,用于构建和发送回客户端的响应,提供了设置状态码、添加响应头、写入响应体等方法。

5、什么情况下调用 doGet()和 doPost()?

当客户端发送的请求使用了 HTTP GET 方法时,Servlet 容器会调用 Servlet 的 doGet() 方法来处理该请求。

当客户端发送的请求使用了 HTTP POST 方法时,Servlet 容器会调用 Servlet 的 doPost() 方法来处理该请求。

GET请求通常用于请求数据或查询信息,它的特点是请求的数据会附加在URL之后,并且是可见的。因此,GET请求不适合传输敏感信息,如密码或银行账户信息。

POST 请求通常用于向服务器发送数据,进行数据修改、提交或发送较大的数据等操作。比如,向服务器提交表单数据。

6、request.getAttribute() 和 request.getParameter() 有何区别?

request.getParameter() 方法用于获取客户端请求中的查询参数(GET 请求)或表单参数(POST 请求)。它返回的是一个字符串类型,用于表示指定参数名对应的参数值。

request.getAttribute() 方法用于获取在服务器端范围内共享的数据,这些数据通常是通过服务器端代码设置到请求域中的。它返回的是一个 Object 类型的数据,因此需要进行类型转换才能使用。通过 request.setAttribute() 方法设置的数据可以在同一个请求中的不同资源(如 Servlet、JSP)之间共享。

7、forward 和 redirect 的区别?

可以从三个方面来回答,处理方式、应用场景、效率。

forward是服务器内部的资源转发,浏览器地址栏不会发生变化,用户无法感知到转发过程。而redirect则是服务端通知客户端进行页面跳转,客户端会发起新的请求到指定的URL,因此浏览器地址栏会显示新的地址。

forward通常用于需要根据用户角色或其他条件来展示不同内容的情况,比如登录后根据用户权限转发到不同的管理页面。而redirect则常用于需要用户重新登录或在完成某项操作后返回上一个页面的场景,如注销后重定向到登录页面。

forward由于是服务器内部处理,通常效率较高,因为它避免了额外的网络请求和响应的延迟。而redirect因为涉及到客户端的多次请求和响应,所以效率相对较低。

8、jsp 有哪些内置对象?作用分别是什么?

  1. request,客户端的请求,用于获取客户端通过HTTP协议发送到服务器的数据,包括请求头、请求参数、请求方式等;
  2. response,服务器的响应,用于向客户端发送数据,包括设置响应头、发送响应体等;
  3. out,用于向客户端输出内容,是JSP页面中的输出流;
  4. session,表示客户端与服务器之间的一次会话,用于保存用户的状态信息,如用户登录信息、购物车数据等;
  5. application,代表整个Web应用的上下文,用于保存全局的信息,这些信息在整个Web应用中都是可见的;
  6. pageContext,提供了对JSP页面内各种对象(如request、response、session等)的访问,以及用于查找其他资源的API;
  7. config,用于获取JSP页面的初始化参数和Servlet上下文信息;
  8. page,代表JSP页面本身,可以通过它访问JSP页面的属性和方法;
  9. exception,当JSP页面发生异常时,该对象会被自动设置为抛出的异常对象,允许在JSP页面中处理异常。

9、jsp 有哪些动作?作用分别是什么?

在JSP(Java Server Pages)中,动作(Action)是一种特殊的标签,用于执行特定的操作,比如转发请求、包含文件、设置属性等。

  1. include 动作,将其他JSP或HTML页面的内容嵌入到当前JSP页面中,使得页面可以动态包含其他页面的内容。
  2. forward 动作,将请求转发到其他资源,比如转发到另一个JSP页面或Servlet,这样可以共享请求属性,并且URL会改变。
  3. param 动作,用于设置请求参数,可以将参数添加到包含或转发的请求中。
  4. setProperty 动作,用于设置JavaBean属性。
  5. getProperty 动作,用于获取JavaBean的属性值。
  6. useBean 动作,用于实例化JavaBean,如果JavaBean不存在则创建,存在则不创建。
  7. plugin 动作,用于包含插件,一般用于内嵌多媒体对象。
  8. jsp:element 动作,在JSP页面中生成XML元素。
  9. jsp:attribute 动作,定义自定义标签的属性,并为属性设置默认值。
  10. jsp:body 动作,在自定义标签中定义标签体的内容。

这些动作能够在JSP页面中实现各种功能,如包含内容、转发请求、操作JavaBean等。它们使JSP页面能够更加灵活和强大。

10、JSP 中动态 INCLUDE 与静态 INCLUDE 的区别?

(1)动态 include:

  • 动态 include 是通过 jsp:include 动作实现的,可以在运行时动态地包含另一个 JSP 页面或 Servlet 的输出。
  • 可以根据特定的条件或逻辑来决定包含哪个页面,也可以在循环中动态包含不同的页面。
  • 使用 jsp:include 标签,例如:<jsp:include page=“included.jsp”/>

(2)静态 include:

  • 静态 include 是在编译时将指定的 JSP 页面或 HTML 文件合并到当前 JSP 页面中,形成一个单一的页面。
  • 在 JSP 页面执行之前,包含的内容已经静态地合并到当前页面中了。
  • 使用 <%@ include file=“included.jsp” %> 语法,其中 file 属性指定要包含的文件。

动态 include 是在运行时进行包含,可以动态决定包含哪个页面,而静态 include 是在编译时静态地将指定文件的内容合并到当前页面中,运行时无法改变包含的内容。具体使用时需要根据实际场景来选择使用动态 include 还是静态 include。

11、jsp 和 servlet 有什么区别?

Servlet是用Java编写的服务器端程序,它的主要功能是处理客户端的请求并生成动态Web内容。Servlet是Java Web应用的基础,负责接收请求、处理请求、生成响应。

JSP本质上是一种特殊的Servlet,它允许开发者在HTML页面中直接嵌入Java代码片段(scriptlets)、JSP动作、JSP指令以及表达式等,以生成动态Web页面。JSP的主要目的是使开发者能够更容易地创建动态Web页面,而无需编写大量的Java代码。

12、说一下 jsp 的 4 种作用域?

(1)Page作用域

最窄的作用域,它仅限于当前的JSP页面。当页面处理完成后,存储在page作用域中的任何数据都将被丢弃。此作用域通常用于存储仅在当前页面中使用的临时变量。

(2)Request作用域

这个作用域涵盖了单个HTTP请求及其对应的响应。在此作用域中定义的任何数据都可以在同一请求中的多个页面之间共享,但当请求处理完毕后,这些数据就会失效。这适用于跨多个JSP页面传递数据的情况。

(3)Session作用域

此作用域与特定的用户会话相关联。在一个用户访问网站期间,该用户的所有请求都可以访问session作用域中的数据。当用户离开网站或会话超时,session中的数据才会被清除。这通常用于存储需要跟踪用户状态的信息,比如购物车内容或者登录信息。

(4)Application作用域

最宽泛的作用域,它适用于整个Web应用程序。在此作用域中声明的数据对所有用户和所有请求都是可见的,并且在整个应用程序的生命周期内都有效。常用于存储应用程序级别的信息,例如配置参数或统计信息。

13、session 和 cookie 有什么区别?

Session和Cookie的主要区别在于存储位置、存储容量以及存储有效期。

① 存储位置:Cookie数据信息存放在客户端浏览器中,而Session的数据信息存放在服务器上。

② 存储容量:Cookie的存储容量较小,一般不超过4KB,而Session的存储容量理论上没有限制,但为了服务器性能考虑,通常不会存放过多数据。

③ 存储有效期:Cookie可以设置为长时间保持,甚至可以设置到期时间来实现长期存储,而Session的失效时间通常较短,一般为会话结束或浏览器关闭时失效。

14、如果客户端禁止 cookie 能实现 session 还能用吗?

一般默认情况下,在会话中,服务器存储 session 的 sessionid 是通过 cookie 存到浏览器里。

如果浏览器禁用了 cookie,浏览器请求服务器无法携带 sessionid,服务器无法识别请求中的用户身份,session失效。

但是可以通过其他方法在禁用 cookie 的情况下,可以继续使用session。

  1. 通过url重写,把 sessionid 作为参数追加的原 url 中,后续的浏览器与服务器交互中携带 sessionid 参数。
  2. 服务器的返回数据中包含 sessionid,浏览器发送请求时,携带 sessionid 参数。
  3. 通过 Http 协议其他 header 字段,服务器每次返回时设置该 header 字段信息,浏览器中 js 读取该 header 字段,请求服务器时,js设置携带该 header 字段。

15、Token、Cookie、Session的区别?

Token 是一种用于认证和授权的令牌,通常由服务器生成并发送给客户端。客户端在收到 Token 后,将其存储在本地,然后在每次需要进行身份验证或授权时使用该 Token。常见的 Token 包括 JWT (JSON Web Token) 和 OAuth Token。Token 在客户端和服务器之间进行持久性的认证和授权,通常用于实现跨域身份验证。

Cookie 是一种在客户端中存储的小型文本数据,由服务器发送给客户端,随后在每次请求中通过 HTTP 头部发送回服务器。通常用于存储用户的身份验证信息、用户设置、浏览历史等。Cookie 是存储在客户端的,可以设置过期时间和路径,不同页面之间共享。

Session 是服务器端用于存储用户会话状态的机制,通常使用 Session ID 来标识用户会话。当用户第一次访问服务器时,服务器会为其创建一个 session,然后将 session ID 存储在 cookie 或者 URL 中,用于在该用户的后续请求中进行身份验证和状态管理。Session 数据存储在服务器端,相对于 Cookie 更安全、更难被篡改,但也需要服务器维护和消耗更多的资源。

16、说一下 session 的工作原理?

① 客户端发送请求:当用户发送请求到服务器时,服务器会为该用户创建一个唯一识别的 session ID,并将其返回给客户端,在 HTTP Response Header 中可以使用 Set-Cookie 来设置这个 session ID。通常情况下,这个 session ID 会以一个名为 “JSESSIONID” 的 Cookie 存储在客户端。

② 服务器端存储会话数据:当服务器收到客户端的请求时,会检查请求中是否包含有效的 session ID。如果存在有效的 session ID,服务器就会使用这个 session ID 来获取对应的会话数据。如果没有有效的 session ID,服务器会创建一个新的 session,并为其分配一个新的 session ID。服务器端会针对每个 session ID 维护一个对应的会话数据存储,可以存储用户的身份验证信息、用户设置、购物车数据等用户会话相关的信息。

③ 与客户端交互:在处理完客户端的请求后,服务器会将 session ID 返回给客户端,在 HTTP Response Header 中使用 Set-Cookie。客户端会存储这个 session ID,在后续的请求中将其包含在 HTTP 请求头中,服务器通过 session ID 来识别用户,并获取对应的会话数据进行处理。

④ 会话超时和销毁:在一定的时间间隔后,若用户没有活动,服务器可能会认为该会话已经超时并销毁会话数据,释放资源。这样可以保证服务器的资源不会被无效的会话占用。

简而言之,Session 的工作原理是通过在服务器端创建、存储和管理会话数据,并通过在客户端使用 session ID 进行身份验证和状态管理,实现用户会话的跟踪和状态维护。

17、http 响应码 301 和 302 代表的是什么?有什么区别?

http 响应码 301:

  • 301表示请求的资源已经永久移动到了一个新的 URL 地址。
  • 当服务器返回 301 状态码时,它会在响应头中包含一个 Location 属性,客户端会根据该属性进行重定向。
  • 客户端在后续的请求中会直接请求新的 URL 地址。

http 响应码 302:

  • 302示请求的资源暂时性地移动到了一个新的 URL 地址。
  • 客户端会在收到响应后根据 Location 头信息跳转到新的 URL。但客户端在后续的请求中会继续请求原来的 URL 地址。
  • 302 响应不会被浏览器缓存,每次请求时会重新执行跳转。

18、tomcat 如何调优?

调整Tomcat的性能和优化配置是提高Web应用程序性能的重要步骤。

以下是一些优化Tomcat的常见方法:

(1)调整内存分配

将JVM最大堆大小(-Xmx)和初始堆大小(-Xms)设置为合适的值,以确保应用程序运行期间有足够的内存,一般建议堆的最大值设置为可用内存的最大值的 80%。

调整新生代和老年代的比例,可以使用参数 -XX:NewSize 和 -XX:MaxNewSize 调整新生代堆大小。

(2)调整线程池和连接池

配置Tomcat的连接和线程池大小,确保它能够处理预期的并发请求,可以通过调整 maxThreads、minSpareThreads 和 maxConnections 等参数进行配置。

使用合适的连接池,例如对于数据库连接,可以使用连接池来管理连接,以提高性能和资源利用率。

(3)启用压缩

启用Tomcat的压缩功能,可以通过配置启用GZIP压缩,减小传输内容的大小,提高性能。

(4)优化静态资源处理

使用独立的Web服务器(如Nginx或Apache)作为前置服务器,处理静态资源和缓存请求,减轻Tomcat服务器负担。

针对Tomcat内置的静态资源缓存,可以通过配置添加Expires或Cache-Control响应头来缓存静态资源。

(5)监控和调整

使用监控工具如JConsole、JVisualVM或者性能工具如VisualVM来监控Tomcat性能,识别性能瓶颈并做相应调整。

根据监控结果,适时调整JVM和Tomcat的配置参数,以优化性能。

19、如何增加 tomcat 的连接数?

  1. maxConnections参数决定了Tomcat能够同时处理的最大连接数。在BIO模式下,默认最大连接数是它的最大线程数(一般设置为200)。
  2. maxThreads参数表示Tomcat接收客户端请求的最大线程数,即同时处理任务的个数。在高并发的I/O密集型应用中,这个值可以设置为1000左右以提升处理能力。
  3. 使用NIO模式,因为NIO是非阻塞的IO,可以提高Tomcat在高并发环境下的性能。
  4. 调整acceptCount,当线程数量达到maxThreads设置的值时,acceptCount决定了所能接受的最大排队数量,超过这个值,新的请求会被拒绝。
  5. 如果单个Tomcat实例无法满足需求,可以考虑使用负载均衡器将流量分发到多个Tomcat实例。

20、如何增加Tomcat的内存?

要增加 Tomcat 的内存,你需要调整 Tomcat 运行时的JVM参数。以下是一般步骤:

① 找到 Tomcat 的启动脚本

Tomcat 的启动脚本通常位于 bin 目录下,具体文件名可能是 catalina.sh (Linux) 或 catalina.bat (Windows)。

② 编辑启动脚本,设置 JVM 参数

在启动脚本中找到 JAVA_OPTS 或 CATALINA_OPTS 变量,并增加 -Xmx 和 -Xms 参数来分别设置最大堆和初始堆大小。

示例:

CATALINA_OPTS=“$CATALINA_OPTS -Xms512m -Xmx1024m”
这将会将初始堆大小设置为512MB,最大堆大小设置为1024MB。你可以根据实际情况调整这些值。

③ 重启 Tomcat 服务器

保存启动脚本并重启 Tomcat 服务器,以应用新的内存设置。

21、Tomcat 有几种部署方式?

① 将WAR包或文件夹直接放置到Tomcat的webapps目录下,Tomcat会自动解压并部署项目,缺点是需要重启项目。

② 不想放在webapps下,也可以在Tomcat的server.xml文件中配置标签,添加标签来指定项目的WAR包路径。(一般采用①)。

③ 可以将Tomcat运行在Docker容器中,通过Dockerfile或者docker-compose文件来管理和部署应用程序。

④ 可以将 Tomcat 应用部署到云服务提供商(如AWS、Azure、Google Cloud等)的云服务器上,实现灵活的弹性部署,按需分配资源。


3万字80道Java经典面试题总结(2024修订版)- Java基础篇

2 万字 42 道Java经典面试题总结(2024修订版)- Java集合篇

4 万字 102 道Java经典面试题总结(2024修订版)- 多线程篇

10万字208道Java经典面试题总结(2024修订版)- SSM篇


🏆文章收录于:100天精通Java从入门到就业

全网最细Java零基础手把手入门教程,系列课程包括:Java基础、Java8新特性、Java集合、高并发、性能优化等,适合零基础和进阶提升的同学。

🏆哪吒多年工作总结:Java学习路线总结,搬砖工逆袭Java架构师

华为OD机试 2023B卷题库疯狂收录中,刷题点这里

刷的越多,抽中的概率越大,每一题都有详细的答题思路、详细的代码注释、样例测试,发现新题目,随时更新,全天CSDN在线答疑。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

ssm项目后端如何导出war及前端如何导出静态资源

后端如何导出war包 后端工具&#xff1a;IDEA 2020.1.3 运行我们编写工具maven里面的package 运行成功的日志 我们运行完&#xff0c;会生成一个target文件夹&#xff0c;在这个文件夹里面找到war包即可 前端如何导出静态资源 使用工具&#xff1a;WebStorm 2020.1.3 打开左…

xLua详解

目录 环境准备xLua导入 C#调用LuaLua解析器Lua文件加载重定向Lua解析管理器全局变量的获取全局函数的获取List和Dictionary映射table类映射table接口映射tableLuaTable映射table Lua调用C#准备工作Lua使用C#类Lua调用C#枚举Lua使用C# 数组 List 字典数组List字典 Lua使用C#扩展…

读天才与算法:人脑与AI的数学思维笔记12_数学的艺术

1. 数学 1.1. 灵光乍现&#xff0c;从来都是厚积薄发 1.1.1. 亨利庞加莱&#xff08;Henri Poincar&#xff09; 1.2. 数学的起源可以追溯到人类试图理解自己所生活的环境&#xff0c;预测接下来会发生什么&#xff0c;从而使我们更加适应环境&#xff0c;并选择对我们有利的…

Python-VBA函数之旅-map函数

目录 一、map函数的常见应用场景 二、map函数使用注意事项 三、如何用好map函数&#xff1f; 1、map函数&#xff1a; 1-1、Python&#xff1a; 1-2、VBA&#xff1a; 2、推荐阅读&#xff1a; 个人主页&#xff1a;神奇夜光杯-CSDN博客 一、map函数的常见应用场景 ma…

Jammy@Jetson Orin - Tensorflow Keras Get Started: Concept

JammyJetson Orin - Tensorflow & Keras Get Started: Concept 1. 源由2. 模型2.1 推理流程2.1.1 获取图像2.1.2 算法识别2.1.3 判断决策 2.2 理想情况2.2.1 多因素输入2.2.2 理想识别概率 2.3 学习过程2.3.1 标记训练集2.3.2 损失函数2.3.3 训练网络2.3.4 渐进方法 3. 总…

使用Docker部署Jupyter Notebook并结合花生壳的内网穿透实现远程访问(详文)

一、前言 本文主要介绍如何利用宝塔面板中的Docker 3.9.3管理器,使用Docker本地部署Jupyter Notebook,并结合花生壳内网穿透工具实现任意浏览器公网远程访问Jupyter登录界面。 安装完成后在宝塔面板中图例 Jupyter Notebook是一个交互式笔记本,支持运行40多种编程语言。…

Vue 组件单元测试深度探索:组件交互与状态变更 专业解析和实践

在Vue组件单元测试中&#xff0c;验证组件之间的交互&#xff08;如父组件与子组件、兄弟组件之间的通信&#xff09;以及状态变更的正确性对于保证整个应用的协调运作至关重要。本文详细介绍了父组件向子组件传递props、子组件向父组件发送事件、兄弟组件通过共享状态&#xf…

xfce4 panel 不能显示QQ,钉钉的状态图标

有一段时间不能显示了&#xff0c;之前刚装完系统的时候很长时间内都是好的&#xff0c;所以刚开始肯定是支持显示这些状态图标的。就是因为不能显示的原因&#xff0c;所以还装了lxQt桌面&#xff0c;这个桌面确实不错。不过还是有时会怀念xfce4&#xff0c;想看看能不能解决这…

Odoo:全球排名第一的免费开源PLM管理系统介绍

概述 利用开源智造OdooPLM产品生命周期管理应用&#xff0c;重塑创新 实现产品生命周期管理数字化&#xff0c;高效定义、开发、交付和管理创新的可持续产品&#xff0c;拥抱数字化供应链。 通过开源智造基于Odoo开源技术平台打造数字化的产品生命周期管理&#xff08;PLM&am…

Java UUID 类中的 getMostSignificantBits 和 leastSignificantBits 方法

getMostSignificantBits() 方法的一些介绍&#xff1a; getMostSignificantBits 这个方法主要用于在 UUID 中获取高64 位的有效位后返回 Long 数据类型。 在获取最高有效位时不会引发异常。 对应的还有一个 getLeastSignificantBits() 方法。 这个方式是从 UUID 中获取低 6…

阳光能源,创造永远:光模块的未来”:随着大数据、区块链、云计算和5G的发展,光模块成为满足不断增长的数据流量需求的关键技术

光模块的类型介绍&#xff1a; 为了适应不同的应用需求&#xff0c;不同参数和功能的光模块应运而生。光模块的分类方式及类型详见如下&#xff1a; &#x1f50e;封装形式&#x1f50d;&#xff1a; &#x1f4e3;&#x1f4e2;光模块按照封装形式来分有以下几种常见类型&a…

如何将本地Android studio项目上传到GitHub

操作步骤&#xff1a; 1、在GitHub上创建账户 2、在androd studio中添加上述创建的GitHub账号 3、在android studio上找到"share project on GitHub"&#xff0c;点击此选项上传当前项目到GitHub 上传成功后&#xff0c;会在GitHub上创建默认仓库repository 注&a…

LeetCode - LCR 008.长度最小的子数组

一. 题目链接 LeetCode - 209. 长度最小的子数组 二. 思路分析 由于此问题分析的对象是「⼀段连续的区间」&#xff0c;因此可以考虑「滑动窗口」的思想来解决这道题。 让滑动窗口满足&#xff1a;从 i 位置开始&#xff0c;窗口内所有元素的和小于target &#xff08;那么当…

图像处理到神经网络:线性代数的跨领域应用探索

作者介绍&#xff1a;10年大厂数据\经营分析经验&#xff0c;现任大厂数据部门负责人。 会一些的技术&#xff1a;数据分析、算法、SQL、大数据相关、python 欢迎加入社区&#xff1a;码上找工作 作者专栏每日更新&#xff1a; LeetCode解锁1000题: 打怪升级之旅 python数据分析…

Python爬虫--Scrapy框架安装

Scrapy框架安装 &#xff0c; Scrapy 是 Python 领域专业的爬虫开发框架&#xff0c;已经完成爬虫程序的大部分通用工具 它使用了 Twisted 异步网络库来处理网络通讯。整体架构大致如下 第一步&#xff1a;挂小灰机或者将要安装的文件下载到本地 Scrapy 框架安装踩坑中 为什…

ubuntu的镜像源+bionic版本

首先第一步 查找和你自己ubuntu版本匹配的版本号 匹配代号如下 在终端输入lsb_release -a查看自己系统上的版本号 可以看到我这个版本号的代号是bionic。 每个版本的镜像文件都是有规律的。 bionic版本的源如下 # 阿里源 deb http://mirrors.aliyun.com/ubuntu/ bionic ma…

前端用a标签实现静态资源文件(excel/word/pdf)下载

接上文实现的 前端实现将二进制文件流&#xff0c;并下载为excel文件后&#xff0c; 实际项目中一般都会有一个模版下载的功能&#xff0c;一般都由服务端提供一个下载接口&#xff0c;返回文件流或url地址&#xff0c;然后前端再处理成对应需要的类型的文件。 但是&#xff…

HTML5(1)

目录 一.HTML5(超文本&#xff08;链接&#xff09;标记&#xff08;标签<>&#xff09;语言) 1.开发环境&#xff08;写代码&#xff0c;看效果&#xff09; 2.vscode 使用 3.谷歌浏览器使用 4.标签语法 5.HTML基本骨架&#xff08;网页模板&#xff09; 6.标签的…

排序 “肆” 之归并排序

1. 归并排序 1.1 原理介绍 归并排序的基本原理是将一个未排序的数组分解为较小的子数组&#xff0c;然后递归地对这些子数组进行排序&#xff0c;最后再将排好序的子数组合并成一个有序数组。其核心操作是将一维数组中前后相邻的两个有序序列归并为一个有序序列。 其主要步骤包…

【区块链】椭圆曲线数字签名算法(ECDSA)

本文主要参考&#xff1a; 一文读懂ECDSA算法如何保护数据 椭圆曲线数字签名算法 1. ECDSA算法简介 ECDSA 是 Elliptic Curve Digital Signature Algorithm 的简称&#xff0c;主要用于对数据&#xff08;比如一个文件&#xff09;创建数字签名&#xff0c;以便于你在不破坏它…