Коротко основные отличия между structure и class. #structures #classes
🔹Классы поддерживают наследование, а структуры — нет.
Классы — ссылочный тип, структуры — тип-значение.
🔹Классы поддерживают наследование, а структуры — нет.
Классы — ссылочный тип, структуры — тип-значение.
Что такое generics и для чего они нужны? #generics
🔹 В Swift вы можете использовать generics в классах, структурах и перечислениях.
🔹 Generics устраняют проблему дублирования кода. Если у вас есть метод, который принимает параметры одного типа, иногда приходится дублировать код, чтобы работать с параметрами другого типа.
🔹 Например, в этом коде вторая функция — это «клон» первой, за исключением того, что у неё параметры string, а не integer.
func areIntEqual(_ x: Int, _ y: Int) -> Bool {
return x == y
}
func areStringsEqual(_ x: String, _ y: String) -> Bool {
return x == y
}
areStringsEqual("ray", "ray") // true
areIntEqual(1, 1) // true
🔹 Применяя generics, вы совмещаете две функции в одной и одновременно обеспечиваете безопасность типов:
func areTheyEqual<T: Equatable>(_ x: T, _ y: T) -> Bool {
return x == y
}
areTheyEqual("ray", "ray")
areTheyEqual(1, 1)
🔹 Так как вы тестируете равенство, вы ограничиваете типы теми, которые отвечают протоколу Equatable. Этот код обеспечивает требуемый результат и препятствует передаче параметров неподходящего типа.
🔹 В Swift вы можете использовать generics в классах, структурах и перечислениях.
🔹 Generics устраняют проблему дублирования кода. Если у вас есть метод, который принимает параметры одного типа, иногда приходится дублировать код, чтобы работать с параметрами другого типа.
🔹 Например, в этом коде вторая функция — это «клон» первой, за исключением того, что у неё параметры string, а не integer.
func areIntEqual(_ x: Int, _ y: Int) -> Bool {
return x == y
}
func areStringsEqual(_ x: String, _ y: String) -> Bool {
return x == y
}
areStringsEqual("ray", "ray") // true
areIntEqual(1, 1) // true
🔹 Применяя generics, вы совмещаете две функции в одной и одновременно обеспечиваете безопасность типов:
func areTheyEqual<T: Equatable>(_ x: T, _ y: T) -> Bool {
return x == y
}
areTheyEqual("ray", "ray")
areTheyEqual(1, 1)
🔹 Так как вы тестируете равенство, вы ограничиваете типы теми, которые отвечают протоколу Equatable. Этот код обеспечивает требуемый результат и препятствует передаче параметров неподходящего типа.
В некоторых случаях не получится избежать неявного разворачивания (implicitly unwrapped) optionals. Когда и почему? #optionals
🔹Наиболее частые причины для использования implicitly unwrapped optionals:
когда вы не можете инициализировать свойство, которое не nil в момент создания. Типичный пример — outlet у Interface Builder, который всегда инициализируется после его владельца. В этом особенном случае, если в Interface Builder всё правильно сконфигурировано — вам гарантировано, что outlet не-nil перед его использованием.
чтобы разрешить проблему цикла сильных ссылок, когда два экземпляра классов ссылаются друг на друга и требуется не-nil ссылка на другой экземпляр. В этом случае вы помечаете ссылку на одной стороне как unowned, а на другой стороне используете неявное разворачивание optional.
🔹Наиболее частые причины для использования implicitly unwrapped optionals:
когда вы не можете инициализировать свойство, которое не nil в момент создания. Типичный пример — outlet у Interface Builder, который всегда инициализируется после его владельца. В этом особенном случае, если в Interface Builder всё правильно сконфигурировано — вам гарантировано, что outlet не-nil перед его использованием.
чтобы разрешить проблему цикла сильных ссылок, когда два экземпляра классов ссылаются друг на друга и требуется не-nil ссылка на другой экземпляр. В этом случае вы помечаете ссылку на одной стороне как unowned, а на другой стороне используете неявное разворачивание optional.
Внимание! Все способы разворачивания опционалов. #optionals
спойлер: всего их 7!
🔹1. Принудительное развёртывание (forced unwrapping) — небезопасно.
let a: String = x!
🔹2. Неявное развертывание при объявлении переменной — небезопасно.
var a = x!
🔹3. Optional binding — безопасно.
if let a = x {
print("x was successfully unwrapped and is = \(a)")
}
🔹4. Optional chaining — безопасно.
let a = x?.count
🔹5. Nil coalescing operator — безопасно.
let a = x ?? ""
🔹6. Оператор Guard — безопасно.
guard let a = x else {
return
}
🔹7. Optional pattern — безопасно.
if case let a? = x {
print(a)
}
спойлер: всего их 7!
🔹1. Принудительное развёртывание (forced unwrapping) — небезопасно.
let a: String = x!
🔹2. Неявное развертывание при объявлении переменной — небезопасно.
var a = x!
🔹3. Optional binding — безопасно.
if let a = x {
print("x was successfully unwrapped and is = \(a)")
}
🔹4. Optional chaining — безопасно.
let a = x?.count
🔹5. Nil coalescing operator — безопасно.
let a = x ?? ""
🔹6. Оператор Guard — безопасно.
guard let a = x else {
return
}
🔹7. Optional pattern — безопасно.
if case let a? = x {
print(a)
}
В чём разница между nil и .none? #optionals
🔹 Нет никакой разницы, Optional.none (кратко .none) и nil эквивалентны.
Фактически, следующий оператор вернёт true:
nil == .none
🔹 Использование nil более общепринято и рекомендовано.
🔹 Нет никакой разницы, Optional.none (кратко .none) и nil эквивалентны.
Фактически, следующий оператор вернёт true:
nil == .none
🔹 Использование nil более общепринято и рекомендовано.
Жизненный цикл ViewController'a #ViewController
viewDidLoad()
viewWillAppear(_ animated: Bool)
viewDidAppear(_ animated: Bool)
viewWillDisappear(_ animated: Bool)
viewDidDisappear(_ animated: Bool)
viewDidLoad()
viewWillAppear(_ animated: Bool)
viewDidAppear(_ animated: Bool)
viewWillDisappear(_ animated: Bool)
viewDidDisappear(_ animated: Bool)
Функции высшего порядка (Higher-Order functions) #functions
🔹 определяются как функции, принимающие другую функцию как аргумент или возвращающие функцию.
🔹 их много: map , filter , reduce , forEach , flatMap , compactMap ,sorted и т.д. Наиболее распространенными примерами функций высшего порядка являются функции map , filter и reduce.
🔹 определяются как функции, принимающие другую функцию как аргумент или возвращающие функцию.
🔹 их много: map , filter , reduce , forEach , flatMap , compactMap ,sorted и т.д. Наиболее распространенными примерами функций высшего порядка являются функции map , filter и reduce.
Функции высшего порядка (Higher-Order functions) #functions
map, reduce, sorted, filter
🔹 Map: для преобразования содержимого массивов, map(_:)
//пример
let numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
func timesTen(_ x:Int) -> Int {
return x * 10
}
let result = numbers.map (timesTen)
print(numbers) //[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
print(result) //[10, 20, 30, 40, 50, 60, 70, 80, 90, 100]
🔹 Reduce: перебирает каждый элемент в коллекции и сводит их к одному значению, reduce (_:, _:)
//пример
let values = [3, 4, 5]
let sum = values.reduce(0, +)
print(sum)
//вывод: 12
🔹Sorted: сортировка массивов, основана на заданном вами замыкании, sorted(by:)
//пример (сортировка по алфавиту)
let avatarMovie = Movie(name: "Avatar")
let titanicMovie = Movie(name: "Titanic")
let piranhaMovie = Movie(name: "Piranha II: The Spawning")
let movies = [avatarMovie, titanicMovie, piranhaMovie]
let sortedMovies = movies.sorted(by: { $0 < $1 })
print(sortedMovies)
// вывод: [Avatar, Piranha II: The Spawning, Titanic]
🔹Filter: преобразует массив в соответствии с заданным условием, filter (_:)
//пример
let numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
let filted = numbers.filter{$0 % 2 == 0}
//[2, 4, 6, 8, 10]
map, reduce, sorted, filter
🔹 Map: для преобразования содержимого массивов, map(_:)
//пример
let numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
func timesTen(_ x:Int) -> Int {
return x * 10
}
let result = numbers.map (timesTen)
print(numbers) //[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
print(result) //[10, 20, 30, 40, 50, 60, 70, 80, 90, 100]
🔹 Reduce: перебирает каждый элемент в коллекции и сводит их к одному значению, reduce (_:, _:)
//пример
let values = [3, 4, 5]
let sum = values.reduce(0, +)
print(sum)
//вывод: 12
🔹Sorted: сортировка массивов, основана на заданном вами замыкании, sorted(by:)
//пример (сортировка по алфавиту)
let avatarMovie = Movie(name: "Avatar")
let titanicMovie = Movie(name: "Titanic")
let piranhaMovie = Movie(name: "Piranha II: The Spawning")
let movies = [avatarMovie, titanicMovie, piranhaMovie]
let sortedMovies = movies.sorted(by: { $0 < $1 })
print(sortedMovies)
// вывод: [Avatar, Piranha II: The Spawning, Titanic]
🔹Filter: преобразует массив в соответствии с заданным условием, filter (_:)
//пример
let numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
let filted = numbers.filter{$0 % 2 == 0}
//[2, 4, 6, 8, 10]
30 days of Swift - все заметки стараюсь делать с максимальной пользой, наткнулся на обалденый репозиторий в Git, там парнишка разместил 30 различных проектов на Swift начального уровня.
🔹Если в лом залезать в папочки и смотреть код, то там даже GIFки есть с отображением функционала :)) https://github.com/allenwong/30DaysofSwift
🔹Если в лом залезать в папочки и смотреть код, то там даже GIFки есть с отображением функционала :)) https://github.com/allenwong/30DaysofSwift
GitHub
GitHub - allenwong/30DaysofSwift: A self-taught project to learn Swift.
A self-taught project to learn Swift. Contribute to allenwong/30DaysofSwift development by creating an account on GitHub.
Цикл For в Swift
Цикл for базовый метод во всех языка, в swift часто называют for-in
🔹for-in для массива #collections #array
В примере итерация по массиву городов #array, в Swift массивы так же известны под таким понятием как коллекции #collections
let cities = ["Amsterdam", "New York", "San Francisco"]
for city in cities {
print(city)
}
вывод: // Amsterdam
// New York
// San Francisco
🔹for-in для словаря #dictionary
Пример итерации словаря. Выводим возраст
let ages = ["Antoine": 28, "Jaap": 2, "Jack": 72]
for (name, age) in ages {
print("\(name) is \(age) years old")
}
вывод: // Antoine is 28 years old
// Jaap is 2 years old
// Jack is 72 years old
🔹for-in для словаря последовательностей #range
В следующем примере берем #range и выполняем оператор печати 4 раза. Счет идет в обратном порядке, потому что мы его добавили .reversed, это также может использоваться в других циклах.
for index in (0...3).reversed() {
print("\(index)..")
}
/// 3..
/// 2..
/// 1..
/// 0..
Цикл for базовый метод во всех языка, в swift часто называют for-in
🔹for-in для массива #collections #array
В примере итерация по массиву городов #array, в Swift массивы так же известны под таким понятием как коллекции #collections
let cities = ["Amsterdam", "New York", "San Francisco"]
for city in cities {
print(city)
}
вывод: // Amsterdam
// New York
// San Francisco
🔹for-in для словаря #dictionary
Пример итерации словаря. Выводим возраст
let ages = ["Antoine": 28, "Jaap": 2, "Jack": 72]
for (name, age) in ages {
print("\(name) is \(age) years old")
}
вывод: // Antoine is 28 years old
// Jaap is 2 years old
// Jack is 72 years old
🔹for-in для словаря последовательностей #range
В следующем примере берем #range и выполняем оператор печати 4 раза. Счет идет в обратном порядке, потому что мы его добавили .reversed, это также может использоваться в других циклах.
for index in (0...3).reversed() {
print("\(index)..")
}
/// 3..
/// 2..
/// 1..
/// 0..
Optionals (опционалы) #optionals — это удобный механизм обработки ситуаций, когда значение переменной может отсутствовать. Значение будет использовано, только если оно есть.
p.s: самое мое любимое,когда коротко и ясно :)
p.s: самое мое любимое,когда коротко и ясно :)
Вопросы с собеседований
🔹 Explain the common execution states for iOS App
1.Non-running - The app is not running.
2.Inactive - The app is running in the foreground, but not receiving events. An iOS app can be placed into an inactive state, for example, when a call or SMS message is received.
3. Active - The app is running in the foreground, and receiving events.
4. Background - The app is running in the background, and executing code.
5. Suspended(Приостановленный) - The app is in the background, but no code is being executed.
🔹 Explain the common execution states for iOS App
1.Non-running - The app is not running.
2.Inactive - The app is running in the foreground, but not receiving events. An iOS app can be placed into an inactive state, for example, when a call or SMS message is received.
3. Active - The app is running in the foreground, and receiving events.
4. Background - The app is running in the background, and executing code.
5. Suspended(Приостановленный) - The app is in the background, but no code is being executed.
Топ 5 iOS библиотек, которые должны знать разработчики
🔹полное описание по ссылке
1. AFNetworking
2. JSONModel
3. MagicalRecord
4. SDWebImage
5. ReactiveCocoa
🔹полное описание по ссылке
1. AFNetworking
2. JSONModel
3. MagicalRecord
4. SDWebImage
5. ReactiveCocoa
Infinum
Top 5 iOS Libraries Every iOS Developer Should Know About
Using third-party libraries in your iOS projects can save you a lot of time and hassle. Which libraries are worth using, though? Read on and find out!
Дорогие и уважаемые, как лучше выкладывать примеры с кодом, скринами или текстом?
Anonymous Poll
61%
Скрин
22%
Текст
17%
Без разницы 😑
let oneMillion = 1_000_000
let oneThousand = oneMillion / 0_1_0_0_0
print(oneThousand)
🔹как думаете какой будет результат?
//Ответ:1000
let oneThousand = oneMillion / 0_1_0_0_0
print(oneThousand)
🔹как думаете какой будет результат?
//Ответ:
🔹 онлайн компилятор Swift, поддерживает два релиза 5.0 и 5.1.
OnlineSwiftPlaygrounds
OnlineSwiftPlaygrounds
online.swiftplayground.run
Online Swift Playground
Self hosted and embeddable Swift Playground solution with a third-party module support baked in.
#optionals
🔹 еще один вариант работы с опционалами, размещаем дефолтное значение после символов ?? и если в переменной будет nil, получим Unknown, если не nil, то значение, как на скрине.
🔹 еще один вариант работы с опционалами, размещаем дефолтное значение после символов ?? и если в переменной будет nil, получим Unknown, если не nil, то значение, как на скрине.
🔹 Пример использования #forin циклов, в первом кейсе ищем четные числа, во втором при помощи continue ищем нечетные в массиве numbers.