Java的线程问题互锁问题

我创建了两个线程,共同请求两个资源 Object1 和 Object2。线程1占用O1然后请求
O2;同理 线程2 占用 O2 请求 O1,为了防止线程一下子走完从而没有一直保持占用资源的状态,我还添加了一个倒计时。

可是当线程2明显占用了资源2的时候,线程1还是能够获取到资源2.请问这是为什么呢?

public class DeadLockThreadDemo {

    // 定义两个资源
    public static Object resource01 = new Object();
    public static Object resource02 = new Object();

    public static void main(String[] args) {
        /*ExecutorService executorService = Executors
                .newFixedThreadPool(3, new MyThreadFactory("Gary Thread pool"));
        executorService.execute(new TakeResource1(resource01, resource02));
        executorService.execute(new TakeResource2(resource01, resource02));*/
        Thread thread1 = new Thread(new TakeResource1(resource01, resource02));
        Thread thread2 = new Thread(new TakeResource2(resource01, resource02));
        thread1.start();
        thread2.start();
    }
}

class TakeResource1 implements Runnable{

    final Object resource1;
    final Object resource2;
    public TakeResource1(Object resource1, Object resource2) {
        this.resource1 = resource1.toString();
        this.resource2 = resource2.toString();
    }

    @Override
    public void run() {

        synchronized (resource1)
        {
            System.out.println("线程" + Thread.currentThread().getName() + " 占用资源 " + resource1 + " 请求 " +resource2 + " 线程状态:" + Thread.currentThread().getState());

            synchronized (resource2) {
                System.out.println("线程" + Thread.currentThread().getName() + " 成功占用 " + resource2);
            }
        }
    }
}

class TakeResource2 implements Runnable{

    final Object resource1;
    final Object resource2;
    public TakeResource2(Object resource1, Object resource2) {
        this.resource1 = resource1.toString();
        this.resource2 = resource2.toString();
    }

    @Override
    public void run() {
        synchronized (resource2)
        {
            System.out.println("线程" + Thread.currentThread().getName()  + " 占用资源 " + resource2 + " 请求 " + resource1);

            try {
                for (int i = 10; i > 0; i--) {
                    System.out.println(Thread.currentThread().getName() + " 线程占用了" + resource2 + " 开始休眠:" + i);
                    Thread.sleep(1000);
                }
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            synchronized (resource1) {
                System.out.println("线程" + Thread.currentThread().getName() + " 成功占用 " + resource1);

            }
        }
    }
}

图片说明

3个回答

加锁需要使用同一个实例

加速应该用单列模式去加。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
C# 中线程的互锁(Interlock),那位大神能帮忙看看

最近在使用Interlock时,出现读值错误,所以写了一个demo,有大神帮忙看看有什么问题。 ``` namespace ThreadDemo { class Tester { private int counter = 0; static void Main(string[] args) { //make an instance of this class Tester t = new Tester(); //run outside static Main t.DoTest(); Console.ReadKey(); } private void DoTest() { Thread t1 = new Thread(new ThreadStart(Incrementer)); t1.IsBackground = true; t1.Name = "ThreadOne"; t1.Start(); Console.WriteLine("Started thread {0}",t1.Name); Thread t2 = new Thread(new ThreadStart(Incrementer)); t2.IsBackground = true; t2.Name = "ThreadTwo"; t2.Start(); Console.WriteLine("Started thread {0}", t2.Name); t1.Join(); t2.Join(); //等待所有的线程都结束 Console.WriteLine("All my threads are done."); } //线程调用的函数 private void Incrementer() { //Console.WriteLine("Incrementer:{0}",counter); try { while (counter < 10) { //使用互锁 Interlocked.Increment(ref counter); //线程挂起 Thread.Sleep(1); //显示结果 Console.WriteLine("Thread {0}.Incrementer:{1}",Thread.CurrentThread.Name,counter); } } catch(ThreadInterruptedException) { Console.WriteLine("Thread {0} Interlocked!Cleaning up ...",Thread.CurrentThread.Name); } finally { Console.WriteLine("Thread {0} Exiting.",Thread.CurrentThread.Name); } } } } ``` 结果显示如下图: ![图片说明](https://img-ask.csdn.net/upload/201703/27/1490596629_398612.png) 我已经使用Interlocked进行了锁定,为什么线程2在线程1没有结束的时候会改变变量的值,求大神帮忙看看。

关于linux上的java线程最大限制问题

java的线程开启,默认的虚拟机会分配1M的内存,但是在4G的windows上线程最多也就开到300多 ,是因为windows本身的一些限制? 另外我想知道的是,在linux服务器上,linux默认给每个线程的内存是10M,那java在linux上开启线程到底是拿到1M还是10M的内存?不管是哪种方式, 一台4G的服务器,最多又能开多少个java线程呢?

Java多线程问题,线程没被执行的问题

``` package test; import java.io.IOException; import java.io.PrintWriter; import java.util.ResourceBundle; public class Command { public static void main(String[] args) throws Exception { ResourceBundle resource = ResourceBundle.getBundle("config"); Thread gitThread = new gitStartThread(resource); gitThread.start(); gitThread.join(); System.out.println("haha"); } static class gitStartThread extends Thread { ResourceBundle resource; public gitStartThread(ResourceBundle resource) { this.resource = resource; this.setDaemon(true); } @Override public void run() { Process process; try { process = Runtime.getRuntime().exec(resource.getString("cmd")); System.out.println("写入cmd成功"); PrintWriter writer = new PrintWriter(process.getOutputStream()); writer.println(resource.getString("GITCMD")); writer.flush(); System.out.println("写入GIT成功,开始拉取..."); writer.close(); } catch (Exception e) { // TODO Auto-generated catch block System.out.println("gitstart运行异常"); e.printStackTrace(); } finally { } } } } ``` 如上这里线程并不会被运行,而是主线程一下子运行完了,子线程没被执行 注: resource.getString("cmd")拿到的字符是cmd resource.getString("GITCMD")拿到的字符是git clone -b wlnsss_dev https://gitee.com/Wx 上面拉取git的字符乱写的,反正程序的最终作用就是 这是一个通过Java调用cmd拉取git到本地的程序,如果在join方法前加入线程睡眠似乎会正常执行,请各位大佬讲解下这是为什么,谢谢啦

java线程问题:怎样多次执行

有三个线程,第一个执行1到5递增,第二个执行6-10递增,第三个11-15。并且每个线程执行5次。我们老师给了一个类,但是我不会写方法,还请大神帮帮忙。![图片说明](https://img-ask.csdn.net/upload/201604/20/1461118500_739522.png)

java线程的中断状态问题

![图片说明](https://img-ask.csdn.net/upload/201703/25/1490411914_451139.png) 打印如下: 111111 线程id:10,中断状态:false aaaaaa 线程id:10,中断状态:false bbbbbbb 线程id:10,中断状态:true 222222 线程id:10,中断状态:false 请问为什么19行的中断状态和30行的中断状态不一样? 谢谢!

java线程暂停和唤醒问题

java线程如何暂停,暂停的时间未知。之后又可以在程序中唤醒呢?

java 后台线程中创建一个线程问题求解

今晚在看Think In Java的时候,看到后台线程这一小节,突然有个想法,如果在一个守护线程里面创建一个非守护线程(不显示的设置setDaemon(true)),那么创建的非守护线程是否也变成了守护线程。 代码如下 package com.hq.day0601; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.TimeUnit; /** * 简单的后台线程(守护线程)练习,该练习主要演示的是后台线程在最后一个非后台线程结束后,也会被关闭 * @author Administrator * */ public class SimpleDaemons implements Runnable { <span style="white-space:pre"> </span>@Override <span style="white-space:pre"> </span>public void run() {<span style="white-space:pre"> </span> <span style="white-space:pre"> </span>try { <span style="white-space:pre"> </span>ExecutorService exec = Executors.newCachedThreadPool(); <span style="white-space:pre"> </span>exec.execute(new TestThread());<span style="white-space:pre"> </span> <span style="white-space:pre"> </span>TimeUnit.MILLISECONDS.sleep(100); <span style="white-space:pre"> </span>System.out.println("SimpleDaemons is Daemons:"+Thread.currentThread().isDaemon()); <span style="white-space:pre"> </span>System.out.println(Thread.currentThread() +" "+this ); <span style="white-space:pre"> </span> <span style="white-space:pre"> </span>} catch (InterruptedException e) {<span style="white-space:pre"> </span> <span style="white-space:pre"> </span>e.printStackTrace(); <span style="white-space:pre"> </span>System.out.println("sleep() Interrupted"); <span style="white-space:pre"> </span>}<span style="white-space:pre"> </span> <span style="white-space:pre"> </span>} <span style="white-space:pre"> </span> <span style="white-space:pre"> </span>public static void main(String[] args) throws Exception { <span style="white-space:pre"> </span>for(int i = 0 ; i < 3;i++){ <span style="white-space:pre"> </span>Thread daemons = new Thread(new SimpleDaemons()); <span style="white-space:pre"> </span>daemons.setDaemon(true); <span style="white-space:pre"> </span>daemons.start(); <span style="white-space:pre"> </span>} <span style="white-space:pre"> </span>System.out.println("daemons start!"); <span style="white-space:pre"> </span>TimeUnit.SECONDS.sleep(1); <span style="white-space:pre"> </span>} } /** * 校验守护线程中创建的线程是否是守护线程 * @author Administrator * */ class TestThread implements Runnable { <span style="white-space:pre"> </span>@Override <span style="white-space:pre"> </span>public void run() { <span style="white-space:pre"> </span>System.out.println("TestThread is Daemon:"+Thread.currentThread().isDaemon()); <span style="white-space:pre"> </span>} } 打印结果: 从打印结果观察到,在后台线程中创建的线程不是后台线程。 然后,我对代码进行了改造,加上while循环 代码如下: package com.hq.day0601; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.TimeUnit; /** * 简单的后台线程(守护线程)练习,该练习主要演示的是后台线程在最后一个非后台线程结束后,也会被关闭 * @author Administrator * */ public class SimpleDaemons implements Runnable { @Override public void run() { try { ExecutorService exec = Executors.newCachedThreadPool(); exec.execute(new TestThread()); while(true){//添加while循环 TimeUnit.MILLISECONDS.sleep(100); System.out.println("SimpleDaemons is Daemons:"+Thread.currentThread().isDaemon()); System.out.println(Thread.currentThread() +" "+this ); } } catch (InterruptedException e) { e.printStackTrace(); System.out.println("sleep() Interrupted"); } } public static void main(String[] args) throws Exception { for(int i = 0 ; i < 3;i++){ Thread daemons = new Thread(new SimpleDaemons()); daemons.setDaemon(true); daemons.start(); } System.out.println("daemons start!"); TimeUnit.SECONDS.sleep(1); } } /** * 校验守护线程中创建的线程是否是守护线程 * @author Administrator * */ class TestThread implements Runnable { @Override public void run() { System.out.println("TestThread is Daemon:"+Thread.currentThread().isDaemon()); } } 我以为程序会在一秒后终止。但是却出了一个奇怪的现象,控制台一直在打印while循环里要打印的内容, 这让我感到非常费解,不知道有没有哪个大神讲解下这是什么原因。

Java多线程并发问题。

``` public class Test { public static void main(String[] args) throws Exception { Executor executor = new Executor(); new Thread(executor::write).start(); new Thread(executor::read).start(); Thread.sleep(500000); } static class Executor { private int MAX_TIMES = 10000; private boolean hasValue = false; void write() { for (int i = 0; i < MAX_TIMES; i++) { while (hasValue) {} System.out.println("Write, " + i); hasValue = true; } } void read() { for (int i = 0; i < MAX_TIMES; i++) { while (!hasValue) {} hasValue = false; System.out.println("Read, " + i); } } } } ``` 我有这么一段代码,原本目的是两个线程交换执行、write线程执行一次,read线程执行一次,但hasValue并不是volatile类型,所以会发生死锁 我有两个问题: 1. 如果读写都是cache line,那为什么不是刚执行就发生死锁,而是执行一会,大概会交替执行100次左右才死锁。 2. 输出结果很奇怪,为什么不是write 0=> read 0 => write 1=>read 1.......这样下去,实际输出结果是这样的 ``` Write, 0 Write, 1 Read, 0 Read, 1 Write, 2 Read, 2 Write, 3 Write, 4 Read, 3 Read, 4 Write, 5 Write, 6 Read, 5 Read, 6 Write, 7 Write, 8 Read, 7 Read, 8 Write, 9 Write, 10 Read, 9 Read, 10 Write, 11 Write, 12 ```

关于JAVA线程自己结束的问题。

public class DisplayMessage implements Runnable { private String message; public DisplayMessage(String message) { this.message = message; } public void run() { while(true) { System.out.println(message); } } } run跑起来后会自己结束,且每次循环的个数都不相同,求指点。

java线程问题(很简单的程序)?

最近回顾java课本上的一个例子的时候遇到了个问题。 整个程序的功能是用main线程启动线程A,在main线程中用死循环监听线程Thread的子类A中的属性n,n在A线程中用死循环累加,每累加一次,A线程睡去1秒,以便main线程监听,当main线程监听到A.n等于8时,使用System.exit(0)结束程序。 具体出现的问题请看代码中的注解,各位大佬帮忙看看是怎么个回事 ``` public class Main { public static void main(String args[]) { A a = new A(); a.setName("A"); a.start(); while(true) { if(8 == a.n){ System.out.println("进入if,即将执行System.exit"); System.exit(0); } else { /** * 问题出在这,当不去访问a.n的时候,A线程永远不会停止, * 当去访问a.n(比如下面的直接输出a.n),a.n=8时程序正常结束 */ //System.out.println(a.n); } } } } class A extends Thread { int n = 0; @Override public void run() { while(true){ System.out.println("n="+n+",即将加一"); n++; try { sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } } } } ```

java线程中断的问题。

为什么在调用sleep或者wait方法之前改变线程的中断状态,sleep也会抛出异常并将中断状态复位?

Java中静态方法的线程安全问题

Java中多个线程同时访问一个静态方法是否存在线程安全问题? 比如以下代码,两个线程同时对方法中b修改不同的值,会有线程安全问题吗? new Thread(new Runnable() { @Override public void run() { fun(0); } }).start(); new Thread(new Runnable() { @Override public void run() { fun(1); } }).start(); } static void fun(int a) { int b = 100; b = a; for (int i=0; i<100; i++) System.out.println(Thread.currentThread().getName() + "-->" + b); }

java线程问题——使用线程解决anr问题

以下两个方式效果一样吗? 1、 Hanlder handler = new Handler(); handler.post(new Runnable(){ public void run(){ //耗时操作 } }); 2、 final Runnable onCompleteRunnable = new Runnable() { @Override public void run() { //耗时操作 } }; onCompleteRunnable.run(); 问题:我用第二种方法执行耗时操作,有时候会引起anr。第一种方法可以解决anr问题吗?

java线程的循环跳出问题

做了一个线程的试验,结果不能跳出for循环,怎么回事?望解答 ``` public class Mythread { public static void main(String[] args) { new Extendsthread("wo"); new Extendsthread("my"); Thread m=Thread.currentThread(); System.out.println("this is main thread...." + " " + m.getName()); System.out.println("the next express: " + m); } } class Extendsthread extends Thread{ Thread t; Extendsthread(String name){ t=new Thread(this,name); t.start(); } public void run(){ for(int i=0;i<5;i++){ System.out.println(t.getName()+i); if(t.getName()=="wo") break; System.out.println("skip break!!!!"); System.out.println("this is child thread: " + i + t +" \n" + t.getName()); } } } ```

java线程拷贝的共享对象副本是放在jvm哪个空间中?

java多线程可见性的问题,对于实例的成员变量,它引用的对象在堆中,但线程会copy一份作为自己的副本。我想问这个副本是在线程的栈中,还是在堆中新开辟一块空间?

java 线程 怎么暂停与重新开启

这是我的一个线程类 class senddata extends Thread{ private String command; public void setcommand(String c){ this.command=c; } public void run() { //省略行为,其实就是使用socket发送数据 } } 我想发送一个信息,第一次发送可以没问题,第二次我使用setcommand方法换一个命令再发送,就完了!前一个命令已经发送完了,不应该执行完run方法里的东西这个线程就关闭吗?请问大牛,我这个简单的需求该怎么实现?

java多线程与并发的线程之间通信的问题

既然每个线程有自己的工作内存为什么我执行下面代码的时候主内存变量的更改能够影响线程 为什么会执行到 System.out.println(num+"*****************线程终止************"); 还有为什么我把System.out.println(num);一行注释掉就永远停止不了了 那么Java到底在什么时间执行read和load、store和write ``` public class CourrTest02 extends Thread{ private static long num=0; private boolean a=true; @Override public void run() { while(num!=10001){ // System.out.println(num); } System.out.println(num+"*****************线程终止************"); } public static void main(String[] args) throws InterruptedException { boolean b=true; CourrTest02 c1=new CourrTest02(); c1.start(); Thread.sleep(1000); for(int i=0;i<10000;i++){ c1.num=10001; } } } ```

java多线程与变量设置问题

在java中,线程开始的地方是哪里?我想定义一个变量让每个线程都访问的到和一个变量只有一个线程能访问该如何定义?

java线程中的run方法怎样算是结束?

代码如下: ``` import java.applet.Applet; import java.applet.AudioClip; public class SoundEffect { public static void playSound(){ new PlayThread().start(); } } class PlayThread extends Thread{ private AudioClip ac; PlayThread(){ ac = Applet.newAudioClip(SoundEffect.class.getResource("/resources/sound/a.wav")); } public void run() { ac.play(); } } ``` run方法会调用一次audioclip的play()方法,结束之后线程会自动销毁对吧? 可是声音播放是有一段时间的,线程是如何知道声音播放完成了呢?

定量遥感中文版 梁顺林著 范闻捷译

这是梁顺林的定量遥感的中文版,由范闻捷等翻译的,是电子版PDF,解决了大家看英文费时费事的问题,希望大家下载看看,一定会有帮助的

Java 最常见的 200+ 面试题:面试必备

这份面试清单是从我 2015 年做了 TeamLeader 之后开始收集的,一方面是给公司招聘用,另一方面是想用它来挖掘在 Java 技术栈中,还有那些知识点是我不知道的,我想找到这些技术盲点,然后修复它,以此来提高自己的技术水平。虽然我是从 2009 年就开始参加编程工作了,但我依旧觉得自己现在要学的东西很多,并且学习这些知识,让我很有成就感和满足感,那所以何乐而不为呢? 说回面试的事,这份面试...

机器学习初学者必会的案例精讲

通过六个实际的编码项目,带领同学入门人工智能。这些项目涉及机器学习(回归,分类,聚类),深度学习(神经网络),底层数学算法,Weka数据挖掘,利用Git开源项目实战等。

远程工具,免费

远程工具,免费

java jdk 8 帮助文档 中文 文档 chm 谷歌翻译

JDK1.8 API 中文谷歌翻译版 java帮助文档 JDK API java 帮助文档 谷歌翻译 JDK1.8 API 中文 谷歌翻译版 java帮助文档 Java最新帮助文档 本帮助文档是使用谷

csma/ca和csma/cd的matlab仿真源代码带有详细的注释

csma/ca和csma/cd的matlab仿真源代码带有详细的注释,载波侦听,随意设置节点数,带有炫酷的图形展示效果。

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

软件测试入门、SQL、性能测试、测试管理工具

软件测试2小时入门,让您快速了解软件测试基本知识,有系统的了解; SQL一小时,让您快速理解和掌握SQL基本语法 jmeter性能测试 ,让您快速了解主流来源性能测试工具jmeter 测试管理工具-禅道,让您快速学会禅道的使用,学会测试项目、用例、缺陷的管理、

pokemmo的资源

pokemmo必须的4个rom 分别为绿宝石 火红 心金 黑白 还有汉化补丁 资源不错哦 记得下载

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

无线通信中的智能天线:IS-95和第3代CDMA应用_.pdf

无线通信中的智能天线:IS-95和第3代CDMA应用_.pdf

设计模式(JAVA语言实现)--20种设计模式附带源码

课程亮点: 课程培训详细的笔记以及实例代码,让学员开始掌握设计模式知识点 课程内容: 工厂模式、桥接模式、组合模式、装饰器模式、外观模式、享元模式、原型模型、代理模式、单例模式、适配器模式 策略模式、模板方法模式、观察者模式、迭代器模式、责任链模式、命令模式、备忘录模式、状态模式、访问者模式 课程特色: 笔记设计模式,用笔记串连所有知识点,让学员从一点一滴积累,学习过程无压力 笔记标题采用关键字标识法,帮助学员更加容易记住知识点 笔记以超链接形式让知识点关联起来,形式知识体系 采用先概念后实例再应用方式,知识点深入浅出 提供授课内容笔记作为课后复习以及工作备查工具 部分图表(电脑PC端查看):

Java8零基础入门视频教程

这门课程基于主流的java8平台,由浅入深的详细讲解了java SE的开发技术,可以使java方向的入门学员,快速扎实的掌握java开发技术!

玩转Linux:常用命令实例指南

人工智能、物联网、大数据时代,Linux正有着一统天下的趋势,几乎每个程序员岗位,都要求掌握Linux。本课程零基础也能轻松入门。 本课程以简洁易懂的语言手把手教你系统掌握日常所需的Linux知识,每个知识点都会配合案例实战让你融汇贯通。课程通俗易懂,简洁流畅,适合0基础以及对Linux掌握不熟练的人学习; 【限时福利】 1)购课后按提示添加小助手,进答疑群,还可获得价值300元的编程大礼包! 2)本月购买此套餐加入老师答疑交流群,可参加老师的免费分享活动,学习最新技术项目经验。 --------------------------------------------------------------- 29元=掌握Linux必修知识+社群答疑+讲师社群分享会+700元编程礼包。 &nbsp;

极简JAVA学习营第四期(报名以后加助教微信:eduxy-1)

想学好JAVA必须要报两万的培训班吗? Java大神勿入 如果你: 零基础想学JAVA却不知道从何入手 看了一堆书和视频却还是连JAVA的环境都搭建不起来 囊中羞涩面对两万起的JAVA培训班不忍直视 在职没有每天大块的时间专门学习JAVA 那么恭喜你找到组织了,在这里有: 1. 一群志同道合立志学好JAVA的同学一起学习讨论JAVA 2. 灵活机动的学习时间完成特定学习任务+每日编程实战练习 3. 热心助人的助教和讲师及时帮你解决问题,不按时完成作业小心助教老师的家访哦 上一张图看看前辈的感悟: &nbsp; &nbsp; 大家一定迫不及待想知道什么是极简JAVA学习营了吧,下面就来给大家说道说道: 什么是极简JAVA学习营? 1. 针对Java小白或者初级Java学习者; 2. 利用9天时间,每天1个小时时间; 3.通过 每日作业 / 组队PK / 助教答疑 / 实战编程 / 项目答辩 / 社群讨论 / 趣味知识抢答等方式让学员爱上学习编程 , 最终实现能独立开发一个基于控制台的‘库存管理系统’ 的学习模式 极简JAVA学习营是怎么学习的? &nbsp; 如何报名? 只要购买了极简JAVA一:JAVA入门就算报名成功! &nbsp;本期为第四期极简JAVA学习营,我们来看看往期学员的学习状态: 作业看这里~ &nbsp; 助教的作业报告是不是很专业 不交作业打屁屁 助教答疑是不是很用心 &nbsp; 有奖抢答大家玩的很嗨啊 &nbsp; &nbsp; 项目答辩终于开始啦 &nbsp; 优秀者的获奖感言 &nbsp; 这是答辩项目的效果 &nbsp; &nbsp; 这么细致的服务,这么好的氛围,这样的学习效果,需要多少钱呢? 不要1999,不要199,不要99,只要9.9 是的你没听错,只要9.9以上所有就都属于你了 如果你: 1、&nbsp;想学JAVA没有基础 2、&nbsp;想学JAVA没有整块的时间 3、&nbsp;想学JAVA没有足够的预算 还等什么?赶紧报名吧,抓紧抢位,本期只招300人,错过只有等时间待定的下一期了 &nbsp; 报名请加小助手微信:eduxy-1 &nbsp; &nbsp;

Python数据清洗实战入门

本次课程主要以真实的电商数据为基础,通过Python详细的介绍了数据分析中的数据清洗阶段各种技巧和方法。

董付国老师Python全栈学习优惠套餐

购买套餐的朋友可以关注微信公众号“Python小屋”,上传付款截图,然后领取董老师任意图书1本。

linux下利用/proc进行进程树的打印

在linux下利用c语言实现的进程树的打印,主要通过/proc下的目录中的进程文件,获取status中的进程信息内容,然后利用递归实现进程树的打印

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

HoloLens2开发入门教程

本课程为HoloLens2开发入门教程,讲解部署开发环境,安装VS2019,Unity版本,Windows SDK,创建Unity项目,讲解如何使用MRTK,编辑器模拟手势交互,打包VS工程并编译部署应用到HoloLens上等。

150讲轻松搞定Python网络爬虫

【为什么学爬虫?】 &nbsp; &nbsp; &nbsp; &nbsp;1、爬虫入手容易,但是深入较难,如何写出高效率的爬虫,如何写出灵活性高可扩展的爬虫都是一项技术活。另外在爬虫过程中,经常容易遇到被反爬虫,比如字体反爬、IP识别、验证码等,如何层层攻克难点拿到想要的数据,这门课程,你都能学到! &nbsp; &nbsp; &nbsp; &nbsp;2、如果是作为一个其他行业的开发者,比如app开发,web开发,学习爬虫能让你加强对技术的认知,能够开发出更加安全的软件和网站 【课程设计】 一个完整的爬虫程序,无论大小,总体来说可以分成三个步骤,分别是: 网络请求:模拟浏览器的行为从网上抓取数据。 数据解析:将请求下来的数据进行过滤,提取我们想要的数据。 数据存储:将提取到的数据存储到硬盘或者内存中。比如用mysql数据库或者redis等。 那么本课程也是按照这几个步骤循序渐进的进行讲解,带领学生完整的掌握每个步骤的技术。另外,因为爬虫的多样性,在爬取的过程中可能会发生被反爬、效率低下等。因此我们又增加了两个章节用来提高爬虫程序的灵活性,分别是: 爬虫进阶:包括IP代理,多线程爬虫,图形验证码识别、JS加密解密、动态网页爬虫、字体反爬识别等。 Scrapy和分布式爬虫:Scrapy框架、Scrapy-redis组件、分布式爬虫等。 通过爬虫进阶的知识点我们能应付大量的反爬网站,而Scrapy框架作为一个专业的爬虫框架,使用他可以快速提高我们编写爬虫程序的效率和速度。另外如果一台机器不能满足你的需求,我们可以用分布式爬虫让多台机器帮助你快速爬取数据。 &nbsp; 从基础爬虫到商业化应用爬虫,本套课程满足您的所有需求! 【课程服务】 专属付费社群+每周三讨论会+1v1答疑

MySQL 8.0.19安装教程(windows 64位)

话不多说直接开干 目录 1-先去官网下载点击的MySQL的下载​ 2-配置初始化的my.ini文件的文件 3-初始化MySQL 4-安装MySQL服务 + 启动MySQL 服务 5-连接MySQL + 修改密码 先去官网下载点击的MySQL的下载 下载完成后解压 解压完是这个样子 配置初始化的my.ini文件的文件 ...

Python数据挖掘简易入门

&nbsp; &nbsp; &nbsp; &nbsp; 本课程为Python数据挖掘方向的入门课程,课程主要以真实数据为基础,详细介绍数据挖掘入门的流程和使用Python实现pandas与numpy在数据挖掘方向的运用,并深入学习如何运用scikit-learn调用常用的数据挖掘算法解决数据挖掘问题,为进一步深入学习数据挖掘打下扎实的基础。

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

网络工程师小白入门--【思科CCNA、华为HCNA等网络工程师认证】

本课程适合CCNA或HCNA网络小白同志,高手请绕道,可以直接学习进价课程。通过本预科课程的学习,为学习网络工程师、思科CCNA、华为HCNA这些认证打下坚实的基础! 重要!思科认证2020年2月24日起,已启用新版认证和考试,包括题库都会更新,由于疫情原因,请关注官网和本地考点信息。题库网络上很容易下载到。

Ubuntu18.04安装教程

Ubuntu18.04.1安装一、准备工作1.下载Ubuntu18.04.1 LTS2.制作U盘启动盘3.准备 Ubuntu18.04.1 的硬盘空间二、安装Ubuntu18.04.1三、安装后的一些工作1.安装输入法2.更换软件源四、双系统如何卸载Ubuntu18.04.1新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列...

sql语句 异常 Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your

在我们开发的工程中,有时候会报 [Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ------ 这种异常 不用多想,肯定是我们的sql语句出现问题,下面...

西南交通大学新秀杯数学建模试题

题目比较难,如果符合大家的口味欢迎大家下载哈,提高你的思维想象能力

Windows版YOLOv4目标检测实战:训练自己的数据集

课程演示环境:Windows10; cuda 10.2; cudnn7.6.5; Python3.7; VisualStudio2019; OpenCV3.4 需要学习ubuntu系统上YOLOv4的同学请前往:《YOLOv4目标检测实战:训练自己的数据集》 课程链接:https://edu.csdn.net/course/detail/28745 YOLOv4来了!速度和精度双提升! 与 YOLOv3 相比,新版本的 AP (精度)和 FPS (每秒帧率)分别提高了 10% 和 12%。 YOLO系列是基于深度学习的端到端实时目标检测方法。本课程将手把手地教大家使用labelImg标注和使用YOLOv4训练自己的数据集。课程实战分为两个项目:单目标检测(足球目标检测)和多目标检测(足球和梅西同时检测)。 本课程的YOLOv4使用AlexyAB/darknet,在Windows系统上做项目演示。包括:安装软件环境、安装YOLOv4、标注自己的数据集、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算)和先验框聚类分析。还将介绍改善YOLOv4目标检测性能的技巧。 除本课程《Windows版YOLOv4目标检测实战:训练自己的数据集》外,本人将推出有关YOLOv4目标检测的系列课程。请持续关注该系列的其它视频课程,包括: 《Windows版YOLOv4目标检测实战:人脸口罩佩戴检测》 《Windows版YOLOv4目标检测实战:中国交通标志识别》 《Windows版YOLOv4目标检测:原理与源码解析》

Spring Boot -01- 快速入门篇(图文教程)

Spring Boot -01- 快速入门篇 今天开始不断整理 Spring Boot 2.0 版本学习笔记,大家可以在博客看到我的笔记,然后大家想看视频课程也可以到【慕课网】手机 app,去找【Spring Boot 2.0 深度实践】的课程,令人开心的是,课程完全免费! 什么是 Spring Boot? Spring Boot 是由 Pivotal 团队提供的全新框架。Spring Boot...

相关热词 c# 不能序列化继承类 c# char* 调用 c# 开发dll模板 c#添加控件到工具箱 c#控制台组合数 编程计算猴子吃桃问题c# c# wpf 背景透明 随机抽取号码软件c# c# 开发环境 c# 属性和字段
立即提问