关键字优化

Java中的static关键字解析

天涯浪子 提交于 2019-11-28 17:43:44
  “static方法就是没有this的方法。在static方法内部不能调用非静态方法,反过来是可以的。而且可以在没有创建任何对象的前提下,仅仅通过类本身来调用static方法。这实际上正是static方法的主要用途。”   这段话虽然只是说明了static方法的特殊之处,但是可以看出static关键字的基本作用,简而言之,一句话来描述就是:   方便在没有创建对象的情况下来进行调用(方法/变量)。   很显然,被static关键字修饰的方法或者变量不需要依赖于对象来进行访问,只要类被加载了,就可以通过类名去进行访问。   static可以用来修饰类的成员方法、类的成员变量,另外可以编写static代码块来优化程序性能。 1)static方法   static方法一般称作静态方法,由于静态方法不依赖于任何对象就可以进行访问,因此对于静态方法来说,是没有this的,因为它不依附于任何对象,既然都没有对象,就谈不上this了。并且由于这个特性,在静态方法中不能访问类的非静态成员变量和非静态成员方法,因为非静态成员方法/变量都是必须依赖具体的对象才能够被调用。   但是要注意的是,虽然在静态方法中不能访问非静态成员方法和非静态成员变量,但是在非静态成员方法中是可以访问静态成员方法/变量的。举个简单的例子: 因此,如果说想在不创建对象的情况下调用某个方法,就可以将这个方法设置为static

C++unique和C/C++register关键字

核能气质少年 提交于 2019-11-28 05:08:06
看大佬的代码时发现这两个东西,然后就去了解了一下,以后估计也会用到,所以,简单写个博客记录下来。 一 unique ; unique是 c++标准模板库STL中十分实用的函数之一,使用此函数需要#include < algorithm >头文件 该函数的作用是“去除”容器或者数组中 相邻元素 的重复出现的元素 (1) 这里的去除并非真正意义的erase,而是将重复的元素放到容器的末尾,返回值是去重之后的尾地址。 (2) unique针对的是相邻元素,所以对于顺序顺序错乱的数组成员,或者容器成员, 需要先进行排序,可以调用std::sort()函数 简单示范 register关键字 在早期c语言编译器不会对代码进行优化,因此使用register关键字修饰变量是很好的补充,大大提高的速度。 register关键字请求让编译器将变量a直接放入寄存器里面,以提高读取速度,在C语言中register关键字修饰的变量不可以被取地址,但是c++中进行了优化。 c++中依然支持register关键字,但是c++编译器也有自己的优化方式,即某些变量不用register关键字进行修饰,编译器也会将多次连续使用的变量优化放入寄存器中,例如入for循环的循环变量i。 c++中也可以对register修饰的变量取地址,不过c++编译器发现程序中需要取register关键字修饰的变量的地址时

《VUE》搜索关键字高亮显示

一个人想着一个人 提交于 2019-11-28 00:02:00
效果实例 // 第一种:筛选变色        KeyRegExp:function(val, keyword) { val = val + ''; if (val.indexOf(keyword) !== -1 && keyword !== '') { return val.replace(keyword, '<font color="#f00">' + keyword + '</font>') } else { return val } }, // 第二种:正则表达式        KeyRegExp:function(val, keyword) { var Reg = new RegExp(keyword, 'i'); if (val) { return val.replace(Reg, `<span style="color: #f00;">${keyword}</span>`); } }, // 第三种:正则表达式(对于第二种的优化) keyRegExp:function (str,key){ // 搜索关键字高亮显示 // 正则匹配中文、英文关键字高亮,高亮后的关键字和之前的大小写保持一致 var key = key;//这里定义关键词 key = '('+key.replace(/([\+\.\*\|\?\-\(\[\^\$])/g,'\\$1' ).replace(

Scala面试题汇总

荒凉一梦 提交于 2019-11-27 07:10:40
文章转载自: http://www.pythonheidong.com/blog/article/2855/ scala常见笔试题(囊括了scala的精髓) scala最近几年很火,主要是因为其在大数据领域的应用。 下面这些面试题,基本上是scala函数式编程的精髓。 Q1 var,val和def三个关键字之间的区别? 答:var是变量声明关键字,类似于Java中的变量,变量值可以更改,但是变量类型不能更改。 val常量声明关键字。 def 关键字用于创建方法(注意方法和函数的区别) 还有一个lazy val(惰性val)声明,意思是当需要计算时才使用,避免重复计算 Q2 trait(特质)和abstract class(抽象类)的区别? 答:(1)一个类只能集成一个抽象类,但是可以通过with关键字继承多个特质; (2)抽象类有带参数的构造函数,特质不行(如 trait t(i:Int){} ,这种声明是错误的) Q3 object和class的区别? 答:object是类的单例对象,开发人员无需用new关键字实例化。如果对象的名称和类名相同,这个对象就是伴生对象(深入了解请参考问题Q7) Q4 case class (样本类)是什么? 答:样本类是一种不可变且可分解类的语法糖,这个语法糖的意思大概是在构建时,自动实现一些功能。样本类具有以下特性: (1

JAVA提高(二)--- 数据库部分

穿精又带淫゛_ 提交于 2019-11-26 13:51:33
1. 数据库架构 如何设计一个关系型数据库: 将其划分为两个部分——一个是存储部分,把数据持久化在存储设备中。另一个是程序实例模块,又细分为存储管理(程序逻辑关系转换为存储关系)、缓存机制(优化执行效率)、SQL解析、日志管理(记录操作)、权限划分(多用户管理)、容灾机制、索引管理(优化数据查询效率)、锁管理(支持并发模块)。 2. 优化索引 (一)使用平衡二叉树或者红黑树,在每次节点的访问就会进行一次IO,如果数据很多,就会多次IO。速度比全表扫码慢很多。 (二)B树(平衡多路查找树),每个节点有M个孩子,就是M阶B树,每个存储块中有关键字和指向孩纸的指针。 特征(孩子): 根节点至少包括两个孩子 树中每个节点最多有m个孩子(m>=2,m取决于容量和数据库的配置) 除了根节点和叶节点外,其他节点至少有m/2(向上取整)个孩子,至少具备连个孩子 所有叶子节点都位于同一层 特征(关键字) 关键字是升序排列的 关键字个数永远比孩子数少一个 最左边的关键字大于最左边孩纸节点里面的值,最右边的关键字小于最右边孩子节点里面的值,而孩子i则在关键字(i-1)与关键字i之间(注:开区间的)。 作为索引比二叉树好。因为深度更低、不会出现线性。 (三)B+树 孩子特征与B树相同 特征(关键字) 孩子与关键字个数相同 非叶子节点的子树指针P[i], 指向关键字的值[k[i],k[i+1])