文章目录 一、Groovy 扩展方法引入 二、 分析 Groovy 中 Thread 类的 start 扩展方法 一、Groovy 扩展方法引入 ---- Groovy 可以对 JDK 中的一些类进行...方法扩展 , 这些 JDK 自带类可以执行额外的扩展方法 ; 在之前的博客 【Groovy】使用 Groovy 语言开发服务器 Server 和客户端 Client 套接字程序 ( 服务器客户端完整代码示例...| 运行服务器端与客户端效果及过程分析 ) 中 , 使用了 Thread.start { } 用法 , 在闭包中执行的就是线程 Thread 的 run 方法内容 ; 二、 分析 Groovy 中 Thread...类的 start 扩展方法 ---- 分析该为 Thread 类扩展的 start 扩展方法 , 扩展方法定义在了 DefaultGroovyStaticMethods 类中 ; 该 start 方法接收一个...start 方法参数是 闭包 类型 ; Thread 类的 start 扩展方法 源码 : /** * 这个类定义了groovy环境中普通JDK类上出现的所有新的静态groovy方法。
文章目录 一、扩展方法示例 二、静态扩展方法配置 三、编译静态扩展类 四、打包静态扩展类字节码到 jar 包中 五、测试使用 Thread 静态扩展类 一、扩展方法示例 ---- 为 Thread 扩展..., extensionClasses 用于配置 实例扩展方法 ; 这里配置的是 静态扩展方法 ; 配置完成后的项目结构如下 : 三、编译静态扩展类 ---- 在 Terminal 面板中 , 执行...源码到 classes 目录中 ; 其中 ThreadExt.groovy 中定义了 Thread 类的扩展方法 ; 编译过程及结果如下 : 四、打包静态扩展类字节码到 jar 包中 ---- 在...命令 , 将 classes 中的字节码文件按照 manifest/ 规则 , 打包到 thread.jar 文件中 ; 五、测试使用 Thread 静态扩展类 ---- 创建一个 Groovy 脚本..., 执行为 Thread 扩展的静态方法 hello 方法 ; Thread.hello{ printf "Hello" } 在 Terminal 面临中 , 使用命令行执行该 Groovy
文章目录 一、扩展方法示例 二、实例扩展方法配置 三、编译实例扩展类 四、打包静态扩展类字节码到 jar 包中 五、测试使用 Thread 实例扩展方法 一、扩展方法示例 ---- 为 Thread 扩展..., extensionClasses 用于配置 实例扩展方法 ; 这里配置的是 实例扩展方法 ; 配置完成后的项目结构如下 : 三、编译实例扩展类 ---- 在 Terminal 面板中 , 执行...源码到 classes 目录中 ; 其中 ThreadExt.groovy 中定义了 Thread 类的扩展方法 ; 编译过程及结果如下 : 四、打包静态扩展类字节码到 jar 包中 ---- 在...命令 , 将 classes 中的字节码文件按照 manifest/ 规则 , 打包到 thread.jar 文件中 ; 五、测试使用 Thread 实例扩展方法 ---- 创建一个 Groovy 脚本..., 执行为 Thread 扩展的静态方法 hello 方法 ; new Thread().hello{ printf "Hello" } 在 Terminal 面临中 , 使用命令行执行该 Groovy
文章目录 前言 一、Groovy 类中调用 Groovy 脚本 1、参考 Script#evaluate 方法分析 Groovy 类中调用 Groovy 脚本 2、创建 Binding 对象并设置 args...类中调用 Groovy 脚本 , 与 Groovy 类中调用 Groovy 脚本 , 代码基本类似 ; 也是参考 groovy.lang.Script#evaluate 方法 , 创建 Binding...---- 1、参考 Script#evaluate 方法分析 Groovy 类中调用 Groovy 脚本 可以参考 groovy.lang.Script 类的 evaluate 方法 , 通过 GroovyShell...在类方法中调用 Groovy 脚本 ; 在 evaluate 方法中 , 首先创建 GroovyShell 实例对象 , 然后执行该实例对象的 evaluate 方法 , 传入要调用的 Groovy...脚本 /* 下面的 age 和 age2 都是变量定义 age 变量的作用域是 本地作用域 age2 变量的作用域是 绑定作用域 一个是私有变量 , 一个是共有变量
我们常见的 Object a = new Object(); Object b; b = a; 这种形式的代码复制的是引用, 即对象在内存中的地址, a和b指向了同一个对象....简单说, 深克隆不仅克隆了当前对象, 还把当前对象所引用的对象都复制了一遍. Object中的clone Object类中的clone()方法属于浅克隆....它的工作原理如下: 在内存中先开辟一块和原始对象相同的空间, 然后复制原始对象的内容....Java中实现深克隆 将类中的所有引用类型都进行clone, 并重写对象clone()方法, 对所有引用类型进行clone. 代码如下: ? 将所有引用类型都进行clone, 实现了深克隆....Java序列化克隆 如果引用类型中海包括引用类型, 要实现多层克隆会很麻烦, 这使用可以使用序列化和反序列化的方式实现对象的深克隆.
无论是在java面试过程中,还是在与各种老鸟交流的过程中,对java对象的深浅拷贝,都是一个绕不开的问题,这个问题看似很容易,却是大多数人用来区分小白的标准问题。现在对该问题进行说明。...1.定义 浅克隆(拷贝):复制一个对象的实例,但是这个对象中包含的其它的对象还是共用的。一般用super.clone()方法,clone的对象就是浅克隆。...深克隆(拷贝):复制一个对象的实例,而且这个对象中包含的其它的对象也要复制一份。...clone和deepClone方法。...当然,实现深克隆的方法并不局限于流这一种办法,还可以通过json等其他办法实现。
文章目录 一、Java 类成员及 setter 和 getter 方法设置 二、Groovy 类自动生成成员的 getter 和 setter 方法 一、Java 类成员及 setter 和 getter...类自动生成成员的 getter 和 setter 方法 ---- 在 Groovy 脚本中创建 Groovy 类 , 在其中定义 2 个成员 ; /** * 创建 Groovy 类 * 在其中定义...2 个成员 */ class Student { def name def age } 在 Groovy 中的类中 , 不需要定义成员变量的 setter 和 getter 方法 ,...Groovy 会自动生成相关的 getter 和 setter 方法 ; /** * 创建 Groovy 类 * 在其中定义 2 个成员 */ class Student { def name...Student.class 字节码文件 , 可以看到系统为 Student 类自动生成了 getter 和 setter 方法 ; 完整的字节码类如下 : // // Source code recreated
文章目录 一、Groovy 类中调用 Groovy 脚本 1、创建 GroovyShell 对象并执行 Groovy 脚本 2、代码示例 二、完整代码示例 1、调用者 Groovy 脚本的类 2、被调用者...Groovy 脚本 3、执行结果 一、Groovy 类中调用 Groovy 脚本 ---- 1、创建 GroovyShell 对象并执行 Groovy 脚本 首先 , 创建 GroovyShell 对象...// 注意这里创建 groovy.lang.Binding def binding = new Binding() // 设置 args 参数到 Binding 中的 variable...shell.evaluate(file) } } new Test().startScript() 二、完整代码示例 ---- 1、调用者 Groovy 脚本的类 class...() 2、被调用者 Groovy 脚本 /* 下面的 age 和 age2 都是变量定义 age 变量的作用域是 本地作用域 age2 变量的作用域是 绑定作用域 一个是私有变量
文章目录 一、以动态特性编译的 Groovy 类 二、Groovy 语言与 Java 语言执行效率对比 三、以静态特性编译的 Groovy 类 一、以动态特性编译的 Groovy 类 ---- Groovy...类都实现了 GroovyObject 接口 , 如下面的 Groovy 类 , class Farmer {} 编译后的字节码文件内容如下 : public class Farmer implements...语言与 Java 语言执行效率对比 ---- Groovy 语言实现了动态性 , 是以牺牲执行效率和性能为代价的 ; 执行相同时间复杂度的代码 , 从消耗的时间上分析 , Groovy 语言是 Java...语言的几倍 ; 三、以静态特性编译的 Groovy 类 ---- 在 Groovy 类上 , 使用 @CompileStatic 注解 , @CompileStatic class Farmer {}...即可关闭动态特性 , 按照普通的 Java 类进行编译 , 编译出的字节码如下 : public class Farmer implements GroovyObject { @Generated
Codeigniter框架提供了实现多个应用Application的方法,如参考资料[2]中描述的,这种方法实际上是在网站目录下存在多个入口文件和Application文件夹的方式。...Controller中的文件需要一些公共的方法,在Codeigniter中,当我们需要在所有的控制器Controller中添加一些公共方法时,可以考虑对Controller进行扩展。...例如用户登录的检查函数,具体的方法我们可以参考[1]中的描述。如果我的前台页面不需要检查登录,后台页面需要检查登录,使用这种方法就会有问题。...扩展核心类的实现代码,位于System/Core/Codeigniter.php的第214行,代码如下: 1: if (file_exists(APPPATH.'core/'....版本中能够有些改善。
文章目录 一、Groovy 类中调用 Groovy 脚本 1、参考 Script#evaluate 方法分析 Groovy 类中调用 Groovy 脚本 2、创建 Binding 对象并设置 args...参数 一、Groovy 类中调用 Groovy 脚本 ---- 1、参考 Script#evaluate 方法分析 Groovy 类中调用 Groovy 脚本 可以参考 groovy.lang.Script...类的 evaluate 方法 , 通过 GroovyShell 在类方法中调用 Groovy 脚本 ; 在 evaluate 方法中 , 首先创建 GroovyShell 实例对象 , 然后执行该实例对象的...类中 , 并没有该 Binding 成员变量 , 需要通过手动创建 Binding 实例对象 , 然后传入 GroovyShell 构造函数 ; 在 Binding 对象中的 Map variables...成员中 , 设置 args 参数 , 作为调用 Groovy 脚本的执行参数 ; 首先 , 要在 Groovy 类方法中 , 创建 Binding 对象 , // 注意这里创建 groovy.lang.Binding
在上一期从Java到Groovy的八级进化论中,我分享了Java是如何转变成Groovy。今天,我将分享学习Groovy对list的语法支持。 以下Java类也是有效的Groovy类。...str.length() < length + 1) { result.add(str) } } return result }``` 无需创建类的实例...到目前为止,这些小变化并不是真正的新事物,因为我们之前已经遵循了这些步骤。现在,我们要发现的是,借助`Groovy`列表的本机语法,如何使列表更加友好。那么我们如何定义一个新列表?...可以使用下标运算符设置和访问元素: ```Python assert names[1] == "Fred" names[1] = "Frederic" `Groovy...`Groovy`通过“装饰”核心JDK类来做到这一点。
Groovy元组是有序的,不变的元素列表。Groovy有自己的groovy.lang.Tuple类。我们可以通过构造函数Tuple提供需要包含在其中的所有元素来创建一个实例Tuple。...我们甚至不能更改元组中的元素,因此它是完全不变的。这使得它非常适合用作需要返回多个值的方法的返回值。Groovy还提供了一个Tuple2仅可用于两个元素的元组实例的类。元素在Tuple2实例中键入。...在以下示例中,我们看到Tuple和Tuple2类的不同用法: package com.FunTester.demo import com.fun.frame.SourceCode class demo5
在上一期从Java到Groovy的八级进化论中,我分享了Java是如何转变成Groovy。今天,我将分享学习Groovy对list的语法支持。 以下Java类也是有效的Groovy类。...str.length() < length + 1) { result.add(str) } } return result }``` 无需创建类的实例...到目前为止,这些小变化并不是真正的新事物,因为我们之前已经遵循了这些步骤。现在,我们要发现的是,借助`Groovy`列表的本机语法,如何使列表更加友好。那么我们如何定义一个新列表?...`def names = []` 而且,我们可以一次填充一个元素,而不是一次在列表中添加一个元素: `def names = ["Ted", "Fred", "Jed", "Ned"]` 可以使用下标运算符设置和访问元素...Groovy通过“装饰”核心JDK类来做到这一点。列表上添加了两个方便的方法,它们是用于遍历所有元素的each()方法,以及用于查找符合某个条件的所有元素的findAll()方法。
,object】 (在内存中表现为一个指针,保存在堆中) 将一个对象的所有属性均复制,并将该对象与原对象放在内存中不同的位置,此时,改变新对象的属性不会对原对象造成影响,这种行为叫做深克隆。...看他们的爱好: 浅克隆只是简单的复制对象,若对象其中一个属性是引用值,由于引用型变量保存的是内存的一个地址,所以后来的hobby属性,都指向内存中的同一块地址,最后输出的结果同样相同。...从上面的例子也可以看出,name等原始值的改变,并不会影响原对象中的原始值。 ---- 解决克隆引用值问题,还是需要深度克隆的!...看他们的爱好: ---- 一些扩展 js里的concat函数 concat函数对数组进行了深度克隆 var a = [1,2,3]; console.log(a.concat(4,5)); //[1,...target 类型: Object 对象扩展。这将接收新的属性。
枚举类 Kotlin中的枚举类和Java中的枚举类型非常相似,具有类的特性。一般将可枚举的同类型的一组值作为枚举类定义。...因此枚举值在枚举类中的位置和枚举值对应的数值可能并不相同。...在类的外部对系统的类进行扩展,由于将扩展的部分都放到了自己的源代码中,因此这些源代码仍然可以运行在其他机器的JDK和Kotlin运行时上。...扩展属性 扩展属性和扩展方法类似,Kotlin属性在类中必须初始化,而初始化需要使用backing field,也就是那个field字段,可以将属性设置的值保存在field中,也可以从field获得属性值...如果在B中扩展A,那么在A的扩展方法中调用A和B都有的成员函数,到底是调用A的还是B的呢?
前序和后序树遍历 Groovy中的Node类有depthFirst和breadthFirst方法,可以使用深度优先遍历或广度优先遍历返回Node对象的集合。...由于Groovy 2.5.0,我们可以指定是使用preorder(默认值)还是postorder遍历。此外,这些方法现在接受一个“闭包”,该“闭包”将为每个访问的节点调用。...Closure将当前“节点”作为第一个参数,第二个参数是当前节点的树级。...在下面的例子中,我们读取了一些XML,然后使用depthFirst以几种方式访问节点树: // We start with a XML node hierarchy. def xml = '''...这意味着树中每层访问的节点: // Let's create a Node hierarchy. def builder = NodeBuilder.newInstance() def root = builder.A
[_tfdUserName setValue:[UIColor whiteColor] forKeyPath:@"_placeholderLabel.textC...
文章目录 一、创建 Groovy 代码文件 二、使用 Java 语法实现 Groovy 类和主函数并运行 三、按照 Groovy 语法改造上述 Java 语法规则代码 一、创建 Groovy 代码文件...---- 在 Gradle 工程中 , 右键点击 src/main/groovy 目录 , 创建 Class , 命名为 Test ; 二、使用 Java 语法实现 Groovy 类和主函数并运行...; 三、按照 Groovy 语法改造上述 Java 语法规则代码 ---- 按照 Groovy 语法改造上述 Java 语法规则代码 : Groovy 类前可以不加 public 函数参数类型 ,...可以不用声明 Groovy 代码可以不使用分号 println 方法可以直接调用 , 不使用 System.out 也可以 println 后与要打印的字符串 使用空格隔开即可 , 可以不使用括号 修改后的代码示例.../ Groovy 代码可以不使用分号 // println 方法可以直接调用 , 不使用 System.out 也可以 // println 后与要打印的字符串 使用空格隔开即可
克隆,想必大家都有耳闻,世界上第一只克隆羊多莉就是利用细胞核移植技术将哺乳动物的成年体细胞培育出新个体,甚为神奇。其实在Java中也存在克隆的概念,即实现对象的复制。...本文将尝试介绍一些关于Java中的克隆和一些深入的问题,希望可以帮助大家更好地了解克隆。...Clone 在Java中,clone是将已有对象在内存中复制出另一个与之相同的对象的过程。java中的克隆为逐域复制。...应尽量避免clone 1.通常情况下,实现接口是为了表明类可以为它的客户做些什么,而Cloneable仅仅是一个标记接口,而且还改变了超类中的手保护的方法的行为,是接口的一种极端非典型的用法,不值得效仿...因此为了实现克隆,我们需要考虑舍去该可变对象域的final关键字。 4.线程安全 如果你决定用线程安全的类实现Cloneable接口,需要保证它的clone方法做好同步工作。
领取专属 10元无门槛券
手把手带您无忧上云