当前位置: 首页 > news >正文

公司做网站的费用属于什么费用北京十大室内设计公司排名

公司做网站的费用属于什么费用,北京十大室内设计公司排名,长沙网络推广小公司,唐山网站建设哪家优惠目录 多线程编程 线程的概念与生命周期 创建线程的两种方式(继承Thread类、实现Runnable接口) 线程同步与锁机制(synchronized、Lock) 线程池(ExecutorService) 线程间通信(wait、notify、notifyAll) 实践建议:编写多线程程序,模拟生产者-消费者问题。 反射机…目录 多线程编程 线程的概念与生命周期 创建线程的两种方式(继承Thread类、实现Runnable接口) 线程同步与锁机制(synchronized、Lock) 线程池(ExecutorService) 线程间通信(wait、notify、notifyAll) 实践建议:编写多线程程序,模拟生产者-消费者问题。 反射机制 Class类与反射 获取类的信息(字段、方法、构造器) 动态创建对象与调用方法 实践建议:通过反射实现一个简单的依赖注入。 注解(Annotation) 内置注解(@Override、@Deprecated等) 自定义注解 元注解(@Target、@Retention等) 实践建议:自定义注解并实现简单的注解处理器。 网络编程 TCP/IP协议与Socket编程 UDP协议与DatagramSocket编程 HTTP协议与URLConnection 实践建议:编写一个简单的聊天程序。 数据库编程 JDBC简介 连接数据库(DriverManager、Connection) 执行SQL语句(Statement、PreparedStatement) 事务管理 数据库连接池(DBCP、C3P0、HikariCP) 多线程编程 线程的概念与生命周期 // 1. 线程的概念与生命周期// 线程是程序执行的最小单位,一个程序可以有多个线程。 // 线程有以下几种状态: // - NEW: 新建状态,线程已经创建但尚未开始执行。 // - RUNNABLE: 运行状态,线程正在运行或等待被调度执行。 // - BLOCKED: 阻塞状态,线程因等待锁而被阻塞。 // - WAITING: 等待状态,线程正在等待其他线程的通知。 // - TIMED_WAITING: 超时等待状态,线程正在等待超时。 // - TERMINATED: 终止状态,线程执行完成或者异常终止。// 示例:线程状态的转换 public class ThreadLifeCycle {public static void main(String[] args) {Thread thread = new Thread(() - {System.out.println("Thread is running...");});System.out.println("Thread state: " + thread.getState()); // NEW 状态thread.start();System.out.println("Thread state: " + thread.getState()); // RUNNABLE 状态} } 创建线程的两种方式(继承Thread类、实现Runnable接口) // 2. 创建线程的两种方式// (1)继承 Thread 类 class MyThread extends Thread {@Overridepublic void run() {System.out.println("Thread is running using Thread class!");} }public class ThreadExample {public static void main(String[] args) {// 创建并启动线程MyThread myThread = new MyThread();myThread.start(); // 调用 start() 方法启动线程} }// (2)实现 Runnable 接口 class MyRunnable implements Runnable {@Overridepublic void run() {System.out.println("Thread is running using Runnable interface!");} }public class RunnableExample {public static void main(String[] args) {// 创建线程Thread thread = new Thread(new MyRunnable());thread.start(); // 调用 start() 方法启动线程} } 线程同步与锁机制(synchronized、Lock) // 3. 线程同步与锁机制// 线程同步:避免多个线程同时访问共享资源导致数据不一致的问题。 // (1)使用 synchronized 关键字进行同步 class Counter {private int count = 0;// 使用 synchronized 确保线程安全public synchronized void increment() {count++;}public int getCount() {return count;} }public class SynchronizedExample {public static void main(String[] args) throws InterruptedException {Counter counter = new Counter();// 创建两个线程并启动Thread thread1 = new Thread(() - {for (int i = 0; i 1000; i++) {counter.increment();}});Thread thread2 = new Thread(() - {for (int i = 0; i 1000; i++) {counter.increment();}});thread1.start();thread2.start();thread1.join();thread2.join();System.out.println("Final count: " + counter.getCount()); // 输出结果应该是 2000} }// (2)使用 Lock 进行同步 import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock;class LockCounter {private int count = 0;private Lock lock = new ReentrantLock();public void increment() {lock.lock(); // 获取锁try {count++;} finally {lock.unlock(); // 释放锁}}public int getCount() {return count;} }public class LockExample {public static void main(String[] args) throws InterruptedException {LockCounter counter = new LockCounter();// 创建两个线程并启动Thread thread1 = new Thread(() - {for (int i = 0; i 1000; i++) {counter.increment();}});Thread thread2 = new Thread(() - {for (int i = 0; i 1000; i++) {counter.increment();}});thread1.start();thread2.start();thread1.join();thread2.join();System.out.println("Final count using Lock: " + counter.getCount()); // 输出结果应该是 2000} } 线程池(ExecutorService) // 4. 线程池(ExecutorService)// 使用线程池来管理线程,避免频繁的创建与销毁线程。 // ExecutorService 是一个接口,提供了用于创建线程池和提交任务的方法。import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors;public class ThreadPoolExample {public static void main(String[] args) {// 创建一个固定大小的线程池ExecutorService executorService = Executors.newFixedThreadPool(2);// 提交任务executorService.submit(() - System.out.println("Task 1 is executed"));executorService.submit(() - System.out.println("Task 2 is executed"));// 关闭线程池executorService.shutdown();} } 线程间通信(wait、notify、notifyAll) // 5. 线程间通信(wait、notify、notifyAll)// 使用线程间通信来协调多个线程的执行顺序。 // - wait():使当前线程进入等待状态,并释放锁。 // - notify():唤醒等待队列中的一个线程。 // - notifyAll():唤醒等待队列中的所有线程。class SharedResource {private int count = 0;// 使用 wait 和 notify 进行线程间通信public synchronized void produce() throws InterruptedException {while (count = 1) {wait(); // 如果资源已满,当前线程等待}count++;System.out.println("Produced, count: " + count);notify(); // 通知消费者}public synchronized void consume() throws InterruptedException {while (count = 0) {wait(); // 如果资源为空,当前线程等待}count--;System.out.println("Consumed, count: " + count);notify(); // 通知生产者} }public class ProducerConsumerExample {public static void main(String[] args) throws InterruptedException {SharedResource resource = new SharedResource();// 创建并启动生产者线程Thread producer = new Thread(() - {try {for (int i = 0; i 5; i++) {resource.produce();}} catch (InterruptedException e) {e.printStackTrace();}});// 创建并启动消费者线程Thread consumer = new Thread(() - {try {for (int i = 0; i 5; i++) {resource.consume();}} catch (InterruptedException e) {e.printStackTrace();}});producer.start();consumer.start();producer.join();consumer.join();} } 实践建议:编写多线程程序,模拟生产者-消费者问题。 反射机制 Class类与反射 反射机制是 Java 提供的一个强大特性,它允许在运行时动态地查询和操作类的结构(如字段、方法、构造器等),以及动态创建对象和调用方法。// 1. Class类与反射// 在 Java 中,`Class` 是一个类,用于描述一个类的信息, // 每个类在 JVM 中都有一个与之对应的 `Class` 对象,通过该对象可以获取类的各种信息。 // 获取 `Class` 对象的方式有几种:// (1)使用 `getClass()` 方法 Object obj = new String("Hello"); Class? clazz1 = obj.getClass(); // 获取对象的 Class 对象 System.out.println(clazz1.getName()); // 输出类的全限定名:java.lang.String// (2)使用 `Class.forName()` 方法 Class? clazz2 = Class.forName("java.lang.String"); // 通过类名获取 Class 对象 System.out.println(clazz2.getName()); // 输出类的全限定名:java.lang.String// (3)使用 `.class` 语法 Class? clazz3 = String.class; // 获取 String 类的 Class 对象 System.out.println(clazz3.getName()); // 输出类的全限定名:java.lang.String
http://www.w-s-a.com/news/990395/

相关文章:

  • 免费网站建设培训学校手机百度高级搜索入口在哪里
  • 建站经验安徽六安发现一例新冠阳性检测者
  • 滨州内做网站系统的公司汕头网络营销公司
  • 苏州制作网站的公司哪家好wordpress google搜索
  • c语言做项目网站wordpress博客被书为什么还
  • 企业建站用什么系统网站建设补充协议模板
  • 常州网站关键字优化淘客网站怎么做排名
  • 全flash网站制作教程网站做进一步优化
  • 建设网站步骤是如何做自媒体和网站签约赚点击
  • 网站建设的闪光点网站 备案 拍照
  • 那些企业需要做网站九洲建设集团网站
  • 中山企业做网站昆明做网站价格
  • wordpress 新网站 代码网站可以做系统还原吗
  • 百度给做网站公司餐饮设计装饰公司
  • 专门卖医疗器械的网站网站建设方案一份
  • 吉林省建设安全监督站网站wordpress 4.7.5下载
  • 网页制作视频的网站建设营销策划公司
  • 玉雕网站建设八点品牌设计公司招聘
  • 服务器可以自己的网站吗flash 网站 源码
  • 湖南做网站 搜搜磐石网络网站注册收入
  • 北京软件网站开发装修设计培训机构
  • 哪个网站能帮助做路书网站建设的技巧
  • 上海网站备案在哪里在国外怎么做网站
  • 做网站得花多钱乡村振兴网站建设
  • 站设计培训课程wordpress自动回复
  • 上海闵行区 网站建设永久免费crm软件下载
  • 天津营销网站建设公司排名台州网站排名公司
  • 环保网站 怎么做物流网站的功能与特色
  • 网站多久才会被收录服务器租用泰海
  • 电商网站建设合同模板临汾推广型网站建设