亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Swift > 正文

蘋果公司推出的新編程語言Swift簡(jiǎn)介和入門教程

2020-03-09 17:52:32
字體:
供稿:網(wǎng)友
這篇文章主要介紹了蘋果公司推出的新編程語言Swift簡(jiǎn)介和入門教程,Swift是蘋果于WWDC 2014.6.3發(fā)布的編程語言,主要用來替代Objective-C,需要的朋友可以參考下
 

一、Swift是什么?

Swift是蘋果于WWDC 2014發(fā)布的編程語言,這里引用The Swift Programming Language的原話:

復(fù)制代碼代碼如下:

Swift is a new programming language for iOS and OS X apps that builds on the best of C and Objective-C, without the constraints of C compatibility.
Swift adopts safe programming patterns and adds modern features to make programming easier, more flexible and more fun.
Swift's clean slate, backed by the mature and much-loved Cocoa and Cocoa Touch frameworks, is an opportunity to imagine how software development works.
Swift is the first industrial-quality systems programming language that is as expressive and enjoyable as a scripting language.

 

簡(jiǎn)單的說:
Swift用來寫iOS和OS X程序。(估計(jì)也不會(huì)支持其它屌絲系統(tǒng))
Swift吸取了C和Objective-C的優(yōu)點(diǎn),且更加強(qiáng)大易用。
Swift可以使用現(xiàn)有的Cocoa和Cocoa Touch框架。
Swift兼具編譯語言的高性能(Performance)和腳本語言的交互性(Interactive)。

二、Swift語言概覽

1.基本概念

注:這一節(jié)的代碼源自The Swift Programming Language中的A Swift Tour。

1.1.Hello, world

類似于腳本語言,下面的代碼即是一個(gè)完整的Swift程序。

復(fù)制代碼代碼如下:

println("Hello, world")

 

1.2.變量與常量

Swift使用var聲明變量,let聲明常量。

 

復(fù)制代碼代碼如下:

ar myVariable = 42
myVariable = 50
let myConstant = 42

 

1.3.類型推導(dǎo)

Swift支持類型推導(dǎo)(Type Inference),所以上面的代碼不需指定類型,如果需要指定類型:

 

復(fù)制代碼代碼如下:
let explicitDouble : Double = 70

 

Swift不支持隱式類型轉(zhuǎn)換(Implicitly casting),所以下面的代碼需要顯式類型轉(zhuǎn)換(Explicitly casting):

 

復(fù)制代碼代碼如下:

let label = "The width is "
let width = 94
let width = label + String(width)

 


1.4.字符串格式化

Swift使用(item)的形式進(jìn)行字符串格式化:

復(fù)制代碼代碼如下:

let apples = 3
let oranges = 5
let appleSummary = "I have (apples) apples."
let appleSummary = "I have (apples + oranges) pieces of fruit."

 


1.5.數(shù)組和字典

Swift使用[]操作符聲明數(shù)組(array)和字典(dictionary):

復(fù)制代碼代碼如下:

var shoppingList = ["catfish", "water", "tulips", "blue paint"]
shoppingList[1] = "bottle of water"
var occupations = [
    "Malcolm": "Captain",
    "Kaylee": "Mechanic",
]
occupations["Jayne"] = "Public Relations"

 

一般使用初始化器(initializer)語法創(chuàng)建空數(shù)組和空字典:

復(fù)制代碼代碼如下:

let emptyArray = String[]()
let emptyDictionary = Dictionary<String, Float>()

 

如果類型信息已知,則可以使用[]聲明空數(shù)組,使用[:]聲明空字典。

2.控制流

2.1概覽

Swift的條件語句包含if和switch,循環(huán)語句包含for-in、for、while和do-while,循環(huán)/判斷條件不需要括號(hào),但循環(huán)/判斷體(body)必需括號(hào):

 

復(fù)制代碼代碼如下:

let individualScores = [75, 43, 103, 87, 12]
var teamScore = 0
for score in individualScores {
    if score > 50 {
        teamScore += 3
    } else {
        teamScore += 1
    }
}

 

2.2可空類型

結(jié)合if和let,可以方便的處理可空變量(nullable variable)。對(duì)于空值,需要在類型聲明后添加?顯式標(biāo)明該類型可空。

復(fù)制代碼代碼如下:

var optionalString: String? = "Hello"
optionalString == nil
var optionalName: String? = "John Appleseed"
var gretting = "Hello!"
if let name = optionalName {
    gretting = "Hello, (name)"
}

 

2.3靈活的switch

Swift中的switch支持各種各樣的比較操作:

復(fù)制代碼代碼如下:

let vegetable = "red pepper"
switch vegetable {
case "celery":
    let vegetableComment = "Add some raisins and make ants on a log."
case "cucumber", "watercress":
    let vegetableComment = "That would make a good tea sandwich."
case let x where x.hasSuffix("pepper"):
    let vegetableComment = "Is it a spicy (x)?"
default:
    let vegetableComment = "Everything tastes good in soup."
}

 

2.4其它循環(huán)

for-in除了遍歷數(shù)組也可以用來遍歷字典:

 

復(fù)制代碼代碼如下:

let interestingNumbers = [
    "Prime": [2, 3, 5, 7, 11, 13],
    "Fibonacci": [1, 1, 2, 3, 5, 8],
    "Square": [1, 4, 9, 16, 25],
]
var largest = 0
for (kind, numbers) in interestingNumbers {
    for number in numbers {
        if number > largest {
            largest = number
        }
    }
}
largest

 

while循環(huán)和do-while循環(huán):
 

復(fù)制代碼代碼如下:

var n = 2
while n < 100 {
    n = n * 2
}

var m = 2
do {
    m = m * 2
} while m < 100
m

 

Swift支持傳統(tǒng)的for循環(huán),此外也可以通過結(jié)合..(生成一個(gè)區(qū)間)和for-in實(shí)現(xiàn)同樣的邏輯。

復(fù)制代碼代碼如下:

var firstForLoop = 0
for i in 0..3 {
    firstForLoop += i
}
firstForLoop
var secondForLoop = 0
for var i = 0; i < 3; ++i {
    secondForLoop += 1
}
secondForLoop

 

注意:Swift除了..還有…:..生成前閉后開的區(qū)間,而…生成前閉后閉的區(qū)間。

3.函數(shù)和閉包

3.1函數(shù)

Swift使用func關(guān)鍵字聲明函數(shù):

復(fù)制代碼代碼如下:

func greet(name: String, day: String) -> String {

 

    return "Hello (name), today is (day)."

}
greet("Bob", "Tuesday")

 

通過元組(Tuple)返回多個(gè)值:

復(fù)制代碼代碼如下:

func getGasPrices() -> (Double, Double, Double) {
    return (3.59, 3.69, 3.79)
}
getGasPrices()

 

支持帶有變長(zhǎng)參數(shù)的函數(shù):

復(fù)制代碼代碼如下:

func sumOf(numbers: Int...) -> Int {
    var sum = 0
    for number in numbers {
        sum += number
    }
    return sum
}
sumOf()
sumOf(42, 597, 12)

 

函數(shù)也可以嵌套函數(shù):

復(fù)制代碼代碼如下:

func returnFifteen() -> Int {
    var y = 10
    func add() {
        y += 5
    }
    add()
    return y
}
returnFifteen()

 

作為頭等對(duì)象,函數(shù)既可以作為返回值,也可以作為參數(shù)傳遞:

復(fù)制代碼代碼如下:

func makeIncrementer() -> (Int -> Int) {
    func addOne(number: Int) -> Int {
        return 1 + number
    }
    return addOne
}

 

var increment = makeIncrementer()
increment(7)

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

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

var numbers = [20, 19, 7, 12]
hasAnyMatches(numbers, lessThanTen)

 

3.2閉包

本質(zhì)來說,函數(shù)是特殊的閉包,Swift中可以利用{}聲明匿名閉包:

復(fù)制代碼代碼如下:

numbers.map({
    (number: Int) -> Int in
    let result = 3 * number
    return result
    })

 

當(dāng)閉包的類型已知時(shí),可以使用下面的簡(jiǎn)化寫法:

復(fù)制代碼代碼如下:

numbers.map({ number in 3 * number })

 

此外還可以通過參數(shù)的位置來使用參數(shù),當(dāng)函數(shù)最后一個(gè)參數(shù)是閉包時(shí),可以使用下面的語法:

復(fù)制代碼代碼如下:
sort([1, 5, 3, 12, 2]) { $0 > $1 }

 

4.類和對(duì)象

4.1創(chuàng)建和使用類

Swift使用class創(chuàng)建一個(gè)類,類可以包含字段和方法:

復(fù)制代碼代碼如下:

class Shape {
    var numberOfSides = 0
    func simpleDescription() -> String {
        return "A shape with (numberOfSides) sides."
    }
}


創(chuàng)建Shape類的實(shí)例,并調(diào)用其字段和方法。

復(fù)制代碼代碼如下:

var shape = Shape()
shape.numberOfSides = 7
var shapeDescription = shape.simpleDescription()

 

通過init構(gòu)建對(duì)象,既可以使用self顯式引用成員字段(name),也可以隱式引用(numberOfSides)。

復(fù)制代碼代碼如下:

class NamedShape {
    var numberOfSides: Int = 0
    var name: String
    init(name: String) {
        self.name = name
    }
    func simpleDescription() -> String {
        return "A shape with (numberOfSides) sides."
    }
}

 


使用deinit進(jìn)行清理工作。

4.2繼承和多態(tài)

Swift支持繼承和多態(tài)(override父類方法):

復(fù)制代碼代碼如下:

class Square: NamedShape {
    var sideLength: Double
    init(sideLength: Double, name: String) {
        self.sideLength = sideLength
        super.init(name: name)
        numberOfSides = 4
    }
    func area() -> Double {
        return sideLength * sideLength
    }
    override func simpleDescription() -> String {
        return "A square with sides of length (sideLength)."
    }
}
let test = Square(sideLength: 5.2, name: "my test square")
test.area()
test.simpleDescription()

 

注意:如果這里的simpleDescription方法沒有被標(biāo)識(shí)為override,則會(huì)引發(fā)編譯錯(cuò)誤。

4.3屬性

為了簡(jiǎn)化代碼,Swift引入了屬性(property),見下面的perimeter字段:

復(fù)制代碼代碼如下:

class EquilateralTriangle: NamedShape {
    var sideLength: Double = 0.0
    init(sideLength: Double, name: String) {
        self.sideLength = sideLength
        super.init(name: name)
        numberOfSides = 3
    }
    var perimeter: Double {
    get {
        return 3.0 * sideLength
    }
    set {
        sideLength = newValue / 3.0
    }
    }
    override func simpleDescription() -> String {
        return "An equilateral triagle with sides of length (sideLength)."
    }
}
var triangle = EquilateralTriangle(sideLength: 3.1, name: "a triangle")
triangle.perimeter
triangle.perimeter = 9.9
triangle.sideLength

 


注意:賦值器(setter)中,接收的值被自動(dòng)命名為newValue。

4.4willSet和didSet

EquilateralTriangle的構(gòu)造器進(jìn)行了如下操作:
1.為子類型的屬性賦值。
2.調(diào)用父類型的構(gòu)造器。
3.修改父類型的屬性。
如果不需要計(jì)算屬性的值,但需要在賦值前后進(jìn)行一些操作的話,使用willSet和didSet:

復(fù)制代碼代碼如下:

class TriangleAndSquare {
    var triangle: EquilateralTriangle {
    willSet {
        square.sideLength = newValue.sideLength
    }
    }
    var square: Square {
    willSet {
        triangle.sideLength = newValue.sideLength
    }
    }
    init(size: Double, name: String) {
        square = Square(sideLength: size, name: name)
        triangle = EquilateralTriangle(sideLength: size, name: name)
    }
}
var triangleAndSquare = TriangleAndSquare(size: 10, name: "another test shape")
triangleAndSquare.square.sideLength
triangleAndSquare.square = Square(sideLength: 50, name: "larger square")
triangleAndSquare.triangle.sideLength

 

從而保證triangle和square擁有相等的sideLength。

4.6調(diào)用方法

Swift中,函數(shù)的參數(shù)名稱只能在函數(shù)內(nèi)部使用,但方法的參數(shù)名稱除了在內(nèi)部使用外還可以在外部使用(第一個(gè)參數(shù)除外),例如:

復(fù)制代碼代碼如下:

class Counter {
    var count: Int = 0
    func incrementBy(amount: Int, numberOfTimes times: Int) {
        count += amount * times
    }
}
var counter = Counter()
counter.incrementBy(2, numberOfTimes: 7)

 

注意Swift支持為方法參數(shù)取別名:在上面的代碼里,numberOfTimes面向外部,times面向內(nèi)部。

4.7 ?的另一種用途

使用可空值時(shí),?可以出現(xiàn)在方法、屬性或下標(biāo)前面。如果?前的值為nil,那么?后面的表達(dá)式會(huì)被忽略,而原表達(dá)式直接返回nil,例如:

 

復(fù)制代碼代碼如下:
let optionalSquare: Square? = Square(sideLength: 2.5, name: "optionalsquare")
let sideLength = optionalSquare?.sideLength

 

當(dāng)optionalSquare為nil時(shí),sideLength屬性調(diào)用會(huì)被忽略。

5.枚舉和結(jié)構(gòu)

5.1枚舉

使用enum創(chuàng)建枚舉——注意Swift的枚舉可以關(guān)聯(lián)方法:

enum Rank: Int {

    case Ace = 1

    case Two, Three, Four, Five, Six, Seven, Eight, Nine, Ten

    case Jack, Queen, King

        func simpleDescription() -> String {

        switch self {

            case .Ace:

                return "ace"

            case .Jack:

                return "jack"

            case .Queen:

                return "queen"

            case .King:

                return "king"

        }
    }
}
let ace = Rank.Ace
let aceRawValue = ace.toRaw()

使用toRaw和fromRaw在原始(raw)數(shù)值和枚舉值之間進(jìn)行轉(zhuǎn)換:

復(fù)制代碼代碼如下:

if let convertedRank = Rank.fromRaw(3) {
    let threeDescription = convertedRank.simpleDescription()
}

 

注意枚舉中的成員值(member value)是實(shí)際的值(actual value),和原始值(raw value)沒有必然關(guān)聯(lián)。

一些情況下枚舉不存在有意義的原始值,這時(shí)可以直接忽略原始值:

復(fù)制代碼代碼如下:

enum Suit {
    case Spades, Hearts, Diamonds, Clubs
        func simpleDescription() -> String {
        switch self {
            case .Spades:
                return "spades"
            case .Hearts:
                return "hearts"
            case .Diamonds:
                return "diamonds"
            case .Clubs:
                return "clubs"
        }
    }
}
let hearts = Suit.Hearts
let heartsDescription = hearts.simpleDescription()

除了可以關(guān)聯(lián)方法,枚舉還支持在其成員上關(guān)聯(lián)值,同一枚舉的不同成員可以有不同的關(guān)聯(lián)的值:
復(fù)制代碼代碼如下:

enum ServerResponse {
    case Result(String, String)
    case Error(String)
}
let success = ServerResponse.Result("6:00 am", "8:09 pm")
let failure = ServerResponse.Error("Out of cheese.")
switch success {
    case let .Result(sunrise, sunset):
        let serverResponse = "Sunrise is at /(sunrise) and sunset is at /(sunset)."
    case let .Error(error):
        let serverResponse = "Failure... /(error)"
}

 

5.2結(jié)構(gòu)

Swift使用struct關(guān)鍵字創(chuàng)建結(jié)構(gòu)。結(jié)構(gòu)支持構(gòu)造器和方法這些類的特性。結(jié)構(gòu)和類的最大區(qū)別在于:結(jié)構(gòu)的實(shí)例按值傳遞(passed by value),而類的實(shí)例按引用傳遞(passed by reference)。

復(fù)制代碼代碼如下:

struct Card {
    var rank: Rank
    var suit: Suit
    func simpleDescription() -> String {
        return "The /(rank.simpleDescription()) of /(suit.simpleDescription())"
    }
}
let threeOfSpades = Card(rank: .Three, suit: .Spades)
let threeOfSpadesDescription = threeOfSpades.simpleDescription()

 

5.3協(xié)議(protocol)和擴(kuò)展(extension) 協(xié)議

Swift使用protocol定義協(xié)議:

復(fù)制代碼代碼如下:

protocol ExampleProtocol {
    var simpleDescription: String { get }
    mutating func adjust()
}

類型、枚舉和結(jié)構(gòu)都可以實(shí)現(xiàn)(adopt)協(xié)議:
復(fù)制代碼代碼如下:

class SimpleClass: ExampleProtocol {
    var simpleDescription: String = "A very simple class."
    var anotherProperty: Int = 69105
    func adjust() {
        simpleDescription += " Now 100% adjusted."
    }
}
var a = SimpleClass()
a.adjust()
let aDescription = a.simpleDescription
struct SimpleStructure: ExampleProtocol {
    var simpleDescription: String = "A simple structure"
    mutating func adjust() {
        simpleDescription += " (adjusted)"
    }
}
var b = SimpleStructure()
b.adjust()
let bDescription = b.simpleDescription


5.4擴(kuò)展

 

擴(kuò)展用于在已有的類型上增加新的功能(比如新的方法或?qū)傩裕?,Swift使用extension聲明擴(kuò)展:

復(fù)制代碼代碼如下:

extension Int: ExampleProtocol {
    var simpleDescription: String {
        return "The number /(self)"
    }
    mutating func adjust() {
        self += 42
    }
}
7.simpleDescription

 

5.5泛型(generics)

Swift使用<>來聲明泛型函數(shù)或泛型類型:

復(fù)制代碼代碼如下:

func repeat<ItemType>(item: ItemType, times: Int) -> ItemType[] {
    var result = ItemType[]()
    for i in 0..times {
        result += item
    }
    return result
}
repeat("knock", 4)

 

Swift也支持在類、枚舉和結(jié)構(gòu)中使用泛型:

復(fù)制代碼代碼如下:

// Reimplement the Swift standard library's optional type
enum OptionalValue<T> {
    case None
    case Some(T)
}
var possibleInteger: OptionalValue<Int> = .None
possibleInteger = .Some(100)


有時(shí)需要對(duì)泛型做一些需求(requirements),比如需求某個(gè)泛型類型實(shí)現(xiàn)某個(gè)接口或繼承自某個(gè)特定類型、兩個(gè)泛型類型屬于同一個(gè)類型等等,Swift通過where描述這些需求:
復(fù)制代碼代碼如下:

func anyCommonElements <T, U where T: Sequence,
U: Sequence, T.GeneratorType.Element: Equatable,
T.GeneratorType.Element == U.GeneratorType.Element> (lhs: T, rhs: U) -> Bool {
    for lhsItem in lhs {
        for rhsItem in rhs {
            if lhsItem == rhsItem {
                return true
            }
        }
    }
    return false
}
anyCommonElements([1, 2, 3], [3])

 

Swift語言概覽就到這里,有興趣的朋友請(qǐng)進(jìn)一步閱讀The Swift Programming Language。

接下來聊聊個(gè)人對(duì)Swift的一些感受。

個(gè)人感受

注意:下面的感受純屬個(gè)人意見,僅供參考。

大雜燴

盡管我接觸Swift不足兩小時(shí),但很容易看出Swift吸收了大量其它編程語言中的元素,這些元素包括但不限于:

屬性(Property)、可空值(Nullable type)語法和泛型(Generic Type)語法源自C#。 格式風(fēng)格與Go相仿(沒有句末的分號(hào),判斷條件不需要括號(hào))。 Python風(fēng)格的當(dāng)前實(shí)例引用語法(使用self)和列表字典聲明語法。 Haskell風(fēng)格的區(qū)間聲明語法(比如1..3,1...3)。 協(xié)議和擴(kuò)展源自O(shè)bjective-C(自家產(chǎn)品隨便用)。 枚舉類型很像Java(可以擁有成員或方法)。 class和struct的概念和C#極其相似。

注意這里不是說Swift是抄襲——實(shí)際上編程語言能玩的花樣基本就這些,況且Swift選的都是在我看來相當(dāng)不錯(cuò)的特性。

而且,這個(gè)大雜燴有一個(gè)好處——就是任何其它編程語言的開發(fā)者都不會(huì)覺得Swift很陌生——這一點(diǎn)很重要。

拒絕隱式(Refuse implicity)

Swift去除了一些隱式操作,比如隱式類型轉(zhuǎn)換和隱式方法重載這兩個(gè)坑,干的漂亮。

Swift的應(yīng)用方向

我認(rèn)為Swift主要有下面這兩個(gè)應(yīng)用方向:

1.教育

我指的是編程教育?,F(xiàn)有編程語言最大的問題就是交互性奇差,從而導(dǎo)致學(xué)習(xí)曲線陡峭。相信Swift及其交互性極強(qiáng)的編程環(huán)境能夠打破這個(gè)局面,讓更多的人——尤其是青少年,學(xué)會(huì)編程。

這里有必要再次提到Brec Victor的Inventing on Principle,看了這個(gè)視頻你就會(huì)明白一個(gè)交互性強(qiáng)的編程環(huán)境能夠帶來什么。

2.應(yīng)用開發(fā)

現(xiàn)有的iOS和OS X應(yīng)用開發(fā)均使用Objective-C,而Objective-C是一門及其繁瑣(verbose)且學(xué)習(xí)曲線比較陡峭的語言,如果Swift能夠提供一個(gè)同現(xiàn)有Obj-C框架的簡(jiǎn)易互操作接口,我相信會(huì)有大量的程序員轉(zhuǎn)投Swift;與此同時(shí),Swift簡(jiǎn)易的語法也會(huì)帶來相當(dāng)數(shù)量的其它平臺(tái)開發(fā)者。

總之,上一次某家大公司大張旗鼓的推出一門編程語言及其編程平臺(tái)還是在2000年(微軟推出C#),將近15年之后,蘋果推出Swift——作為開發(fā)者,我很高興能夠見證一門編程語言的誕生



注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到swift教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
免费看欧美黑人毛片| 国产成人自拍高清视频在线免费播放| 中文字幕日韩一级| 亚洲精品播放| 在线观看成人一级片| 717影院理论午夜伦不卡久久| 精品日本一区二区三区| 巨大黑人极品videos精品| 午夜一区二区三视频在线观看| 欧美一区二区性放荡片| 女人被狂躁到高潮视频免费网站| 精品一二线国产| 欧美污视频网站| 国产午夜在线观看| 一本色道久久综合狠狠躁篇的优点| 欧美韩日亚洲| 一区二区的视频| 国产精品久久..4399| 欧美一区深夜视频| 亚洲第一成人在线视频| 波多野结衣在线电影| 欧美三级午夜理伦三级在线观看| 大吊一区二区三区| 国内不卡的一区二区三区中文字幕| 欧美一卡在线观看| 成人香蕉视频| 欧美一区二区视频| 可以免费观看的毛片| 黄色免费网站观看| 国产女人爽到高潮a毛片| 久久久av亚洲男天堂| 精品毛片在线观看| 成人中心免费视频| 91国模少妇一区二区三区| 久久99免费视频| 欧美一级日韩免费不卡| 国产高清在线一区二区| 岛国av一区二区三区| 国产清纯美女被跳蛋高潮一区二区久久w| 成人资源在线| 成年人网站在线| 亚洲av成人精品一区二区三区| 天天干天天摸天天操| 91成人免费在线观看| 亚洲欧美日本国产专区一区| 欧美hd在线| 精品国产_亚洲人成在线| 国语自产精品视频在免费| 极品裸体白嫩激情啪啪国产精品| 久久久99精品免费观看不卡| 日韩久久久久久久久久| 新版的欧美在线视频| 亚洲第一香蕉视频| 成人午夜视频免费观看| 国产亚洲精品拍拍拍拍拍| 日本不卡高字幕在线2019| 亚洲v日韩v欧美v综合| 精品一区二区成人免费视频| 国产无遮挡猛进猛出免费软件| 三级小说欧洲区亚洲区| 嫩草视频在线观看| av在线亚洲色图| 欧美激情a在线| 久久久久亚洲av无码专区| 深夜福利网站在线观看| 国产精品被窝福利一区| 美女羞羞视频在线观看| 男人天堂中文字幕| 国产精品久久久久久久久久久久久久久| 色婷婷久久综合中文久久蜜桃av| 草草草视频在线观看| 91高清在线视频| 91成人高清| 久久久伊人欧美| 色图欧美色图| 亚洲1区在线观看| 精品蜜桃传媒| 日韩欧美123区| 黄毛片在线观看| 久久久神马电影| 亚洲国产精品久久久久婷婷老年| 国产中文字幕第一页| 综合国产在线观看| 国产一区二区三区自拍| 国产青草视频在线观看视频| 99视频有精品| 国产丝袜在线播放| 日韩理论电影大全| 日韩成人av网站| 成人性爱视频在线观看| 亚洲欧美一区二区久久| 91精品电影| 蜜桃视频在线网站| 91美女片黄在线观看游戏| 国产一区二区三区视频在线| 天天射综合网站| 97人妻天天摸天天爽天天| 黄色激情视频在线观看| 中文字幕一区二区三区精华液| 国产精品视频观看| www.久久久久久久久久| 青青草国产精品一区二区| 国产国语老龄妇女a片| av国产在线观看| 亚洲国产精品国自产拍av| 亚洲三区在线播放| 欧美亚洲日本在线| 亚洲一区二区三区乱码aⅴ蜜桃女| 老汉色影院首页| 成本人h片动漫网站在线观看| 伊人成色综合网| 欧美日韩另类视频| 污污网站免费看| 欧美激情第四页| 精品一区二区三区视频| 91极品尤物在线播放国产| 99视频免费观看蜜桃视频| 日韩一区二区视频| 欧美日韩专区| 午夜小视频在线| 日本黄色精品| av日韩在线免费| 国产成人精品一区二区三区网站观看| 国产精选一区二区三区| 91国偷自产一区二区开放时间| 亚洲中文字幕一区二区| 中文字幕第一页在线播放| 疯狂试爱三2浴室激情视频| 久久精品日产第一区二区三区精品版| 国产精品一区免费在线观看| 成人激情电影在线| 欧美理论在线播放| 先锋成人影音| 老牛影视一区二区三区| 精品一区电影| 国产91|九色| 黄色污污在线观看| 热久久精品国产| 不卡在线一区| 盗摄女厕thunder| 亚洲 欧美 激情 另类| 日韩三级中文字幕| 久久婷婷国产91天堂综合精品| 视频这里只有精品| 在线观看亚洲国产| 欧美成人中文| 国产私人尤物无码不卡| 97久久视频| 日韩av网站在线播放| 丝袜脚交一区二区| 伊人久久99| 久久影视三级福利片| 亚洲天堂小视频| 国产精品丝袜久久久久久消防器材| 亚洲成人天堂| a天堂在线观看视频| 国内一级毛片| 精品一区二区三区五区六区| 一区二区三区在线播放视频| 亚洲成人国产精品| 国产激情999| 午夜视频福利在线观看| 国产日韩欧美精品综合| 欧美视频日韩视频在线观看| 日韩美女毛片| 亚欧日韩另类中文欧美| 亚洲一区二区三区四区五区午夜| 亚洲欧美日韩激情| 欧美精品videosbestsex另类| 伊人成综合网站| 99热这里只有精品免费| 明星乱亚洲合成图.com| 国产成人精品久久久| 久久亚洲精品国产亚洲老地址| 亚洲一区二区福利| 99精品视频播放| 精品九九久久| 日日摸夜夜添夜夜添精品视频| 亚洲欧美另类人妖| 国产综合久久久久| 欧美一级大片| 亚洲第一国产精品| 日本夜爽爽一二区| 亚洲国产精品悠悠久久琪琪| 日日橹狠狠爱欧美超碰| 日韩写真福利视频在线| 日本一二三区在线观看| 国内精品2019| 久久亚洲精华国产精华液| 国产真人真事毛片视频| 一本大道一区二区三区| 天堂8在线视频| 国内av一区二区三区| 亚洲欧美视频在线观看| 日韩一级淫片| 欧美日韩一区二区三区视频播放| 欧美在线中文字幕高清的| 婷婷婷国产在线视频| www.中文字幕在线观看| 91香蕉视频网| 亚洲 欧美 视频| 色偷偷777| 97在线观视频免费观看| 成av人片在线观看www| 精品国产一区二区三区噜噜噜| 亚洲日本成人女熟在线观看| 亚洲国产精品一区二区第四页av| 一级片久久久久| 精品国产美女a久久9999| 精品国产一区二区三区久久久蜜臀| 亚州精品天堂中文字幕| 中文成人无字幕乱码精品区| 亚洲免费在线观看视频| 97在线观视频免费观看| 伊人网在线免费观看| 日本一区二区三区视频视频| 一区高清视频| 国产欧美日韩第一页| 粉嫩av一区二区夜夜嗨| 亚洲大片在线观看| 国产91在线|亚洲| 欧美a级免费视频| 国产精品私拍pans大尺度在线| 日本中文字幕视频在线| 久久av在线| 青青草97国产精品免费观看| 日韩毛片在线免费看| 国产精品sm调教免费专区| 国产一区在线观看免费| 亚洲AV无码久久精品国产一区| 亚洲清纯自拍| 最新在线你懂的| 国产精品高潮在线| 激情小说图片视频| 亚洲一区999| 日韩国产欧美亚洲| 伊人久久大香线蕉无限次| 视频一区国产| 久久久精品免费观看| 欧美亚洲国产激情| 亚洲视频一区二区三区| 成人免费aaa| 亚欧黄色av| 日本伦理一区二区三区| 特级特黄刘亦菲aaa级| 日韩精品在线影院| 日本大胆在线观看| 亚洲欧美国产视频| 亚洲少妇中出一区| 91国产精品电影| 精品人伦一区二区三区蜜桃免费| 日本免费观看网站| 日本一区影院| 天堂中文字幕在线| 国产精品乱人伦| 在线观看国产福利视频| 国产精品一国产精品最新章节| 精品国产人妻一区二区三区| 久久99精品久久久久久国产越南| 欧美亚洲视频在线看网址| 亚洲男人的天堂在线视频| 影音先锋男人资源在线观看| 一区二区国产精品视频| 久久久久久久久久综合| 秋霞电影网一区二区| 久热免费在线视频| 午夜在线电影亚洲一区| 色播久久人人爽人人爽人人片视av| 岛国片免费看| 欧美日韩国产一区精品一区| 亚洲自拍偷拍精品| 激情五月***国产精品| 日韩一本大道| 日本精品一区二区三区四区的功能| 黄色片网站免费| 日韩女同强女同hd| 成人免费三级在线| 亚洲欧美综合一区| 狠狠躁夜夜躁av无码中文幕| 亚洲高清视频中文字幕| 免费看日批视频| 男人添女人下部高潮视频在线观看| 国产91在线播放精品91| 大胆人体一区二区| 日本精品在线播放| 99国产精品久久久久99打野战| 日本精品久久久久中文字幕| 粉嫩13p一区二区三区| 丰满人妻一区二区三区免费| 欧美专区在线视频| 国产精品乱码人人做人人爱| a级片免费在线观看| 中文高清一区| 色婷婷av一区二区三区久久| 国产一区日韩欧美| 国产成人精品亚洲日本在线桃色| 国产高潮av| a级片国产精品自在拍在线播放| 深夜成人在线观看| 视色,视色影院,视色影库,视色网| eeuss影院www影院| 亚洲欧美伊人| 最近中文字幕免费观看| 欧美在线观看成人| 国产在线69| 国产精品久久久久久av| 这里只有精品丝袜| 日本中文字幕成人| 国产精品白丝一区二区三区| 国产美女视频91| 亚洲色图视频在线观看| 91不卡在线观看| 蜜乳av另类精品一区二区| 国产精品无码专区在线观看| 亚洲欧美久久久| 欧美最顶级a∨艳星| 午夜影视一区二区三区| 亚洲国产精品久久不卡毛片| 91香蕉视频mp4| 国语自产偷拍精品视频偷| 日本aⅴ精品一区二区三区| 日韩欧美伦理电影院| 国产成人精品最新| 国产蜜臀一区二区打屁股调教| 国产成人精品一区二区免费看京| 久久精品黄色| 一级片视频免费| 国产成年人视频网站|