会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132462个问题

image.png

Python 全系列/第一阶段:Python入门/序列 9406楼

package com.bjsxt.thread;

/**
 * 使用this作为对象锁
 * 使用字符串作为对象锁
 * 使用class对象作为对象锁
 */
/**
 * 定义销售员工类
 */
class Sale{
    private String name;
    public Sale(String name){
        this.name = name;
    }
    public void  money(){
        synchronized ("s") {
            try {
                System.out.println(this.name +
                        " 被领导表扬");
                Thread.sleep(500);
                System.out.println(this.name +
                        " 拿钱");
                Thread.sleep(500);
                System.out.println(this.name +
                        " 对公司表示感谢");
                Thread.sleep(500);
                System.out.println(this.name +
                        " 开开心心的拿钱走人");
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}
class Programmer{
    private String name;
    public Programmer(String name){
        this.name = name;
    }
    /**
     * 打开电脑
     */
    public void computer(){
        synchronized (this) {
            try {
                System.out.println(this.name + " 接通电源");
                Thread.sleep(500);
                System.out.println(this.name + " 按开机按键");
                Thread.sleep(500);
                System.out.println(this.name + " 系统启动中");
                Thread.sleep(500);
                System.out.println(this.name + " 系统启动成功");
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
    /**
     * 编码
     */
    public void  coding(){
        synchronized (this){
            try {
                System.out.println(this.name + " 双击 Idea");
                Thread.sleep(500);
                System.out.println(this.name + " Idea 启动完毕");
                Thread.sleep(500);
                System.out.println(this.name + " 开开心心的写代码");
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
    /**
     * 去卫生间
     */
    public void wc(){
        synchronized ("wc") {
            try {
                System.out.println(this.name + " 打开卫生间门");
                Thread.sleep(500);
                System.out.println(this.name + " 开始排泄");
                Thread.sleep(500);
                System.out.println(this.name + " 冲水");
                Thread.sleep(500);
                System.out.println(this.name + " 离开卫生间");
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
    /**
     * 领取奖金
     */
    public void money(){
        synchronized ("p") {
            try {
                System.out.println(this.name + " 被领导表扬");
                Thread.sleep(500);
                System.out.println(this.name + " 拿钱");
                Thread.sleep(500);
                System.out.println(this.name + " 对公司表示感谢");
                Thread.sleep(500);
                System.out.println(this.name + " 开开心心的拿钱走人");
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}

/**
 * 打开电脑的工作线程
 */
class Working1 extends Thread{
    private Programmer p;
    public Working1(Programmer p){
        this.p = p;
    }
    @Override
    public void run() {
        this.p.computer();
    }
}

/**
 * 编写代码的工作线程
 */
class Working2 extends Thread{
    private Programmer p;
    public Working2(Programmer p){
        this.p = p;
    }
    @Override
    public void run() {
        this.p.coding();
    }
}

/**
 * 去厕所的线程
 */
class Wc extends Thread{
    private Programmer p;
    public Wc(Programmer p){
        this.p = p;
    }
    @Override
    public void run() {
        this.p.wc();
    }
}
/**
 * 销售部领取奖金的线程
 */
class SaleMoney extends Thread{
    private Sale s;
    public SaleMoney(Sale s){
        this.s = s;
    }
    @Override
    public void run() {
        this.s.money();
    }
}
/**
 * 程序员领取奖金的线程
 */
class ProgrammerMoney extends Thread{
    private Programmer p;
    public ProgrammerMoney(Programmer p){
        this.p = p;
    }
    @Override
    public void run() {
        this.p.money();
    }
}
public class ObjectLock {
    public static void main(String[] args) {
        /*Programmer zs = new Programmer("张三");
        new Working1(zs).start();
        new Working2(zs).start();*/
        /*Programmer zs = new Programmer("张三");
        Programmer ls = new Programmer("李四");
        Programmer wu = new Programmer("王五");
        new Wc(zs).start();
        new Wc(ls).start();
        new Wc(wu).start();*/
        Programmer ls = new Programmer("李四");
        Programmer wu = new Programmer("王五");
        Sale s1 = new Sale("王丽丽");
        Sale s2 = new Sale("王莉莉");
        //new ProgrammerMoney(ls).start();
        //new ProgrammerMoney(wu).start();
        new SaleMoney(s1).start();
        new SaleMoney(s2).start();
    }
}

老师,用字符串作为对象锁也可以实现各自部门的人去各自部门串行领取奖金,达到和使用class对象作为锁一样的效果。都是可以对多个线程操作多个对象进行同步。前面同学问的问题我看了,字符串可以是不同类,Class只能是同一个类。所以意思各有各的应用场景,但是有时候也能达到一样的效果。

老师,这是我总结的您看一下

this:多个线程操作同一个对象可以实现同步效果

字符串:所有线程操作到具有synchrunized(字符串)的就会实现同步效果

class对象:当多个线程操作到通过同一个类实例化的对象的时候会实现同步效果

JAVA 全系列/第二阶段:JAVA 基础深化和提高/多线程技术(旧) 9408楼
JAVA 全系列/第六阶段:项目管理与SSM框架/Mybatis 9411楼
Python 全系列/第一阶段:Python入门/编程基本概念 9412楼
JAVA 全系列/第一阶段:JAVA 快速入门/JAVA入门和背景知识 9413楼

问题点:为什么我用JAVA查询出的数据是相同的而实际在MySQL查询的值是如下图所示

JdbcTest

package cn.bjsxt.jdbc5;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;

import cn.bjsxt.jdbc2.jdbcUtil;

public class JdbcTest {
	public void insertDempartments(String departmentName,int locationId){
	Connection conn = null;
	PreparedStatement pr = null;
	try{
		conn = JdbcUtil.getConnection();
		pr = conn.prepareStatement("insert into departments values(default,?,?)");
		pr.setString(1,departmentName);
		pr.setInt(2, locationId);
		pr.execute();
	}catch(Exception e){
		e.printStackTrace();
	}finally{
		jdbcUtil.closeResource(pr, conn);
	}
	}
	public void updateDempartments(int department_id,String department_name,int location){
		Connection conn = null;
		PreparedStatement pr = null;
		try{
			conn = JdbcUtil.getConnection();
			pr = conn.prepareStatement("update departments set department_name = ?,location_id = ? where department_id = ?");
			pr.setString(1, department_name);
			pr.setInt(2,location);
			pr.setInt(3, department_id);
			pr.execute();
		}catch(Exception e){
			e.printStackTrace();
		}
	}
	public Departments selectDepartment(int departmentId){
		Connection conn = null;
		PreparedStatement pr = null;
		ResultSet re = null;
		Departments dept = null;
		try{
			conn = JdbcUtil.getConnection();
			pr = conn.prepareStatement("select * from departments where department_id = ?");
			pr.setInt(1, departmentId);
			re=pr.executeQuery();
			while(re.next()){
			dept = new Departments();
			dept.setDepartmentId(re.getInt("department_id"));
			dept.setLocation(re.getInt("location_id"));
			dept.setDepartmentName(re.getString("department_name"));
			}
			}catch(Exception e){
			e.printStackTrace();
			
			
		}finally{
			JdbcUtil.closeResorce(conn, re, pr);
		}
		return dept;
	}
	public List<Departments> selectDepartmentByLikeName(String departmentName){
		Connection conn = null;
		PreparedStatement ps = null;
		ResultSet rs = null;
		List<Departments> list = new ArrayList<>();
		try{
			conn = JdbcUtil.getConnection(); 
			ps = conn.prepareStatement("select * from departments where department_name like ?");
			ps.setString(1, "%"+departmentName+"%");
			rs = ps.executeQuery();
			while(rs.next()){
				Departments dept = new Departments();
				 dept.setDepartmentId(rs.getInt("department_id"));
				 dept.setDepartmentName(rs.getString("department_name"));
				 dept.setLocation(rs.getInt("location_id"));
				 list.add(dept);
			}
			
		}catch(Exception e){
			e.printStackTrace();
		}finally{
			JdbcUtil.closeResorce(conn, rs, ps);
		}
		return list;
	}
	
	public static void main(String [] args){
		JdbcTest jdbc = new JdbcTest();
		//jdbc.insertDempartments("人力资源部3",10);
		//jdbc.updateDempartments(8, "人力资源部1", 10);
		/*Departments dept = jdbc.selectDepartment(8);
		if(dept!=null){
			System.out.println(dept.getDepartmentId()+" "+dept.getDepartmentName()+" "+dept.getLocation());
		}*/
		List<Departments> list = jdbc.selectDepartmentByLikeName("人力");
		for(Departments d:list){
			System.out.println(d.getDepartmentId()+" "+d.getDepartmentName()+" "+d.getLocation());
		}
	
	}

}

JdbcUtil:

package cn.bjsxt.jdbc5;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ResourceBundle;

public class JdbcUtil {
	private static String driver;
	private static String jdbcUrl;
	private static String username;
	private static String userpassword;
	static{
		//读取Properties文件
		ResourceBundle bundle = ResourceBundle.getBundle("jdbc");
		driver = bundle.getString("driver");
		jdbcUrl = bundle.getString("jdbcUrl");
		username = bundle.getString("username");
		userpassword = bundle.getString("userpassword");
		try {
			Class.forName(driver);
		} catch (ClassNotFoundException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
	//获取Connection对象
	public static Connection getConnection(){
		Connection conn = null;
		
		try{
		conn = DriverManager.getConnection(jdbcUrl,username,userpassword);	
		}catch(Exception e){
			e.printStackTrace();
		}
		return conn;
	}
	//关闭Statement
	public static void closeStatiemt(Statement state){
		if(state!=null){
			try {
				state.close();
			} catch (SQLException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
		}
	}
	//关闭Connection
	public static void closeConnection(Connection conn){
		if(conn!=null){
			try{
				conn.close();
			}catch(Exception e){
				e.printStackTrace();
			}
		}
	}
	//关闭ResultSet
	public static void closeResultSet(ResultSet re){
		if(re!=null){
			try {
				re.close();
			} catch (SQLException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
		}
	}
	//关闭资源
	public static void closeResorce(Connection conn,ResultSet re,Statement state){
		JdbcUtil.closeConnection(conn);
		JdbcUtil.closeResultSet(re);
		JdbcUtil.closeStatiemt(state);
		
		
	}
	
}

jdbc.properties:

driver =com.mysql.jdbc.Driver
jdbcUrl=jdbc:mysql://localhost:3306/bjsxt?useUnicode=true&characterEncoding=utf-8
username =root
userpassword=123456

Java查询:

image.png

MySQL查询:

image.png

包:

jdbcDemo.rar


JAVA 全系列/第三阶段:数据库编程/JDBC技术(旧) 9414楼
Python 全系列/第四阶段:函数式编程和核心特性/装饰器深入剖析 9415楼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <link rel="stylesheet" href="css1/reset.css">
    <style>
        .box{
            box-sizing: border-box;
            width: 234px;
            height: 320px;
            padding: 20px 0;
            position: relative;
            text-align: center;
            background-color: coral;
            margin: 10px;
        }
        .box img{
            width: 80px;
            height: 160px;
            position: absolute;
            top: 21px;
            left: 77px;


        }
        .box>img:first-child{
            z-index: 10;
        }
        .box2{
            position: absolute;
            top:204px;
            background-color: yellow;
            width: 100%;
            height: 102px;
            text-align: center;
        }
        p{margin-bottom: 1px ;
      }
      .box2>p:last-child{
          margin-top: 10px;
      }

      .box:hover>img:first-child{
          left:40px
      }
      .box:hover>img:last-child{
       left:114px
      }
    </style>
</head>
<body>
   
<div class="box">
    <img src="images/position练习3.jpg" alt="">
    <img src="images/22.jpg" alt="" class="i2">
       <div class="box2">
          <p>黑鲨4S</p>
          <p>磁动力升降肩键</p>
          <p>2699元起</p>

    </div>
</div>
</body>
</html>

老师为啥用这个 last-child选择器不生效  用类选择器.i2就会生效?  要有三个img才可以使用last-child嘛?

.box:hover>img:last-child{
       left:114px
      }


WEB前端全系列/第一阶段:HTML5+CSS3模块/CSS常用属性 9416楼
JAVA 全系列/第一阶段:JAVA 快速入门/JAVA入门和背景知识 9417楼
Python 全系列/第十五阶段:Python 爬虫开发/scrapy框架使用 9418楼
Python 全系列/第一阶段:Python入门/Python入门(动画版) 9419楼
Python 全系列/第十五阶段:Python 爬虫开发/爬虫反反爬 9420楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

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