最近一直忙着处理原来老项目遗留一些SQL优化问题,由于当初表设计以及字段设计问题,随着业务增长,出现了大量慢SQL,导致MySQLCPU资源飙升,基于此,给大家简单分享下这些比较使用易于学习和使用经验。这次的话简单说下如何防止你索引失效。再说之前我先根据我最近经验说下我对索引看法,我觉得并不是所以表都需要去建立索引,对于一些业务数据,可能量比较大了,查询数据已经有了一点压力
转载 2024-02-04 00:08:13
75阅读
首先我们来看一下一个极端反面例子String str=new String("string");这句话每次运行时候都会创建一个​​String​​​实例,由于传递给​​String​​​构造函数就是一个​​String​​实例,所以是完全没有必要。比如,如果将同一个对象插入到​​HashMap​​中一千万次,那么无疑这种做法是非常耗时耗空间。我们推荐做法如下//在同一台JVM中,只要包
原创 2022-01-04 10:29:19
106阅读
public class AutoBoxing { public static void sum() { long start = new java.util.Date().getTime(); /
原创 2023-05-29 11:50:49
43阅读
一般来说,对于java对象来说,可以重用对象情况下:尽量不要在需要时候就创建一个相同功能对象 1、String 2、尽量用静态初始化一些相同功能对象 改进后: 3、基本类型及其包装类 优先使用基础类
原创 2021-12-29 10:11:02
115阅读
在保证程序清晰性和简洁性基础下,重用具有相同功能对象,避免创建新对象当该对象状态是不变化,新创建
原创 2021-07-28 17:46:54
368阅读
1. 避免创建不必要对象频繁创建对象会增加垃圾回收负担,影响性能。可以通过复用对象来提高效率。java// 不好做法 for (int i = 0; i < 1000; i++) { String s = new String("Hello"); // 使用 s } // 好做法 String s = "Hello"; for (int i = 0; i <
原创 7月前
89阅读
 网络管理员在选购网络设备时候都是精挑细选,在同等级别的不同厂商之间反复研究,多次比较后选出最佳性价比产品来。不过有一点可能很多网络管理员都忽略了,那就是网络产品未来,一个产品不可能一直使用。肯定会有出问题时候,出问题后厂家服务就显得尤为重要了。同样网络技术是在不断发展前进,网络产品也要有一定可升级可扩展性。最近笔者就遇到升级核心设备问题,现记录如下:  
转载 2007-08-30 14:28:14
365阅读
简介在Java开发中,程序员要尽可能避免创建相同功能对象,因为这样既消耗内存,又影响程序运行速度。在这种情况下可以考虑重复利用对象。接下来举例几种对象重复利用场景,看看我们是不是有中招了,如果有赶紧趁着还没被发现悄悄改掉,被发现了会被diss啦!1、String和Boolean如下两种写法看似没有什么区别,但是如果深入jvm底层了解,我们可以利用jvm运行时常量池特性,避免创建具有相同功
原创 精选 2021-12-18 19:33:13
279阅读
 关于STL容器,最了不起一点是,它们会自己主动增长以便容纳下你放入当中数据,仅仅要没有超出它们最大限制就能够。对于vector和string,增长过程是这样来实现:每当须要很多其它空间时,就调用与realloc类似的操作。这一类似于realloc操作分为4部分:分配一块大小为当前容量...
转载 2015-08-14 19:45:00
104阅读
2评论
了解NumPy内部原理,避免不必要数组复制,提高NumPy操作效率
推荐 原创 2023-02-01 15:17:52
1161阅读
避免子组件不必要更新使用memo()对函数组件进行缓存,使其只有在props变化时重新执行。使用了memo()之后导致组件不必要更新唯一因素就只有props改变。对于引用类型props改变是导致组件不必要更新罪魁祸首,因为那常常难以让人察觉。不必要赋值缓存引用类型当组件执行时,会对组件中所有变量重新初始化。如下代码:const myComponent = ()=>{const 
转载 2021-01-30 11:00:59
1565阅读
2评论
首先:用netstat -an 来查看所有的开启端口(具体参数可以去man) 以下截图中可以看到我机子中所有的端口号 假如 我认为 22端口没用(其实是ssh服务开启端口,当然有用了,呵呵)那么我用 lsof -i :22 查看是哪个服务开启22端口 以下图可以看到22端口号所对应是ssh服务(如果你还不知道什么是ssh可以去谷歌,为什么ssh后面有个&ldquo;d&rd
原创 2011-10-10 10:49:19
1304阅读
1点赞
Mysql支持多种列类型,包括数值类型、日期时间类型、字符串类型等等一、数值类型1、BIT[(M)]位字段类型,M表示该字段位数,范围是1-64.如果M被省略,则默认为12、TINYINT [UNSIGNED] [ZEROFILL]很小整数,大小为1字节,有符号数范围是-128-127,无符号数范围是0-2552、SMALLINT [UNSIGNED] [ZEROFILL]小整数,大小
很多程序起来会选用一个任意高端口去listening(1024以上端口)但是会在135端口去登记客户端如果应用RPC会到135端口去查,所以135相当于个映射表 文件和打印共享端口 137,138,139 一种是通过传统NetBT走137,138,139端口 还有一种是tcp/ip上smb直接承载445端口 如果禁止这些端口访问只能通过ip访问  方法1.关闭445端口
原创 2009-04-30 16:07:22
803阅读
### mysql视图返回不必要列 在使用mysql数据库时,我们经常会遇到需要查询某些特定字段需求。如果我们直接查询整个数据表,就会返回大量数据,其中包含了一些我们并不需要列。这样不仅会造成数据传输浪费,还会降低查询效率。 为了解决这个问题,mysql提供了视图(View)功能,可以创建一个虚拟表,只包含我们需要列。当我们查询视图时,只会返回视图中列,而不会返回整个数据表
原创 2024-01-22 08:18:58
35阅读
这个时候设计模式中策略模式可以入场了。我试下是否能尽量不写代码给大家说明白策略模式是怎么回事,以及在这里怎么运用吧(当然,最后还是会给个示例,但描述中尽量不用大篇幅代码,以求大家尽量能听得懂)。先举个简单例子吧,如果你现在要做一个计算器,只考虑简单加减乘除,你在输入时是不是要判断是做加法还是减法之类?这是通常if else就会进场if (加法)将两个数相加并返回结果;else if (减法
转载 10月前
11阅读
试比较以下两行代码在被多次反复执行时效率差异:由于String被实现为不可变对象,JVM底层将其实现为常量池,既所有值等于"stringette" String对象实例共享同一对象地址,而且还可以保证,对于所有在同一JVM中运行代码,只要他们包含相同字符串字面常量,该对象就会被重用。我们继续比较下面的例子,并测试他们在运行时效率差异:[java] ​​view plain ​​​​cop
原创 2021-12-31 10:06:53
56阅读
在编程开发中,内存占用是我们经常要面对现实,通常
原创 2022-11-15 20:14:47
134阅读
采用三数取中,并用0下标元素存储枢轴。 //CodeBy Pnig0s1992  #include <iostream>  using namespace std;    int Partition(int * L,int low,int hig
原创 2012-03-04 15:13:34
1393阅读
1评论
虽然您很可能希望尽量多地使用 Web 窗体页框架那些节省时间和代码功能,但在某些情况下却不宜使用 ASP.NET 服务器控件和回发事件处理。 通常,只有在检索或存储数据时,您才需要启动到服务器往返过程。多数数据操作可在这些往返过程间客户端上进行。例如,从 HTML 窗体验证用户输入经常可在数据提交到服务器之前在客户端进行。通常,如果不需要将信息传递到服务器以将其存储在数据库中,那么您不应该编写导致往返过程代码。   如果您开发自定义服务器控件,请考虑让它们为支持 ECMAScript 浏览器呈现客户端代码。通过以这种方式使用服务器控件,您可以显著地减少信息被不必要发送到 Web
转载 2004-10-25 00:07:00
38阅读
2评论
  • 1
  • 2
  • 3
  • 4
  • 5