培训机构Day25

news/2025/1/9 23:58:19 标签: java

今天上午花时间实现了写Servlet,实现了数据库查询显示到浏览器界面上。下午讲了如何处理多线程的访问保证线程安全。

知识点:

设计模式:面向对象的语言。对某个特定领域特定场景问题的最佳解决方案。
1.单例模式。singleton。单个实例,单个对象。
1.1 懒汉式:将实例化延迟到第一次获取实例。可以通过双检锁(Double-check)实现线程安全。
1.2 饿汉式:提前创建类的唯一实现,线程安全的。
1.3 登记式:spring框架。可以对任意类进行单例。通用的。

volatile:表示禁止指令重排,禁止优化。一旦有写操作,其它线程第一时间可以看到。

int a = 10;
int b = 20;
int c = 30;

sout(a+b+c)

xxx.properties
xxx.xml
xxx.yml

============================================
监听器:监听特定的事件,当事件发生时,进行特定的业务处理。
1.ServletContextListener:比较常用。


域对象四种:存储数据的容器。
1.页面域。
2.请求域。HttpServletRequest
3.会话域。
4.全局域。ServletContext。一个应用有唯一的一个全局域。


过滤器:

不过初版的servelt代码还是先扔出来吧:

java">package com.example.demo;

import jakarta.servlet.annotation.WebServlet;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;

import java.io.*;
import java.sql.*;

@WebServlet(name = "Search",value = "/search")
public class Search extends HelloServlet{
    // 数据库连接信息
    private static final String DB_URL = "jdbc:mysql://localhost:3306/test";
    private static final String DB_USER = "root";
    private static final String DB_PASSWORD = "*******";
    public void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException {
        // 设置响应内容类型
        response.setContentType("text/html;charset=UTF-8");
        PrintWriter out = response.getWriter();
        // 获取数据库连接
        Connection conn = null;
        PreparedStatement stmt = null;
        ResultSet rs = null;
        try {
            // 获取数据库连接
            Class.forName("com.mysql.cj.jdbc.Driver");
            conn = DriverManager.getConnection(DB_URL, DB_USER, DB_PASSWORD);

            // 查询数据库获取学生列表
            String sql = "SELECT * FROM t_student LIMIT 10";
            stmt = conn.prepareStatement(sql);
            rs = stmt.executeQuery();

            // 生成HTML页面
            out.println("<html>");
            out.println("<head><title>学生列表</title></head>");
            out.println("<body>");
            out.println("<h1>学生列表</h1>");
            out.println("<table border='1'>");
            out.println("<tr><th>ID</th><th>姓名</th></tr>");

            // 循环显示查询结果
            while (rs.next()) {
                int id = rs.getInt("id");
                String name = rs.getString("name");

                out.println("<tr>");
                out.println("<td>" + id + "</td>");
                out.println("<td>" + name + "</td>");
                out.println("</tr>");
            }

            out.println("</table>");
            out.println("</body>");
            out.println("</html>");
        } catch (Exception e) {
            e.printStackTrace();
            out.println("<h2>错误:" + e.getMessage() + "</h2>");
        } finally {
            // 关闭资源
            try {
                if (rs != null) rs.close();
                if (stmt != null) stmt.close();
                if (conn != null) conn.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }
}


http://www.niftyadmin.cn/n/5818088.html

相关文章

阿里云Chat App消息服务——智能化时代的消息交互新选择

在信息流转迅速的数字化时代&#xff0c;消息交互不仅是企业与用户连接的桥梁&#xff0c;更是提升用户体验、优化业务流程的核心环节。无论是即时通讯、系统通知&#xff0c;还是业务提醒&#xff0c;拥有一个强大、可靠的消息服务平台至关重要。阿里云Chat App消息服务&#…

通过 oh-my-posh posh-git 优化PowerShell

转自oh-my-posh & posh-git 提升在 windows 环境的开发体验 oh-my-posh 是用于自定义 PowerShell 主题和配色的工具&#xff0c;posh-git 则是为 PowerShell 提供了方便的 git 状态显示和命令补全功能。 安装PowerShell 7和 winget下载器&#xff0c;都可以直接在 Microsof…

行情系统用什么数据库好

行情系统最适合使用的数据库包括&#xff1a;关系型数据库、NoSQL数据库、时序数据库。 其中&#xff0c; 关系型数据库&#xff08;如MySQL、PostgreSQL&#xff09;具备数据一致性和事务处理能力强的特点&#xff1b;NoSQL数据库&#xff08;如MongoDB、Cassandra&#xff0…

软件工程期末整理(二)

快速原型开发模型是&#xff08;适用于客户需求难以清楚定义、规模较小的系统&#xff09;。(编写系统实施计划)不是系统设计阶段的主要活动 解释&#xff1a;系统实施计划”更侧重于后续的实施与部署阶段&#xff0c;属于项目管理层面的内容 协作性不属于构件的特性在类图中…

JuiceFS 2024:开源与商业并进,迈向 AI 原生时代

即将过去的 2024 年&#xff0c;是 JuiceFS 开源版本推出的第 4 年&#xff0c;企业版的第 8 个年头。回顾过去这一年&#xff0c;JuiceFS 社区版依旧保持着快速成长的势头&#xff0c;GitHub 星标突破 11.1K&#xff0c;各项使用指标增长均超过 100%&#xff0c;其中文件系统总…

人工智能知识分享第十天-机器学习_聚类算法

聚类算法 1 聚类算法简介 1.1 聚类算法介绍 一种典型的无监督学习算法&#xff0c;主要用于将相似的样本自动归到一个类别中。 目的是将数据集中的对象分成多个簇&#xff08;Cluster&#xff09;&#xff0c;使得同一簇内的对象相似度较高&#xff0c;而不同簇之间的对象相…

依赖注入学习

1.介绍 依赖注入&#xff08;Dependency Injection, DI&#xff09;是一种软件设计模式&#xff0c;用于实现类与其依赖项之间的解耦。它的核心思想是&#xff0c;将类所依赖的对象通过外部注入的方式传递给它&#xff0c;而不是在类内部自行创建依赖对象。通过这种方式&#…

flask后端开发(13):登录功能后端实现和钩子函数

目录 一、登录后端逻辑二、Session会话维持三、钩子函数四、前端登录与非登录状态切换 一、登录后端逻辑 还是检查页面的请求&#xff0c;是GET还是POST&#xff0c;GET一般是向服务器请求静态资源&#xff0c;POST是向服务器提交/上传信息 如果是GET&#xff0c;那就是得到静…