会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132360个问题
JAVA 全系列/第一阶段:JAVA 快速入门/飞机大战小项目训练 1291楼
JAVA 全系列/第一阶段:JAVA 快速入门/面向对象详解和JVM底层内存分析 1292楼
JAVA 全系列/第六阶段:项目管理与SSM框架/Maven 1293楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/智能电话本项目实战 1294楼

/**
 *   发送信息的线程
 */
class Send extends Thread{
    private Socket socket;
    public Send(Socket socket){
        this.socket = socket;
    }

    /**
     * 发送信息的方法
     */
    private void sendMsg(){
        Scanner scanner = null;
        PrintWriter pw = null;
        try{
            // 创建Scanner对象,通过键盘输入获取要发送的信息
            scanner = new Scanner(System.in);
            // 创建字符输出流对象 用于向socket发送信息
            pw = new PrintWriter(this.socket.getOutputStream());
            while (true) {

                // 获取键盘输入的内容
                String msg = scanner.nextLine();
                // 将键盘输入的内容发送出去
                pw.println(msg);
                // 刷新
                pw.flush();
                if("exit".equals(msg)){
                    break;
                }
            }
        }catch (Exception e){
            e.printStackTrace();
        }finally {
            try {
                if(scanner != null){
                    scanner.close();
                }
                if(pw != null){
                    pw.close();
                }
                if (this.socket != null){
                    socket.close();
                }
            }catch (Exception e){
                e.printStackTrace();
            }
        }

    }

    @Override
    public void run() {
        this.sendMsg(); 
    }
}

/**
 *   接受信息的线程
 */
class Receive extends Thread{
    private Socket socket;
    public Receive(Socket socket){
        this.socket = socket;
    }

    /**
     *  接受信息的方法
     */
    private void receiveMsg(){
        BufferedReader br = null;
        try {
            // 创建用于接受对方发送信息的流对象
            br = new BufferedReader(new InputStreamReader(this.socket.getInputStream()));
            while (true){
                String msg = br.readLine();
                System.out.println("他说:"+msg);
                if ("exit".equals(msg)){
                    break;
                }

            }
        }catch (Exception e){
            e.printStackTrace();
        }finally {
            try {
                if(br != null){
                    br.close();
                }
                if(this.socket != null){
                    this.socket.close();
                }
            }catch (Exception e){
                e.printStackTrace();
            }
        }
    }
    @Override
    public void run() {
        this.receiveMsg();
    }
}

老师我添加了一个判断是否结束聊天的判断,但是这样写运行时只能是发送信息的一方关闭,接收的不会关闭

而且发送放会先报个异常再关闭

image.png报错行数是以下两个

image.png

image.png


JAVA 全系列/第二阶段:JAVA 基础深化和提高/网络编程(旧) 1295楼
Python 全系列/第五阶段:数据库编程/mysql的使用 1297楼
JAVA 全系列/第十八阶段:亿级高并发电商项目/亿级高并发电商项目(旧) 1298楼

微信图片_20230524144651.png

JAVA 全系列/第二阶段:JAVA 基础深化和提高/IO流技术 1301楼
Python 全系列/第一阶段:Python入门/控制语句 1303楼
JAVA 全系列/预科阶段:职业规划/学习方法/程序员的基本素养和职业规划 1304楼

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<style type="text/css">
			body{
				background-color: #ffa5a5;
			.cen{
				width: 200px;
				height: 200px;
				background-color: #d5093c;
				
				/*阴影增加的方法*/
				/*水平方向的偏移 垂直方向的偏移  模糊度   阴影的颜色*/
				box-shadow: 0px 0px 70px #D5093C;
				/*执行动画的调用*/
				animation: 1s aj infinite;
			}
			.lef{
				/*倒圆角命令*/
				/*border-radius: 50px;*/
				/*前一个左上右下        后一个 右上左下*/
				/*border-radius: 10px 60px;*/
				/*编辑四个,则是顺时针方向*/
				border-radius: 100px;
				position: absolute;
				top: 200px;
				left: 200px;
			}
			.rig{
				border-radius: 100px;
				position: absolute;
				top: 200px;
				left: 339px;
			}
			.c{
				/*旋转角度*/
				transform: rotate(45deg);
				position: absolute;
				top: 269px;
				left: 271px;
			}
			/*div:hover{
				/*放大的倍数*/
				/*transform: scale(1.3);*/
				transform: translate(0px,-1px);
				box-shadow: 0px 0px 70px #D5093C;
				/*2D旋转  水平方向   垂直方向*/
				/*transform: skew(40deg,45deg);*/}
			*/
			/*CSS3中的动画-定义了一个名为aj的动画  rotate表示执行动画时都转动45°*/
			/*动画的状态   动画的调用*/
			@keyframes aj{
				0%{transform: scale(1)rotate(45deg);}
				50%{transform: scale(1.1)rotate(45deg);}
				100%{transform: scale(1)rotate(45deg);}
			}
			
		</style>
		
	</head>
	<body>
		<!--怎么操作其中两个//用id选择器
			或者起两个class名
		-->
		<div class="cen lef"></div>
		<div class="cen c"></div>
		<div class="cen rig"></div>
	</body>
</html>

加了背景颜色后把心形图给覆盖了怎么办,我那个动画也没有展示出来,是那里出了问题呀

Python 全系列/第七阶段:网页编程基础/CSS 样式 1305楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637