2022.8.23 作业

本文展示了如何在C++中实现一个名为`mystring`的自定义字符串类,包括构造函数、析构函数、拷贝构造函数、拷贝赋值运算符以及一些辅助方法如`myEmpty`、`mySize`、`myStr`等。通过实例展示了如何创建和操作`mystring`对象,如`s1`、`s2`和`s3`,并调用`display`方法显示其内容。

 

#include <iostream>

using namespace std;

class mystring {
public:
    //无参构造函数
    mystring()
    {
        len=0;
        str=nullptr;
    }

    //析构函数
    ~mystring()
    {
        if(str!=nullptr){
            delete []str;
        }
    }

    //有参构造函数
    mystring(const char *_str)
    {
        len=mystrlen(_str);
        str=new char[len+1];
        mystrcpy(str,_str);
    }

    //拷贝构造函数
    mystring(const mystring &operation)
    {
        len=operation.len;
        str=new char[len+1];
        mystrcpy(str,operation.str);
    }

    //拷贝复制函数
    mystring &operator=(const mystring &operation)
    {
        if(this!=&operation){
            len=operation.len;
            str=new char[len+1];
            mystrcpy(str,operation.str);
        }
        return *this;
    }

    bool myEmpty()
    {
        return str==nullptr?true:false;
    }

    int mySize()
    {
        return len;
    }

    const char *myStr()
    {
        return (const char *)str;
    }

    int mystrlen(const char *src)
    {
        const char *ch=src;
        while(*ch!='\0'){
            ch++;
        }
        return ch-src;
    }

    char *mystrcpy(char *dest,const char *src)
    {
        char *ch=dest;
        while(*src!='\0'){
            *(ch++)=*(src++);
        }
        *ch='\0';
        return dest;
    }

    void display()
    {
        cout<<"size="<<mySize()<<endl;
        cout<<"str="<<myStr()<<endl;
        cout<<"Is empty: "<<(myEmpty()?"yes":"no")<<endl;
    }
private:
    char *str;
    int len;
};

int main()
{
    mystring s1("zhangsan");
    mystring s2(s1);
    mystring s3;
    s3=s1;

    s1.display();
    cout<<"**********************"<<endl;
    s2.display();
    cout<<"**********************"<<endl;
    s3.display();

    return 0;
}

 

![](https://cdn.jsdelivr.net/gh/dzg123456/CDN@main/images/20251125143855.png) ### 题目重述 实验题: 1. 创建一个 JSP 页面,包含表单(`form`),支持输入文本、单选按钮、复选框、图片上传,并有提交功能。 2. 提交后跳转到一个 Servlet,显示用户输入的文本、单选结果、复选框结果及上传的图片。 要求:将代码和运行效果图截图作为附件提交。 --- ### 详解(基于 IntelliJ IDEA 2022.1.3 的完整操作步骤) #### ✅ 第一步:创建 Maven Web 项目 1. 打开 **IntelliJ IDEA 2022.1.3**。 2. 选择 `New Project` → `Maven Archetype`。 3. 在 archetype 中选择:`maven-archetype-webapp`。 4. 输入项目信息: - GroupId:如 `com.example` - ArtifactId:如 `jsp-servlet-demo` - Version:1.0-SNAPSHOT 5. 点击 `Finish` 完成创建。 > 若未自动识别为 Web 模块,在 `Project Structure` → `Modules` 中勾选 “Web” 支持并配置 `web.xml` 路径。 --- #### ✅ 第二步:添加必要依赖(`pom.xml`) 打开 `pom.xml`,添加以下依赖以支持 JSP、Servlet 和文件上传: ```xml <dependencies> <!-- Servlet API --> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>4.0.1</version> <scope>provided</scope> </dependency> <!-- JSP API --> <dependency> <groupId>javax.servlet.jsp</groupId> <artifactId>jsp-api</artifactId> <version>2.2</version> <scope>provided</scope> </dependency> <!-- JSTL 可选(用于增强 JSP 功能) --> <dependency> <groupId>javax.servlet</groupId> <artifactId>jstl</artifactId> <version>1.2</version> </dependency> </dependencies> <!-- 构建插件 --> <build> <finalName>jsp-servlet-demo</finalName> <plugins> <plugin> <groupId>org.apache.tomcat.maven</groupId> <artifactId>tomcat7-maven-plugin</artifactId> <version>2.2</version> <configuration> <port>8080</port> <path>/</path> </configuration> </plugin> </plugins> </build> ``` --- #### ✅ 第三步:创建 JSP 页面(`index.jsp`) 路径:`src/main/webapp/index.jsp` ```jsp <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head><title>用户表单</title></head> <body> <h2>用户信息填写</h2> <form action="DisplayServlet" method="post" enctype="multipart/form-data"> 姓名: <input type="text" name="name" required><br><br> 性别: <input type="radio" name="gender" value="男" checked> 男 <input type="radio" name="gender" value="女"> 女<br><br> 兴趣爱好: <input type="checkbox" name="hobby" value="阅读"> 阅读 <input type="checkbox" name="hobby" value="运动"> 运动 <input type="checkbox" name="hobby" value="音乐"> 音乐<br><br> 头像上传: <input type="file" name="avatar" accept="image/*"><br><br> <input type="submit" value="提交"> </form> </body> </html> ``` --- #### ✅ 第四步:创建 Servlet(`DisplayServlet.java`) 路径:`src/main/java/com/example/DisplayServlet.java` ```java package com.example; import javax.servlet.*; import javax.servlet.http.*; import javax.servlet.annotation.*; import java.io.IOException; import java.io.PrintWriter; @WebServlet("/DisplayServlet") @MultipartConfig( maxFileSize = 10485760 // 10MB ) public class DisplayServlet extends HttpServlet { protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { request.setCharacterEncoding("UTF-8"); response.setContentType("text/html;charset=UTF-8"); PrintWriter out = response.getWriter(); String name = request.getParameter("name"); String gender = request.getParameter("gender"); String[] hobbies = request.getParameterValues("hobby"); Part filePart = request.getPart("avatar"); String fileName = filePart.getSubmittedFileName(); // 返回 HTML 页面 out.println("<!DOCTYPE html>"); out.println("<html><head><title>结果页</title></head><body>"); out.println("<h2>您提交的信息如下:</h2>"); out.println("姓名:" + name + "<br>"); out.println("性别:" + gender + "<br>"); out.println("兴趣爱好:"); if (hobbies != null) { for (String h : hobbies) { out.print(h + " "); } } else { out.print("无"); } out.println("<br>"); if (fileName != null && !fileName.isEmpty()) { // 保存文件(示例路径) String uploadPath = getServletContext().getRealPath("/") + "uploads/"; java.nio.file.Path path = java.nio.file.Paths.get(uploadPath + fileName); filePart.write(path.toString()); out.println("头像:<img src='uploads/" + fileName + "' width='100'><br>"); } out.println("<a href='index.jsp'>返回修改</a>"); out.println("</body></html>"); } } ``` > ⚠️ 注意:首次编译可能报错“无法找到 Servlet 类”,请确认 SDK 已设置为 Java 8 或 11,并在模块中引入 `Tomcat` 库或使用 `provided` 依赖。 --- #### ✅ 第五步:配置 web.xml(可选) 路径:`src/main/webapp/WEB-INF/web.xml` ```xml <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd" version="4.0"> <display-name>JSP Servlet Demo</display-name> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> </web-app> ``` --- #### ✅ 第六步:运行项目 1. 确保已安装 Tomcat 插件或本地配置了 Tomcat Server。 2. 推荐使用内置 Maven 插件运行: - 打开 Maven 工具栏 → `Plugins` → `tomcat7:run` - 或在 Terminal 执行: ```bash mvn tomcat7:run ``` 3. 浏览器访问:`http://localhost:8080` --- #### ✅ 第七步:测试与截图 1. 填写表单,选择一张图片,点击“提交”。 2. 查看跳转后的页面是否正确显示所有信息(含图片)。 3. 截图两张: - 第一张:`index.jsp` 表单界面 - 第二张:`DisplayServlet` 显示结果页(含图片) 4. 将代码文件与截图打包提交作业附件。 --- ### 知识点(列出该代码中遇到的知识点) 1. **JSP 与 Servlet 数据交互** JSP 负责前端展示,通过 form 提交数据至 Servlet 处理业务逻辑。 2. **文件上传处理(`@MultipartConfig` 与 `Part`)** 必须设置 `enctype="multipart/form-data"`,使用 `getPart()` 获取上传文件。 3. **HTTP 请求参数获取方法** `getParameter()` 获取单值(如文本、单选),`getParameterValues()` 获取多选值。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值