首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    用java写一个死锁

    “synchronized”关键词的作用是,确保在某个时刻只有一个线程被允许执行特定的代码块,因此,被允许执行的线程首先必须拥有对变量或对象的排他性的访问权。...此时如果把sleep()换成wait()会出现 线程1锁o1 Exception in thread "Thread-0" 线程2锁o2 线程2锁o1 java.lang.IllegalMonitorStateException...查看API发现 java.lang.IllegalMonitorStateException抛出的异常表明某一线程已经试图等待对象的监视器,或者试图通知其他正在等待对象的监视器而本身没有指定监视器的线程...Java中用到的线程调度算法是抢占式。一个线程用完CPU之后,操作系统会根据线程优先级、线程饥饿情况等数据算出一个总的优先级并分配下一个时间片给某个线程执行。...由于Java采用抢占式的线程调度算法,因此可能会出现某条线程常常获取到CPU控制权的情况,为了让某些优先级比较低的线程也能获取到CPU控制权,可以使用Thread.sleep(0)手动触发一次操作系统分配时间片的操作

    2K20

    用JAVA写的word模板自动生成引擎

    当然是写各种文档啦,尤其是在大公司做项目,各种规范文档不可少,虽然说一个成熟的项目管理过程中的确是要依靠各种文档来明确项目里程碑及具体的设计确认和需求分工,但是TJ君还是更喜欢把时间花在开发代码上。...尤其是有些文档的格式都差不多,那是不是我们程序猿可以发挥特长,用程序来生成输出指定的word文档,减少自己的手写时间呢? 当然是可以的!...Apache Poi是用Java编写的一款免费开源的跨平台的JavaAPI,该API可以通过Java程序对Office格式文档进行读写操作,可以说是现阶段Java库当中最好用的office处理库了,可能都不用加之一两个字...所以基于Apache Poi的Poi-tl可以让你在word文档的任何地方做任何你想做的事情。...当然,如果想将Poi-tl用的好的话,还是要花一点时间来研究其中具体模块的语法,好在Poi-tl提供详细的示例代码讲解,小伙伴们只要用心学一下,很快就能掌握的 到底能不能让小伙伴们减轻写文档的压力呢

    1.4K10

    写算法,用 C++ 还是用 Java ,差别大吗?

    因为这篇文章非常详细的讲述了用两门语言在写算法时候的优劣势,非常值得一读。 如果你刚好在学习算法,那么文末也贴心的为你准备了王晓华的算法课程,算法真的很好玩! 全文大约3000字。...C++ 允许全局函数的存在,但是 Java 不允许,不过 Java 也留了个口子,就是用静态成员函数。...Java 没有指针,对象的传递和返回都是用的引用的方式,并且不需要像 C++ 那样用 “&” 做特殊的语法标记。...C++ 用当前迭代器的值是否等于 end() 代表的结束位置迭代器的值来判断是否遍历结束。 Java 的 Collection 也有迭代器的机制,Java 用 hasNext() 判断是否遍历结束。...C++ 直接用 “ * ” 提领迭代器,得到对象本身的引用,Java 用迭代器的 next() 接口得到对象本身的引用。以上 C++ 代码可以翻译成如下 Java 代码: ?

    2.8K20

    用Java写一个简单的缓存操作类

    前言 使用缓存已经是开发中老生常谈的一件事了,常用专门处理缓存的工具比如Redis、MemCache等,但是有些时候可能需要一些简单的缓存处理,没必要用上这种专门的缓存工具,那么自己写一个缓存类最合适不过了...缓存类需要注意的问题: 缓存对象应该是唯一的,也就是单例的; 缓存的操作方法要同步,在多线程并发条件下防止出错; 缓存的容器应该具有较高的并发性能,ConcurrentHashMap是一个不错的选择。...首先是类定义和其属性定义,其中本类实例对象用volatile进行修饰提高可见性,初始化缓存容量用于初始化ConcurrentHashMap缓存容器的大小,此大小根据实际应用场景进行优化。 ?...三、并发测试 普通的实现测试这里就不展示了,肯定是没问题的,读者简单写一些测试样例即可,这里主要展示一下并发测试,因为在实际情况中存在并发处理缓存情况,为了确保其正确性,所以并发测试是必须要做的,下面放出我的测试样例...四、拓展 该类只是简单的实现了缓存的过程,但是在实际应用中不见得能很好地表现,首先它的容量肯定有限,不能存太多缓存,因为使用的是JVM堆内的内存,其次其功能也较为简单,比如不支持LRU淘汰等,这个可以用双链表

    1.7K20

    Java|写一个用迭代法解方程的Java程序

    它利用计算机运算速度快、适合做重复性操作的特点,让计算机对一组指令(或一定步骤)进行重复执行,在每次执行这组指令(或步骤)时,都从变量的原值推出它的一个新值。...迭代法具有循环的计算方法,方法简单,适宜解大型稀疏矩阵方程组,在用计算机计算时只需存储A的非零元素(或可按一定公式形成系数,这样A就不需要存储)。...(1)对于给定的方程组X =Bx+f,用式子逐步代入求近似解的方法称为迭代法(或称为一阶定常迭代法,这里与B和k无关) (2) 如果limx(k), x→∞存在(记作x* ),称此迭代法收敛,显然x就是方程组的解...xk+1=xk-f(xk)➗f’(xk)(k=0,1,2……) 例题讲解 例:用牛顿迭代法三次求方程f(x)=x5-x2+x-30=0,在区间[1,3]中的近似值请详细解答 解: f(1)=-29...所以x=2.0001 例:使用牛顿迭代法求方程的解,X3-2x-5=0,在区间[2,3]上的根。

    1.2K30

    用JAVA写一个冒泡排序「建议收藏」

    大家好,又见面了,我是你们的朋友全栈君。...一:实现思想:   基本思想:在要排序的一组数中,对当前还未排好序的范围内的全部数,自上而下对相邻的两个数依次进行比较和调整,让较大的数往下沉,较小的往上冒。...即:每当两相邻的数比较后发现它们的排序与排序要求相反时,就将它们互换。...如上例:第一趟比较之后,排在最后的一个数一定是最大的一个数,第二趟排序的时候,只需要比较除了最后一个数以外的其他的数,同样也能找出一个最大的数排在参与第二趟比较的数后面,第三趟比较的时候,只需要比较除了最后两个数以外的其他的数...,以此类推……也就是说,没进行一趟比较,每一趟少比较一次,一定程度上减少了算法的量;   缺点:效率不高 (如果一个数组有n个数,那么排序完成后需要比较n*(n-1)/2次); 欢迎大家一起说出自己的想法

    49020

    用 C++ 和 Java 写算法,有差别吗?

    或者 “C++ 很强大,Java 也很优秀,我选 Python”。 所以在本文里,我非常详细的讲述了用 Java 或 C++ 写算法时候的优劣势,你可以参考一下来判断自己喜欢用哪种语言写算法。...C++ 允许全局函数的存在,Java 则不允许,不过 Java 也留了个口子,就是用静态成员函数。...Java 没有指针,对象的传递和返回都是用的引用的方式,并且不需要像 C++ 那样用 “&” 做特殊的语法标记。...C++ 用当前迭代器的值是否等于 end() 代表的结束位置迭代器的值来判断是否遍历结束。 Java 的 Collection 也有迭代器的机制,Java 用 hasNext() 判断是否遍历结束。...C++ 直接用 “ * ” 提领迭代器,得到对象本身的引用,Java 用迭代器的 next() 接口得到对象本身的引用。以上 C++ 代码可以翻译成如下 Java 代码: ?

    2.4K10

    用心写BUG,用脚写代码

    在这样的时代背景下,对于每一个基于代码的自动化测试而言,最痛苦的事莫过于接手了一段辣眼睛的代码。BUG不BUG是其次,更多的时候是看到了一段拥有无数嵌套、晦涩难懂、宛如天书的代码。...原先就一知半解,遇到这样的代码更是难上加难。今天我们就来看看,应该拿什么来拯救那些稀烂的代码。 1、把注释和代码混在一起的代码: 高亮显示后: 如果只做边界的测试,那么就悲剧了。...VSCode,然后【Shift】+【Alt】+F,真香 9、鬼才逻辑: *** 10、充分训练客户自己的排查能力,别一有什么问题就找我们乙方 一般我都直接写百度的。。...话说回来,编写一段雅观的代码,往往需要相当深厚的功力。优秀的代码不仅要有一个中心思想让人一眼辨认,还要在精炼与易读之间做权衡。...Linux之父Linus Torvalds说:如果你的代码里需要有超过三层的缩进,那么你已经搞砸了,应该修改你的代码。

    1.3K20

    Java——覆写(概念、覆写的意义、覆写的要求)

    1、方法的覆写 当子类定义了与父类中完全一样的方法时(参数名称、参数类型及个数、返回值类型),这样的操作就为方法的覆写。...1)方法覆写的意义: 1、父类中定义的方法名称是其他程序认可的,但是子类使用时发现,原有方法不能满足现在的操作要求,但要保留原方法名称,因此出现了覆写的概念; 2、this方法与super方法的区别:...: 被覆写的方法不能有比父类更严格的访问控制全权限。...但是有一点需要注意,在父类中若是用private声明的方法,该方法不能被子类所覆写,且这样的操作没有什么实际意义。实际开发中,对于方法的定义,基本都使用public声明。...No.区别方法重载方法覆写1单次OverloadingOverride2范围发生在一个类中发生在继承关系中3定义方法名称相同,参数类型及个数不同方法名称、参数类型、个数及返回值全部相同4权限没有权限要求被覆写的方法不能有比父类更为严格的访问控制权限

    1.2K10

    用Groovy写Servlet

    快速开始 Groovy语言提供了一个模块,可以让我们写用Groovy脚本的方式来编写Servlet,这叫做Groovlets。先看看一个简单的例子吧。下面这几个例子都来自官方文档。 if (!...不太了解的可以看看我的文章Groovy模板引擎,或者直接看原文档。 if (!session) { session = request.getSession(true) } if (!...request response context application,以上几个和JSP中的一样,直接用就行了 session,该对象可能为空,只有当你向session放东西之后它才不为空,不然就要像官方的例子那样先判断是不是空...,结果发现它的语法虽然挺好用,但是视图部分有点坑。...我用标记模板想迭代一个表格,结果显示无法在空对象上使用属性,查了半天没找到解决办法。所以只好写这么一个小例子,例子很简单,输入一个名称给服务器,然后返回问候。

    74810

    用awk写递归

    看到自己很多年前写的一篇帖子,觉得有些意义,转录过来,稍加修改。 awk是一种脚本语言,语法接近C语言,我比较喜欢用,gawk甚至可以支持tcp/ip,用起来非常方便。...awk也支持递归,只是awk不支持局部变量,所有的变量都是全局的,于是写递归有些麻烦。本文说白了,也只是借awk说一种编程的思路罢了。 原文如下: awk支持函数,也支持递归。...我们考虑C语言,它的局部变量放在硬件支持的栈(一般用栈指针)内。于是我们就去思考,为什么是栈呢?...,它是得不到正确的答案的 第二个是用数组来模拟变量栈,testlen就是所谓的“栈顶指针” 第三个是用字符串来模拟变量栈,字符串末尾就是“栈顶指针”,每个“局部变量”之间是用分号隔开 用随机数据测试一下这个应用...其实,即使两个栈并非同时进出栈也是可以的,只是对于这里的例子来说写不出这么复杂。 实际上,任意多的栈,任意进出栈,都是可以的。 这样就可以做到更加灵活的应用。

    1.6K70

    写一个用迭代法解方程的Java程序

    它利用计算机运算速度快、适合做重复性操作的特点,让计算机对一组指令(或一定步骤)进行重复执行,在每次执行这组指令(或步骤)时,都从变量的原值推出它的一个新值。...迭代法具有循环的计算方法,方法简单,适宜解大型稀疏矩阵方程组,在用计算机计算时只需存储A的非零元素(或可按一定公式形成系数,这样A就不需要存储)。...(1)对于给定的方程组X =Bx+f,用式子 逐步代入求近似解的方法称为迭代法(或称为一阶定常迭代法,这里与B和k无关) (2) 如果limx(k), x→∞存在(记作x* ),称此迭代法收敛,...xk+1=xk-f(xk)➗f’(xk)(k=0,1,2……) 3.例题讲解 例:用牛顿迭代法三次求方程f(x)=x5-x2+x-30=0,在区间[1,3]中的近似值请详细解答 解: f(1)...所以x=2.0001 4.代码编写 例:使用牛顿迭代法求方程的解,X3-2x-5=0,在区间[2,3]上的根。

    1.6K20
    领券