头歌--Java多线程作业

我看挺多学Java的小伙伴们都有这上面的作业,今天先来更新几期头歌的作业吧,笔记我尽量写,加油。


简述

如果一个程序只有一个执行流程,所以这样的程序就是单线程程序。假如一个程序有多条执行流程,那么,该程序就是多线程程序。


提示:以下是本篇文章正文内容,下面案例可供参考

一、创建多线程

1.任务描述

2.解题:

package step1;

public class CreateThreadPractice {

    public static void main(String[] args) {
        MyThread myThread = new MyThread();
        // ---------------------Begin------------------------
        //开启线程
        myThread.start();

        // ---------------------End------------------------
    }
}
// ---------------------Begin------------------------
//继承Thread编写名为MyThead的类,代码内容为循环输出10遍: 线程在运行......
class MyThread extends Thread{
    public void run(){
        for(int  i = 0;i<10;i++){
            System.out.println("线程在运行......");
        }
    }
}


// ---------------------End------------------------

二、使用Callable接口创建多线程

1.任务描述

2.解题:

package step2;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.FutureTask;
// ---------------------Begin------------------------
//tips: 输出语句为:Thread.currentThread().getName()+"的call()方法在运行"
//定义一个实现Callable接口的实现类,类名必须命名为MyThread_callable
class MyThread_callable implements Callable{
    public Object call() throws Exception{
        for(int i = 0;i<5;i++){
        System.out.println(Thread.currentThread().getName()+"的call()方法在运行");
        }
        return Thread.currentThread().getName();
    }
}



// ---------------------End------------------------
public class CallableExample {
    public static void main(String[] args) throws InterruptedException,
            ExecutionException {
        // 创建Callable接口的实现类对象
        MyThread_callable myThread3 = new MyThread_callable();
        // 使用FutureTask封装Callable接口
        FutureTask<Object> ft1 = new FutureTask<>(myThread3);
        // 使用Thread(Runnable target ,String name)构造方法创建线程对象
        Thread thread1 = new Thread(ft1, "thread1");
        // 创建并启动另一个线程thread2
        FutureTask<Object> ft2 = new FutureTask<>(myThread3);
        Thread thread2 = new Thread(ft2, "thread2");
        // ---------------------Begin------------------------
        // 调用线程对象的start()方法启动线程
        //thread1.setPriority(10);
        thread1.start();
        Thread.sleep(100);
        //thread2.setPriority(1);
        thread2.start();
        Thread.sleep(100);

        // 可以通过FutureTask对象的方法管理返回值
        try{
            System.out.println("thread1返回结果:"+ft1.get());
            System.out.println("thread2返回结果:"+ft2.get());
        }catch(Exception e){
            e.printStackTrace();
        }
        // ---------------------End------------------------
    }
}

三、使用Runnable接口创建多线程

1.任务描述

2.解题:

package step3;
// ---------------------Begin------------------------
//定义一个实现Runnable接口的实现类,类名必须命名为MyThread_runable
//tips: 输出语句为:Thread.currentThread().getName()+"的run()方法在运行"
class MyThread_runable implements Runnable{
    public void run(){
for(int i = 0;i<3;i++){
    System.out.println(Thread.currentThread().getName()+"的run()方法在运行");
}
    }
}



// ---------------------End------------------------

四、多线程中的售票问题

1.任务描述

(这一题整的人很麻木,没有说明输出是什么,刚开始时我是按照着前面同步锁的示例来写的,但我运行成功了,但是不匹配,太草率了,这题目出的,有兴趣的可以看一下下面的标准答案。嘿嘿)

2.解题:

package step4;

import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

public class SellTicket extends Thread {
    //多线程共享资源,票数为30张
    public static int ticketnums = 30;
    // ---------------------Begin------------------------
   private static ReentrantLock lock = new ReentrantLock();
   //@Override
   public void run(){
       while(true){
               try{
                    lock.lock();
           if(ticketnums>0){
               try{
                   Thread.sleep(10);
               }catch(InterruptedException e) {
                   e.printStackTrace();}
            System.out.println("卖出了第"+ticketnums+"张票");
            ticketnums--;
           }else{
               System.out.println("票卖完了");
               System.exit(0);
           } 
           }finally{
               lock.unlock();
           }
       }
   }
   






  
    // ---------------------End------------------------
}

五、知识回顾

1.题目一

2.题目二

3.题目三


总结

昨天的作业是这个,那我就先更新这个慢慢往前更新,Java学习笔记,我正在努力的敢,加油努力吧,大家。

  • 11
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用Java中的多线程技术来执行SQL语句。 可以使用Java中的JDBC API来执行SQL语句,并且通过创建多个线程并行执行SQL语句来提高执行效率。 不过,请注意在多线程环境中使用JDBC时需要特别注意线程安全性问题。因为JDBC API并不是线程安全的,因此需要通过特殊的方式来解决这个问题。 推荐使用数据库连接池,在每个线程中使用单独的数据库连接来执行SQL语句。这样可以保证线程安全并且提高执行效率。 ### 回答2: Java中可以使用多线程执行SQL语句的方式有几种。 一种是通过多线程调用JDBC(Java Database Connectivity)来执行SQL语句。JDBC是Java提供的用于与数据库进行连接和操作的API,可以通过多线程创建多个数据库连接,并使用不同的线程执行SQL语句。这种方式需要考虑线程安全的问题,可以通过使用锁或者连接池等机制来解决。 另一种方式是通过使用线程池来执行SQL语句。Java中提供了线程池的机制,可以通过创建线程池来管理多个线程的执行,将SQL语句封装成任务提交给线程池,线程池会自动分配线程执行任务。这种方式可以有效地利用线程资源,提高程序的执行效率。 还可以使用并发控制工具来执行SQL语句,如使用CountDownLatch或CyclicBarrier等工具控制多个线程同时执行SQL语句,或者使用Semaphore来控制并发执行的线程数量。这种方式可以根据需要灵活地控制并发执行的线程数量,以及线程的执行顺序。 无论使用哪种方式,都需要注意线程安全的问题,避免多个线程同时访问和修改数据库的数据导致数据不一致的问题。可以使用事务或者加锁等机制来确保数据的一致性。此外,还需要考虑数据库的连接数限制和性能问题,根据实际情况合理配置连接池和线程池的大小,以及优化SQL语句的执行效率。 ### 回答3: 在Java中,可以使用多线程执行SQL语句以提高数据库操作的效率。实现多线程执行SQL语句可以通过以下步骤: 1. 创建数据库连接池:使用数据库连接池可以复用连接,减少连接数据库的开销。常见的数据库连接池有HikariCP、Druid等,可以根据需求选择合适的连接池。 2. 创建线程池:使用线程池可以管理线程的创建和销毁,提高线程的复用性。可以通过Java提供的Executors类创建线程池,指定线程数量等参数。 3. 创建Runnable任务:将要执行的SQL语句封装为Runnable任务,每个任务负责执行一条SQL语句。可以使用JDBC连接数据库,并使用Connection对象执行SQL语句,处理查询结果等。 4. 提交任务给线程池:将创建的Runnable任务提交给线程池执行。线程池会自动从线程池中获取一个线程来执行任务。 5. 获取执行结果:可以通过Future对象来获取每个任务的执行结果。在提交任务时,会返回一个Future对象,可以通过该对象的方法获取任务的执行状态和结果。 6. 关闭线程池和数据库连接池:在多线程执行SQL语句完成后,需要及时关闭线程池和数据库连接池,释放资源。 需要注意的是,在多线程执行SQL语句时,需要考虑线程安全和事务管理。可以通过加锁、使用事务等技术来保证数据的一致性和线程的安全性。 总而言之,通过使用数据库连接池和线程池,以及合适的多线程编程技术,可以在Java中实现多线程执行SQL语句,提高数据库操作的效率和性能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值