// Playground - noun: a place where people can play

import UIKit

var str = "Hello,playground"

var (a,b) = (10,29)
let (c:String,d:Int) = ("10",19)

println(a + b)

a = 1;

var array = [1,2,3,4];
println(array[2]);

var dict: [String: Int] = [
    "a": 1,"b": 2,"c": 3,"d": 4,"e": 5
];
dict["c"]

//可变类型
var dict11 = [
    "a": 1,"b": "2"
]

dict11["a"]
dict11["b"]


var intList: [Int] = []

var dict1 =
[
    "a": 0,"b": 1,"c": 2
];

dict1["a"]
//println("\(dict1["a"])");



//特殊的组合
let lang2: (String,Int,Int) = ("Swift",1);
lang2.0
lang2.1
lang2.2


//可以为特殊组合定义名称
let lang1: (name:String,age:Int) = (name:"a",age:0);
lang1.name


let length = -6

if(length > 0){
    println(1);
}else if(length > 1){
    println(2);
}else if length < 1 {
    println(-1);
}

for i in array{
    println(i)
}

//Null型??
var strValue: String?

println(strValue)

var strValueOptional: Optional<Int>

if strValue != nil {
    println(0)
}else{
    println(1)
}

var myVar = 0;

println(" (myVar) ");



println("Hello,World!")

var array1 = [1,4,5]

for i in array1{
    println(i)
}


var myVar1 = 0;

println("my var is myVar)" + String(myVar1));

println("my var is ¥(myVar)");

var my : Int = 0;

println(my);

var myVar3 : Double = 3.21123123

println(myVar3);


var movieCount = 0
var songCount = 0


println("Media library contains \(movieCount) movies and \(songCount) songs");


println("国")



//基本控制语句
var score = 50;

var scoreArray = [90,100,23,43,67];

for s in scoreArray {
    println("s is \(s)");
}

var maxscore = 0;
var minscore = 0;
var avgscore = 0.0;
var sumscore = 0.0;

var count = scoreArray.count;

for s in scoreArray{
    sumscore += Double(s);
}

println("sumscore is \(sumscore)");

for (var i = 0; i < count; i++){
    println(scoreArray[i]);
}

var index = 0;
while(index < count){
    var s = scoreArray[index];
    index++;
    println(" while is [\(s)]");
}

let type = "IOS"

//Swift不是穿透型,[fallthrough]可以设定穿透
switch type {
case "IOS":
    println("");
case "IOS1":
    println("");
    fallthrough
default:
    break;
}


///方法的使用
func testConcat(v1:String,v2:String) -> String {
    return "\(v1) and \(v2)";
}

func testConcat2(v1:String,p2 v2:String,p3 v3:String) -> String {
    return "\(v1) and \(v2) and \(v3)";
}

func getInfo() -> (String,String,String){
    return ("syu","gen","syou")
}

func testFunctionInFunction() -> Int {
    
    //基本上和JS是一致的
    var y = 10;
    
    func add(){
        y += 5;
    }
    
    add();
    
    return y;
}

func Function() -> String {
    return "OK!";
}

func addFuc(num : Int) -> Int {
    return num ;
}


func Function(v1 : Int) -> (Int -> String) {
    func addFuc(num : Int) -> String {
        var a = num + 1;
        return "result is \(a)";
    }
    return addFuc;
}


func lessthanTen(number: Int) -> Bool {
    return number < 10;
}

func hasAnyMatch(list: [Int],condition: (Int -> Bool)) -> Bool {
    for item in list {
        if condition(item) {
            return true;
        }
        continue;
    }
    
    return false;
}

func testFuction(){
    println("My First Fuc");
    
    let v = testConcat("hello","world");
    println("v is \(v)");
    
    let v2 = testConcat2("syu",p2: "gen",p3: "syou");
    println("v2 is \(v2)");
    
    let (v3,v4,v5) = getInfo();
    println("\(v4)");
    
    
    let v6 = testFunctionInFunction();
    println("\(v6)");
    
    //方法指针
    var myFunc = Function(1);
    let v7 = myFunc(1);
    println("\(v7)");
    
    var arr = [10,20,30,5];
    let v8 = hasAnyMatch(arr,lessthanTen);
    println("\(v8)");
}

testFuction();


//数据结构

var p1 = 100;
let p2 = "value is " + String(p1);
println("p2 is \(p2)");

var p3 = ["IOS","Android","winPhone","Symbian"];

p3[0] = "IOS/Swift";

for i in p3 {
    println("new i is \(i)");
}

p3.append("BlackBerray");



// 字典型的使用
var p4 : Dictionary = [
    "Name": "zyx","Age": 35,"score": "100"
]

for(key,value) in p4{
    println("key value \(key) and \(value)");
}

p4["Course"] = "100";

for(key,value) in p4{
    println("key value \(key) and \(value)");
}

let p5 = p4.keys;

for key in p5{
    println("key is \(key)");
}


//Closure 闭包= 类似于Net的拉姆达表达式 简化代码写法
var arr = [20,9,34,89,39];

func hasClosureMatch(arr: [Int],compareValue: Int,cb:(num: Int,value: Int) -> Bool) -> Bool{
    for item in arr {
        if (cb(num: item,value: compareValue)) {
            return true;
        }
        
    }
    return false;
}

var v1 = hasClosureMatch(arr,400,{
    (num: Int,value: Int) -> Bool in
    return num >= 400;
});

println("v1 is \(v1)");


var v3 = hasClosureMatch(arr,5,{
    //sh Coding经常食用方法
    return $0 < $1
});

println("v3 is \(v3)");


let v4  = hasClosureMatch(arr,{
    return $1 == 9
});

println("v4 is \(v4)");

//闭包函数特性整理
array = [20,39]

func canMatch(arr: [Int],cb: (num: Int,value: Int) -> Bool) -> Bool {
    
    for item in arr {
        if (cb(num: item,value: compareValue)) {
            return true
        }
    }
    
    return false
}

//Fn1
var compareFn1 = {
    (num: Int,value: Int) -> Bool in
    return num == value;
}

var val1 = canMatch(array,compareFn1);

println("\(val1)")

//Fn2
var val2 = canMatch(array,{ return $0 == $1 });

println("\(val2)")


//构造体
struct QFTest {
    var x = 0;
    var y = 0;
    
    //构造函数固定名称
    init(){
        NSLog("init called");
    }
    
    init(x:Int,y:Int){
        self.x = x;
        self.y = y;
        
        NSLog("init with params is called");
    }
    
    //特殊语法,如果再调用构造函数的时候想使用一般语法的参数传递「QFTest(100,200)」 ,必须自己重写下面的代码
    init(_ x: Int,_ y: Int){
        self.x = 0;
        self.y = 0;
    }
    
    //结构体没有析构函数
    
    //可以定义函数
    mutating func add(v1: Int,v2: Int){
        //结构体是一个对象的拷贝,其成员变量的值在定义的时候初始化
        //默认在构造体内是不能改变成员变量的,如果想改变需要在函数前加上mutating
        
        x += v1;
        y += v2;
    }
    
}

struct dog {
    var age = 0;
}

func testStructure() {
    
    //构造体初期化
    var s = QFTest(x:100,y:200);
    
    printlnForStructure(s);
    
    var s1 = QFtest();
    s1.x = 100;
    s1.y = 200;
    
    printlnForStructure(s1);
    
    
    var s2 = QFTest(100,200);
    printlnForStructure(s2);
    
    s2.add(300,v2:300);
    printlnForStructure(s2);
    
}

func printlnForStructure(p: QFTest){
    println("x: \(p.x) and y: \(p.y)");
}

testStructure();



//クラス
class Person {
    //Swift 变量类型
    var age :Int = 0;
    var name :String?;
    
    init() {
        self.age = 5;
        self.name = "x man";
    }
    
    init(name:String,age:Int){
        self.age = age;
        self.name = name;
    }
    
    //两种方法类型
    //1、成员方法:通过类的实例化对象调用
    func getAge() -> Int {
        return age;
    }
    
    func getName() -> String {
        //! => nil(Null)可以理解是一种装箱操作
        return name!;
    }
    
    //2、类方法、相当于静态方法
    class func  MaxAge() -> Int {
        return 200;
    }
    
    //3. 不经常使用,返回类型本身
    class func person() -> Person {
        return Person();
    }
    
    //析構函数
    deinit {
        
    }
}

var xiaoming = Person();

println("xiaoming is \(xiaoming.age)");


var maxAge = Person.MaxAge();
println("Max age is \(maxAge)");


//参数标签的区别:
//一般情况下方法的第一个参数的标签,在调用的时候是不需要明确写出来的.但是如果参数带有#符号则必须写
//构造函数的参数标签是必须写的
var xiaoli = Person(name: "王さん",age: 32);

//Setter Getter

struct  Point {
    var x = 0.0,y = 0.0;
};

struct Size {
    var width = 0.0,height = 0.0;
}

struct  Rect {
    //在定义类和构造体的时候可以想下面这行这样用一种懒加载的方式定义变量,可以使变量只有在被使用的时候才加载
    //@lazy var aysnObj = Point();
    
    var origin = Point();
    
    var size = Size();
    
    //Center相当于C#的属性成员
    var center : Point {
        get {
            let x = origin.x + (size.width / 2);
            let y = origin.y + (size.height / 2);
            return Point(x :x,y :y);
        }
        
        set(newCenter) {
            origin.x = newCenter.x - size.width/2;
            origin.y = newCenter.y - size.height/2;
            
        }
    }
    
    
    func getCenter() -> (Double,Double) {
        let x = origin.x + (size.width / 2);
        let y = origin.y + (size.height / 2);
        
        return (x,y);
    }
}

var rect = Rect(origin :Point(x:100,y:200),size :Size(width: 400,height: 50));

var (x,y) = rect.getCenter();

println("x y =(\(x),\(y) )")

var p11 :Point = rect.center;

println("x y =(\(p11.x),\(p11.y) )")

var p13 = Point(x:200,y:400);
rect.center = p13;
println("x y =(\(p13.x),\(p13.y) )")

var rect1 = Rect(origin: Point(x:200,y:500),size: Size(width: 300,height: 100));

class Human {
    
    var x = 0
    var y = 0
    var w = 0
    var h = 0
    
    init() {
        
    }
    
    init(x: Int,y: Int,w: Int,h: Int){
        self.x = x
        self.y = y
        self.w = w
        self.h = h
    }
    
    var position: (x: Int,y: Int){
        
        //返回值必须和「(x: Int,y: Int)」属性定义一致
        get {
            return (x,y)
        }
        
        //set的参数也必须和 「(x: Int,y: Int)」属性定义一致
        set(pos) {
            self.x = pos.x
            self.y = pos.y
        }
    }
    
    class func Summay() -> String {
        return "human"
    }
}

var person = Human()
person.position
person.position = (9,9)
Human.Summay()


/* 属性的各种情况 */
class HumanNew {
    
    var fristName: String = ""
    
    var milldeName: String?
    
    var lastName: String = ""
    
    //属性的参数列表带nil值的情况
    var Name: (frist: String,millde: String?,last: String) {
        
        get {
            return (fristName,milldeName,lastName)
        }
        
        set(fullName) {
            self.fristName = fullName.frist
            self.milldeName = fullName.millde
            self.lastName = fullName.last
        }
        
    }
    
    func toString() -> String {
        return lastName + " " + (milldeName ?? "XX") + fristName
    }
    
    //nil属性
    var _company = ""
    //只有一个属性的时候
    var company: (String?) {
        get {
            return _company + "株式会社"
        }
        
        set (companyName) {
            self._company = companyName!
        }
    }
}


var xiaowang = HumanNew()
xiaowang.Name = ("xiao",nil,"wang")
println(xiaowang.toString())


//Interface
//多継承可能
@objc protocol SortProtocol : NSObjectProtocol {
    
    //必须实现的方法
    func compare (value:Int) -> Bool;
    
    
    //如果有用了optional的方法,则Class的前面必须追加@objc。这个方法是可选的。可以不实现
    optional func beginCompare() -> Bool;
    
}

protocol SortProtocol1 : NSObjectProtocol {
    
    func findMaxValue (v1:Int,v2:Int) -> Bool;
    
    
}

class ClassA : NSObject,SortProtocol,SortProtocol1 {
    var age = 0;
    init(age:Int) {
        self.age = age;
    }
    
    func compare(value: Int) -> Bool {
        return true;
    }
    
    func findMaxValue(v1: Int,v2: Int) -> Bool {
        if(v1 > v2){
            return true;
        }else{
            return false;
        }
    }
    
}

let classA = ClassA(age:100);

let ret = classA.compare(200);

let result = classA.findMaxValue(200,v2: 300);

println(result);
//強制类型转换
let newClassA = classA as SortProtocol1;

println(newClassA.findMaxValue(500,v2: 300));

let newClassB = classA as SortProtocol;

//这是在调用一个没有被实现的的方法。该方法没有被实现的时候,可以返回nil
println(newClassB.beginCompare?());


//可简化的循环写法
for i in 1...11 {
    println(i)
}

func add(heigth: Int,#width: Int) -> Int {
    return heigth + width
}

add(100,width: 200)



let number = 10
switch number {
    case 2,6,7,10:
        println("2")
        //可穿透
        fallthrough
    case 10:
        println("10")
    case 1,7:
        println("3")
    default:
        println()
}





Swift基础语法汇总的更多相关文章

  1. HTML5 WebSocket实现点对点聊天的示例代码

    这篇文章主要介绍了HTML5 WebSocket实现点对点聊天的示例代码的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  2. ios – 在Swift的UIView中找到UILabel

    我正在尝试在我的UIViewControllers的超级视图中找到我的UILabels.这是我的代码:这是在Objective-C中推荐的方式,但是在Swift中我只得到UIViews和CALayer.我肯定在提供给这个方法的视图中有UILabel.我错过了什么?我的UIViewController中的调用:解决方法使用函数式编程概念可以更轻松地实现这一目标.

  3. ios – 声明NSDictionary并在Swift中添加键值对?

    我一直在尝试使用类类型键和值来声明一个NSDictionary,如下所示:这里,“Category”和“SubCategory”是全局类.我知道我不能将类类型用于关键字段.但是,无论如何,我应该做到这一点.有没有办法做到这一点?如何声明专门的NSDictionary或类似的东西来做到这一点?

  4. ios – 在Swift中将输入字段字符串转换为Int

    所以我非常擅长制作APP广告Swift,我试图在文本字段中做一些非常简单的输入,取值,然后将它们用作Int进行某些计算.但是’vardistance’有些东西不正确它是导致错误的最后一行代码.它说致命错误:无法解开Optional.None解决方法在你的例子中,距离是一个Int?否则称为可选的Int..toInt()返回Int?因为从String到Int的转换可能失败.请参阅以下示例:

  5. ios – Swift相当于`[NSDictionary initWithObjects:forKeys:]`

    Swift的原生字典是否与[NSDictionaryinitWithObjects:forKeys:]相当?假设我有两个带键和值的数组,并希望将它们放在字典中.在Objective-C中,我这样做:当然我可以通过两个数组迭代一个计数器,使用vardict:[String:Int]并逐步添加东西.但这似乎不是一个好的解决方案.使用zip和enumerate可能是同时迭代两者的更好方法.然而,这种方法

  6. 如何在iOS中检测文本(字符串)语言?

    例如,给定以下字符串:我想检测每个声明的字符串中使用的语言.让我们假设已实现函数的签名是:如果没有检测到语言,则返回可选字符串.因此,适当的结果将是:有一个简单的方法来实现它吗?

  7. xamarin – 崩溃在AccountStore.Create().保存(e.Account,“);

    在Xamarin.Forms示例TodoAwsAuth中https://developer.xamarin.com/guides/xamarin-forms/web-services/authentication/oauth/成功登录后,在aOnAuthenticationCompleted事件中,应用程序在尝试保存到Xamarin.Auth时崩溃错误说不能对钥匙串说期待着寻求帮助.解决方法看看你

  8. ios – 将视频分享到Facebook

    我正在编写一个简单的测试应用程序,用于将视频从iOS上传到Facebook.由于FacebookSDK的所有文档都在Objective-C中,因此我发现很难在线找到有关如何使用Swift执行此操作的示例/教程.到目前为止我有这个在我的UI上放置一个共享按钮,但它看起来已禁用,从我读到的这是因为没有内容设置,但我看不出这是怎么可能的.我的getVideoURL()函数返回一个NSURL,它肯定包含视

  9. xcode – 错误“线程1:断点2.1”

    我正在研究RESTAPI管理器.这是一个错误,我无法解决它.我得到的错误在下面突出显示.当我打电话给这个班级获取资源时:我评论的线打印:Thread1:breakpoint2.1我需要修复错误的建议.任何建议都非常感谢解决方法您可能在不注意的情况下意外设置了断点.单击并拖动代表断路器外部断点的蓝色刻度线以将其擦除.

  10. ios – 更改导航栏标题swift中的字符间距

    类型的值有人可以帮我这个或建议一种不同的方式来改变swift中导航栏标题中的字符间距吗?解决方法您无法直接设置属性字符串.你可以通过替换titleView来做一个技巧

随机推荐

  1. Swift UITextField,UITextView,UISegmentedControl,UISwitch

    下面我们通过一个demo来简单的实现下这些控件的功能.首先,我们拖将这几个控件拖到storyboard,并关联上相应的属性和动作.如图:关联上属性和动作后,看看实现的代码:

  2. swift UISlider,UIStepper

    我们用两个label来显示slider和stepper的值.再用张图片来显示改变stepper值的效果.首先,这三个控件需要全局变量声明如下然后,我们对所有的控件做个简单的布局:最后,当slider的值改变时,我们用一个label来显示值的变化,同样,用另一个label来显示stepper值的变化,并改变图片的大小:实现效果如下:

  3. preferredFontForTextStyle字体设置之更改

    即:

  4. Swift没有异常处理,遇到功能性错误怎么办?

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  5. 字典实战和UIKit初探

    ios中数组和字典的应用Applicationschedule类别子项类别名称优先级数据包contactsentertainment接触UIKit学习用Swift调用CocoaTouchimportUIKitletcolors=[]varbackView=UIView(frame:CGRectMake(0.0,0.0,320.0,CGFloat(colors.count*50)))backView

  6. swift语言IOS8开发战记21 Core Data2

    上一话中我们简单地介绍了一些coredata的基本知识,这一话我们通过编程来实现coredata的使用。还记得我们在coredata中定义的那个Model么,上面这段代码会加载这个Model。定义完方法之后,我们对coredata的准备都已经完成了。最后强调一点,coredata并不是数据库,它只是一个框架,协助我们进行数据库操作,它并不关心我们把数据存到哪里。

  7. swift语言IOS8开发战记22 Core Data3

    上一话我们定义了与coredata有关的变量和方法,做足了准备工作,这一话我们来试试能不能成功。首先打开上一话中生成的Info类,在其中引用头文件的地方添加一个@objc,不然后面会报错,我也不知道为什么。

  8. swift实战小程序1天气预报

    在有一定swift基础的情况下,让我们来做一些小程序练练手,今天来试试做一个简单地天气预报。然后在btnpressed方法中依旧增加loadWeather方法.在loadWeather方法中加上信息的显示语句:运行一下看看效果,如图:虽然显示出来了,但是我们的text是可编辑状态的,在storyboard中勾选Editable,再次运行:大功告成,而且现在每次单击按钮,就会重新请求天气情况,大家也来试试吧。

  9. 【iOS学习01】swift ? and !  的学习

    如果不初始化就会报错。

  10. swift语言IOS8开发战记23 Core Data4

    接着我们需要把我们的Rest类变成一个被coredata管理的类,点开Rest类,作如下修改:关键字@NSManaged的作用是与实体中对应的属性通信,BinaryData对应的类型是NSData,CoreData没有布尔属性,只能用0和1来区分。进行如下操作,输入类名:建立好之后因为我们之前写的代码有些地方并不适用于coredata,所以编译器会报错,现在来一一解决。

返回
顶部