首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么静态方法不能使用this

JVM的运行时数据区中有个虚拟机栈(或Java栈),它的里面是由栈帧'叠加'而成.栈帧由局部变量表,操作数栈,动态连接,方法返回地址等组成. 那么我们就从局部变量表角度解答下这个问题....下面是测试代码,一个静态方法query,一个普通方法shadow,这两个方法的参数和函数体完全一样. // 静态方法 public static void query(String year) {...int month = 12; String address = "Jiangsu"; System.out.println(address); } // 普通方法 public void...query方法的局部变量表,如下 shadow方法的局部变量表,如下 我们发现,非静态方法shadow的局部变量表中有this,而在静态方法query的局部变量表中没有this....普通方法中,它的局部变量表中的第一个槽存放了this, 而静态方法的局部变量表中没有存放this.

1.9K30

Scala如何改变了我的编程风格:从命令式到函数式

尽管C++里面这种编程风格是有可能的,但在我使用C++的日子里,我却没有考虑用这种方式进行多重继承,而我C++设计中也不怎么使用抽象基类。...然而,一旦我开始进行Java编程,我就开始一直使用这种风格了。学习Java—尤其是它的接口构造—改变了我OO设计的方法。...函数化的编程风格强调不可变对象、变量可被初始化但不能重新赋值( Java 中的最终变量)、数据结构转换,以及方法和控制的构造,最终产生一个没有副作用的结果。...函数化的版本里这种错误不会产生,在这种方式下,函数化版本相对而言不易出错。 最后,我想指出的是我转向 Scala 的时候并没有“彻底函数化”。...尽管我已经发现通常大部分情况下函数化风格的代码来得更为简洁、明晰,更不易出错,我还发现有时候命令式风格也可带来更为清晰和简洁的代码。在那种情况下,我就会使用命令式的。

1K30
您找到你想要的搜索结果了吗?
是的
没有找到

技术分享 | Spark RDD详解

为什么会产生RDD? (1)传统的MapReduce虽然具有自动容错、平衡负载和可拓展性的优点,但是其最大缺点是采用非循环式的数据流模型,使得迭代计算式要进行大量的磁盘IO操作。...RDD正是解决这一缺点的抽象方法 (2)RDD的具体描述RDD(弹性数据集)是Spark提供的最重要的抽象的概念,它是一种有容错机制的特殊集合,可以分布集群的节点上,以函数式编 操作集合的方式,进行各种并行操作...要实现这种“血统”容错机制,最大的难题就是如何表达父RDD和子RDD之间的依赖关系。...中的地位及作用 (1)为什么会有Spark?...可以理解为:RDD是一种具有容错性基于内存的集群计算抽象方法,Spark则是这个抽象方法的实现。 3、如何操作RDD?

1.2K50

深圳大数据培训学习:继承--【千锋】

扩展类 Scala中扩展类的方式和Java一样都是使用extends关键字 可以把类声明为final,使之不能扩张 也可以把单个方法或者字段声明为final,以确保它不能被重写,注意和Java的不同,...重写方法 Scala中重写一个非抽象方法必须使用override修饰符 子类中调用超类的方法使用super,和Java一致。...println("I can code by Java")       } else{ println("I can't code by Java")       }     } //未被实现的方法默认为抽象方法...val t1,t2,(a, b, c) = { println("ABC")       (1,2,3)     } println(a) println(t1._1) //Scala中重写一个非抽象方法必须用...def byScala(): String={ "coding by Scala"     } //子类中重写超类的抽象方法时,不需要使用override关键字,写了也可以 def run()

49420

scala 容器详细解释

这种情况下,程序每次运行都可能会导致哈希集合的”第一个“元素发生变化。如果一个容器总是以相同的规则排列元素,那这个容器是有序的。...这就是为什么Scala容器中的所有容器类型都把有序作为可选项。例如,带有序性的HashSet就是LinkedHashSet。...这个trait里所有方法的定义都基于一个抽象方法,迭代器(iterator,会逐一的产生集合的所有元素)。...Iterable有两个方法返回迭代器:grouped和sliding。然而,这些迭代器返回的不是单个元素,而是原容器(collection)元素的全部子序列。...2, 3, 4) scala> sit.next() res7: List[Int] = List(3, 4, 5) 抽象方法: xs.iterator xs迭代器生成的每一个元素,以相同的顺序就像foreach

1.2K10

Scala专题系列(六) : Scala特质

Java 中,类可以实现任意数量的接口。这种模型非常适用于声明实现了多个抽象的类。不过,这类模型也存在一个明显的缺点。对于一些接口而言,使用该接口的所有类使用了样板代码实现接口的大量功能。... Java 8 诞生之前, Java 未提供用于定义和使用这类可重用代码的内置机制。为此, Java必须使用特定的方法进行复用某一接口的实现代码。 Java 8 做出了改变。...Scala和Java一样不允许类从多个超类继承,Java中类只能扩展 自一个超类,它可以实现多个接口,但接口中只能包含抽象方法,不能包含字段 Scala提供的"特质"类似于java中的接口, 但又有所不同...(msg:String) // 这是一个抽象方法 } scala特质中,不需要将方法声明为abstract ,特质中未被实现的方法默认就是抽象的,同时子类的实现如下: class consoleLogger...= new Date() } 混入该特质的类自动获得一个time字段,特质中的每个具体字段,使用该特质得会获得一个字段与之对应,这些字段不能够被继承,它们只是简单的被加到了子类当中.

65420

大数据利器--Scala语言学习(基础)

这种函数我们称之为惰性函数, Java 的某些框架代码中称之为懒加载(延迟加载),Java中没有原生方法。...5) scala 中没有 public 关键字,即不能用 public 显式的修饰属性和方法。...,因此就不涉及到方法重写的概念,因此 override 可省略] Scala 抽象类 1) 抽象不能被实例 2) 抽象类不一定要包含 abstract 方法。...也就是说,抽象类可以没有 abstract 方法 3) 一旦类包含了抽象方法或者抽象属性,则这个类必须声明为 abstract 4) 抽象方法不能有主体,不允许使用 abstract 修饰。...【案例演示+反编译】 6) 抽象方法抽象属性不能使用 private、final 来修饰,因为这些关键字都是和重写/实现相违背的。

99610

Spark RDD详解 -加米谷大数据

为什么会产生RDD? (1)传统的MapReduce虽然具有自动容错、平衡负载和可拓展性的优点,但是其最大缺点是采用非循环式的数据流模型,使得迭代计算式要进行大量的磁盘IO操作。...RDD正是解决这一缺点的抽象方法 (2)RDD的具体描述RDD(弹性数据集)是Spark提供的最重要的抽象的概念,它是一种有容错机制的特殊集合,可以分布集群的节点上,以函数式编 操作集合的方式,...要实现这种“血统”容错机制,最大的难题就是如何表达父RDD和子RDD之间的依赖关系。...可以理解为:RDD是一种具有容错性基于内存的集群计算抽象方法,Spark则是这个抽象方法的实现。 3、如何操作RDD?...注意:默认情况下使用8个并行任务进行分组,你可以传入numTask可选参数,根据数据量设置不同数目的TaskreduceByKey (func, [numTasks])一个(K,V)对的数据集上使用

1.5K90

大数据分析工程师面试集锦2-Scala

为什么要考察Scala?...ScalaJVM上编译运行的时候需要与JDK以及其他Java库进行交互,这部分的交互就会涉及到Scala和Java集合之间转换,默认情况下这两个集合是不兼容的,所以代码中需要增加如下命令: 1)import...Scala工程中抽象类和特质是很有用的工具,这个问题需要先回答什么是抽象类以及什么是特质。...抽象类是普通类的基础上增加了abstract关键字,无法对其进行实例化,它是用来被子类继承的,抽象类中可以只定义字段和方法,具体的值和实现在其子类中实现,子类也可以进行重写。...当调用该函数或方法时,如果没有传该参数的值,Scala会尝试变量作用域中找到一个与指定类型相匹配的使用implicit修饰的对象,即隐式值,注入到函数参数中函数体使用

2K20

全面探索Optional类型

让我们回到Null的本原状态,思考为什么会产生Null?首先,Null代表一种异常状态,即在某种未可知的情形下,可能返回Null;正常情况下,返回的则是非Null的对象。...程序世界里,我们似乎可以将其抽象为一个集合来表达这种非此即彼的状况,但从函数式编程的角度来讲,应将其设计为一个Monad。...Scala语言中可以写成class M[A],或者case class M[A],有或者trait M[A] 一个unit方法(unit v)。...对应Scala中的函数new M(v)或者M(v)的调用。 一个bind方法,起到将运算排成序列的作用。Scala中通过flatMap组合子来实现。...此时的Null不再是特例,而是抽象Option[A]对称的两个元素中的其中一个,Scala中,即Option[T]中的Some[T]或None。它们俩面貌相同,却是一对性格迥异的双生子。

37120

Scala学习教程笔记二之函数式编程、Object对象、伴生对象、继承、Trait、

private来修饰,那么代表这个field是类私有的,类的方法中,可以直接访问类的其他对象的private field;这种情况下,如果不希望field被其他对象访问到,那么可以使用private[...此时可以将父类中的这些方法不给出具体的实现,只有方法签名,这种方法就是抽象方法;     13.1:注意:一个类中如果有一个抽象方法,那么类就必须用abstract来声明为抽象类,此时抽象类是不可以实例化的...,此时的trait就与Java中的接口非常类似; b、trait中可以定义抽象方法,就与抽象类中的抽象方法一样,只要不给出方法的具体体现即可; c、类可以使用extends...中定义具体方法: Scala中的trait可以不是只定义抽象方法,还可以定义具体方法,此时trait更像是包含了通用工具方法的东西,有一个专有的名词来形容这种情况,就是说trait的功能混入了类...中覆盖抽象方法【注意语法】:   Trait中,是可以覆盖父trait的抽象方法的。

1K60

scala快速入门系列【特质】

使用extends来继承trait(scala不论是类还是特质,都是使用extends关键字) 如果要继承多个trait,则使用with关键字 trait作为接口使用 trait作为接口使用...---- 示例 | 继承单个trait 创建一个Logger特质,添加一个接受一个String类型参数的log抽象方法 创建一个ConsoleLogger类,继承Logger特质,实现log方法,打印消息...定义 一个特质中,具体方法依赖于抽象方法,而抽象方法可以放到继承tarit的子类中实现,这种设计方法也称为模板模式。 ?...scala中,trait是可以定义抽象方法,也可以定义具体方法的。 trait中定义了一个抽象方法 trait中定义了其他的几个具体方法,会调用抽象方法。...定义 trait也有构造代码,但和类不一样,特质不能有构造器参数 每个特质只有一个无参数的构造器。

46320

Scala 基础语法(一)

类 - 类是对象的抽象,而对象是类的具体实例。 方法 - 方法描述的基本的行为,一个类可以包含多个方法。 字段 - 每个对象都有它唯一的实例变量集合,即字段。对象的属性通过给字段赋值来创建。...你可以"之间使用任何有效的 Scala 标志符,Scala 将它们解释为一个 Scala 标志符,一个典型的使用为 Thread 的 yield 方法 Scala 中你不能使用 Thread.yield...例如 val s = "菜鸟教程"; println(s) ---- Scala 包 定义包 Scala 使用 package 关键字定义包,Scala将代码定义到某个包中有两种方式: 第一种方法和...Java 一样,文件的头定义包名,这种方法就后续所有代码都放在该包中。..._,这里也能解释,为什么scala开头的包,使用时都是省去scala.的。

71630

Dart的语法详解系列篇(三)-- mixin入门详解一、继承歧义

语言 解决方案 C++(底层、硬件、编解码、算法等都用得到) 默认情况下,每个继承路径都是分开的,因此D对象实际上包含两个独立的a对象,并且必须正确限定a成员的使用。...Java8(服务端开发、Android开发) Java 8接口上引入默认方法。如果A、B、C是接口,B、C可以为A的抽象方法提供不同的实现,从而导致菱形问题。...该算法强制执行两个约束:子类先于父类,如果一个类从多个类继承,它们将按照基类元组中指定的顺序保存(但是在这种情况下,继承图中较高的一些类可能先于图中较低的类)。...因此,方法的分辨率顺序为:D, B, C, A。 Scala(可以用于大数据方面) Scala允许特性的多个实例化,通过类层次结构和特征层次结构之间添加区别,可以实现多重继承。...类只能从单个类继承,但是可以根据需要混合(mix-in)任意多的特性。Scala使用扩展的traits的右优先深度优先的搜索来解析方法名,然后除去结果列表中每个模块的最后一次出现。

1.6K10

scala语言会取代Java的吗?

同样许多其他大的公司如 Sony Picture, EDF, SAP 也开始使用这种语言。为什么Scala发展这么迅猛,可以获得如此热烈的社区支持。...Scala 开发团队发布了最新的2.9.2稳定版本,Scala 语言的特性有许多,例如 高阶函数 和对象、抽象类型绑定,actor 使得函数 Scala 中能是一个子类成为可能,Scala 中的设计模式使得面向对象...Scala的case类及其内置支持的模式匹配模型代数类型许多函数式编程语言中都被使用。  ...Scala是静态类型的 Scala配备了一套富有表现力的类型系统,该抽象概念以一种安全的和一致的方式被使用。...其次,这些基本机制上面有一个抽象层   Scala 提供了稳定的高性能平台(Java 虚拟机)上生成的能力同时也是一门敏捷性语言。

1.9K60

大数据--scala学习第一章:基础第二章:控制结构和函数第三章:数组第四章:字典和元组第五章:类第六章:对象第七章:包和引入第八章:继承第九章文件和正则表达式第十章特质:接口第十一章操作符第十二章函

如果带参数则在类名后的()中定义,如果使用表5.1中定义的参数,将在类中为字段,如果不包含val和var,没有方法使用情况下改参数只用于语句访问,如果方法使用了就是对象私有字段。...*包一样,Scala默认引入了java.lang.、scala.、Predef._。三个包。 第八章:继承 1、Scala继承方式与java一样使用extends关键词,而且也一样只能继承单个类。...2、Scala中一个非抽象方法重写时必须使用override修饰符如:override def toString=getClass.geName+super.toString+”peace”。...3、特质中可以有具体实现的方法,java中的接口Scala中可以当做特质来使用,也可以new对象时继承特质:val acct=new Peolpe with Logger。...甚至如果参数右侧只出现了一次你可以用_替换掉x:valueAtOneQuater(3*_)。这些简写方式只有参数已知情况下才有效,一般只推荐函数参数中使用

4.4K20

3小时Java入门

可以用统一的Iterator方式对大多数容器类进行遍历,这种更加抽象的方式优于使用下标的方式进行遍历。 ?...通常情况下我们使用ArrayList更多一些。 和数组Array不同,List的大小是可以改变的。...静态属性和静态方法属于类而不属于特定的实例,类的实例之间共享。 可以通过类名直接调用静态属性和静态方法,也可以通过实例对象间接调用。 静态方法不能够通过this关键字使用实例属性。 ? ?...二十二,抽象使用abstract声明的方法抽象类,抽象类只能够被继承,不能够创建抽象类的实例。 抽象类的方法可以被abstract声明为抽象方法抽象方法没有执行语句。...interface和interface之间也可以相互继承,使用关键字 extends来表示这种扩展关系。 interface不能有实例属性,但可以有静态属性。

2.7K30

Scala语言快速了解一下?

_,这里也能解释,为什么scala开头的包,使用时都是省去scala.的。如果想要引入包中的几个成员,可以使用selector(选取器):import java.awt.... Scala 中声明变量和常量不一定要指明数据类型,没有指明数据类型的情况下,其数据类型是通过变量或常量的初始值推断出来的。...如果没有指定访问修饰符,默认情况下Scala 对象的访问级别都是 public。Scala 中的 private 限定符,比 Java 更严格,嵌套类情况下,外层类甚至不能访问被嵌套类的私有成员。...子类中重写超类的抽象方法时,你不需要使用override关键字。Scala 使用 extends 关键字来继承一个类,继承会继承父类的所有属性和方法Scala 只允许继承一个父类。...Scala重写一个非抽象方法,必须用override修饰符。

2.9K102
领券