zoukankan      html  css  js  c++  java
  • 大数据学习——scala入门练习

    package com
    
    /**
      * Created by ZX on 2015/11/6.
      */
    object VariableDemo {
      def main(args: Array[String]) {
    
        //1定义变量-----------------------------------------
        //使用val定义的变量值是不可变的,相当于java里用final修饰的变量
        val i = 1
        //使用var定义的变量是可变得,在Scala中鼓励使用val
        var s = "hello"
        //Scala编译器会自动推断变量的类型,必要的时候可以指定类型
        //变量名在前,类型在后
        val str: String = "itcast"
        println(i);
        println(s);
        println(str);
    
        //2循环-----------------------------------------
        for (c <- s) println(c);
    
        //3Array
        val arr = Array(1, 2, 3, 4, 5, 6, 7, 8, 9)
        for (e <- arr)
          println(e)
    
        for (i <- 1 to 10) println(i)
    
        //4高级for循环
        //每个生成器都可以带一个条件,if前面没有分号
        for (i <- 1 to 3; j <- 1 to 3 if i != j)
          println((10 * i + j) + " ")
    
        //5for推导式:如果for循环的循环体以yeild开始,则该循环会构建一个组合
        //每次迭代生成集合中的一个值
        val v = for (i <- 1 to 10) yield i * 10
        println(v)
    
        println((1 to 10).map(_ * 10))
    
        val a = Array("a", "b", "c")
        for (e <- a) println(e)
    
        for (i <- 0 to a.length) println(i)
        for (i <- 0 until a.length) println(a(i))
    
    
    
        //判断x的值,将结果赋给y
        val x = 0
        val y = if (x > 0) 1 else -1
        println(y)
    
        //支持混合类型表达式
        val z = if (x > 1) 1 else "error"
        println(z)
    
        //如果缺失else,相当于if(x>2) 1 else ()
        val m = if (x > 2) 1
        println(m)
    
    
        //操作符重载
        val numa = 2
        val numb = 3
        numa + numb
        numa.+(numb)
    
    
    
        //方法和函数
        //定义方法
        def m1(x: Int): Int = x * x
        //scala可以自动推断返回值类型,但是如果方法中存在递归,则必须指定返回值类型
        def m2(x: Int) = x * x
        println("-----------" + m1(2))
        println("-----------" + m2(2))
    
    
        def n1(y: Int, z: Int): Unit = println(y + z)
        val n2 = n1(1, 2)
        println("n2是" + n2) //n2是() scala中的()相当于java中void
    
        def n3(y: Int, z: Int) {
          println(y + z)
        }
        val n4 = n3(2, 2)
        println("n4是" + n4)
    
        //定义函数 函数可以作为参数传入方法里边
        val f = (x: Int) => x * x;
        println("-----------" + f(3))
        val f1 = (x: Int, y: Int) => x * y
        println("-----------" + f1(3, 4))
    
        val arrs = Array(1, 2, 3, 4, 5)
        arrs.map((x: Int) => x * 10)
        arrs.map((x) => x * 10)
        arrs.map(x => x * 10)
        for (e <- arrs) println(e)
        val arr1 = Array(1, 2, 3);
    
        val arr2 = arr1.map(_ * 10)
        for (e <- arr2) println(e)
    
    
        //函数作为函数的参数传给函数
        val ff1 = (x: Int) => x * x
        val arr3 = arr2.map(ff1)
    
        for (e <- arr3) println("---" + e)
      }
    }
  • 相关阅读:
    STM32 HAL库 +freeRTOS+Keil 移植
    C# OPENGL DEMO 旋转彩色立方体OpenGL, SharpGL
    常用的user32说明
    C# emgu 多模板匹配
    c#操作Excel模板,替换命名单元格或关键字形成报表
    STM32 USB 鼠标+键盘 串口控制
    USB鼠标键盘数据格式以及按键键值
    C# Emgu 类型转换
    C#来操作Word
    Linux部署H2
  • 原文地址:https://www.cnblogs.com/feifeicui/p/10908799.html
Copyright © 2011-2022 走看看