2022.8.3 作业

该程序展示了如何使用POSIX线程库(pthread)实现三个线程按特定顺序(ABC)打印其ID。每个线程通过条件变量进行同步,并遵循A唤醒B,B唤醒C,C唤醒A的规则,确保输出序列正确。

1、编写一个程序,开启3个 线程,这3个线程的ID分别为ABC,每个线程将自己的ID在屏幕上打印10遍,要求输出结果必须按ABC的顺序显示,如ABCABC……依次递推
提示:A只能叫醒B,B只能唤醒C,C只能唤醒A;

#include <stdio.h>	
#include <pthread.h>

#define ERROR(msg) do{\
	fprintf(stderr,"%s %d\n",__func__,__LINE__);\
	perror("msg");\
	return -1;\
}while(0)

int flag=0;
pthread_mutex_t mutex;
pthread_cond_t cond1;
pthread_cond_t cond2;
pthread_cond_t cond3;

void *aecho(void *arg)
{
	int i=0;
	while(1){
		pthread_mutex_lock(&mutex);
		if(i==10){
			pthread_cond_signal(&cond2);
			pthread_mutex_unlock(&mutex);
			break;
		}
		if(flag!=0){
			pthread_cond_wait(&cond1,&mutex);
		}
		printf("A");
		i++;
		flag=1;
		pthread_cond_signal(&cond2);
		pthread_mutex_unlock(&mutex);
	}
	pthread_exit(NULL);
}

void *becho(void *arg)
{
	int i=0;
	while(1){
		pthread_mutex_lock(&mutex);
		if(i==10){
			pthread_cond_signal(&cond2);
			pthread_mutex_unlock(&mutex);
			break;
		}
		if(flag!=1){
			pthread_cond_wait(&cond2,&mutex);
		}
		printf("B");
		i++;
		flag=2;
		pthread_cond_signal(&cond3);
		pthread_mutex_unlock(&mutex);
	}
	pthread_exit(NULL);
}

void *cecho(void *arg)
{
	int i=0;
	while(1){
		pthread_mutex_lock(&mutex);
		if(i==10){
			pthread_mutex_unlock(&mutex);
			break;
		}
		if(flag!=2){
			pthread_cond_wait(&cond3,&mutex);
		}
		printf("C\n");
		i++;
		flag=0;
		pthread_cond_signal(&cond1);
		pthread_mutex_unlock(&mutex);
	}
	pthread_exit(NULL);
}

int main(int argc, const char *argv[])
{
	if(0!=pthread_mutex_init(&mutex,NULL))
		ERROR("pthread_mutex_init");
	if(0!=pthread_cond_init(&cond1,NULL))
		ERROR("pthread_cond_init");
	if(0!=pthread_cond_init(&cond2,NULL))
		ERROR("pthread_cond_init");
	if(0!=pthread_cond_init(&cond3,NULL))
		ERROR("pthread_cond_init");

	pthread_t tida,tidb,tidc;

	if(pthread_create(&tida,NULL,aecho,NULL)!=0)
		ERROR("pthread_create");
	if(pthread_create(&tidb,NULL,becho,NULL)!=0)
		ERROR("pthread_create");
	if(pthread_create(&tidc,NULL,cecho,NULL)!=0)
		ERROR("pthread_create");

	pthread_join(tida,NULL);
	pthread_join(tidb,NULL);
	pthread_join(tidc,NULL);

	pthread_mutex_destroy(&mutex);
	pthread_cond_destroy(&cond1);
	pthread_cond_destroy(&cond2);
	pthread_cond_destroy(&cond3);
	
	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=&#39;uploads/" + fileName + "&#39; width=&#39;100&#39;><br>"); } out.println("<a href=&#39;index.jsp&#39;>返回修改</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()` 获取多选值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值