the ios sdk could not be found please reinstall the application как исправить windows
Как исправить ошибку «Windows SDK версии 8.1» не был найден?
Я недавно обновил Visual Studio 2015 и теперь, когда я пытаюсь построить любой проект всегда терпит неудачу, и я получаю ошибку
Код серьезности Описание Состояние подавления строки файла проекта
Ошибка MSB8036 Windows SDK версии 8.1 не найден. Установите требуемую версию Windows SDK или измените версию SDK в
страницы свойств проекта или щелкнув правой кнопкой мыши по решению и выбрав
«Ретаргетическое решение». Proj D: \ Program Files (x86) \ визуальная студия
2017 \ Common7 \ IDE \ VC \ VCTargets \ Platforms \ Win32 \ PlatformToolsets \ v141 \ Toolset.targets 34
Я переназначил решение, как оно было сказано, и проблема не исчезла, даже несмотря на то, что ретаргетинг был завершен. Я решил установить Visual Studio 2017 из-за этого, и, о чудо, он сделал то же самое. Я также использую Windows 7.
В чем проблема и как я могу это исправить?
Решение
Другие решения
У меня был win10 SDK, и мне оставалось только выполнить ретаргетинг, а затем я перестал получать эту ошибку. Идея заключалась в том, что проекту необходимо обновить целевой Windows SDK.
Еще один способ (работал на 2015 год) — открыть «Установка / удаление программ» (Apps & функции), найдите Visual Studio, выберите Изменить. В открывшемся окне нажмите Modify, проверьте
Я установил версию 8.1 SDK:
Он использовал 1 ГБ (немного больше) при установке.
Как исправить ошибки «EOSSDK-Win64-Shipping.dll Не найден (отсутствует)»
В большинстве случаев проблемы Outward, связанные с EOSSDK-Win64-Shipping.dll, возникают в результате повреждения, отсутствия или заражения вирусами файлов DLL. Большую часть проблем, связанных с данными файлами, можно решить посредством скачивания и установки последней версии файла DLL. В некоторых случаях реестр Windows пытается загрузить файл EOSSDK-Win64-Shipping.dll, который больше не существует; в таких ситуациях рекомендуется запустить сканирование реестра, чтобы исправить любые недопустимые ссылки на пути к файлам.
Формат Dynamic Link Library с расширением файла DLL классифицируют в качестве Системные файлы. Вы можете скачать новую копию файла EOSSDK-Win64-Shipping.dll для %%os%% (и ряда операционных систем Windows) в таблице ниже. К сожалению, в настоящее время в нашей базе могут отсутствовать некоторые версии файлов EOSSDK-Win64-Shipping.dll, но их можно запросить, нажав на кнопку Request (Запрос). В некоторых случаях, чтобы получить необходимую версию файла, вам может потребоваться связаться непосредственно с Nine Dots Studio.
Поместите новый файл EOSSDK-Win64-Shipping.dll на место предыдущего (перезаписав предыдущий). Проблема больше не должна возникать, однако, чтобы убедиться в этом окончательно, следует выполнить проверку. Мы рекомендуем повторно запустить Outward для проверки того, возникает ли проблема.
EOSSDK-Win64-Shipping.dll Описание файла | |
---|---|
Формат файла: | DLL |
Группа: | Game |
Софт: | Outward |
Версия выпуска: | 3685395 |
Компания: | Nine Dots Studio |
Имя файла: | EOSSDK-Win64-Shipping.dll Запрос |
Размер (в байтах): | 7170816 |
SHA-1: | c850474f2aae3f9727e9a2969849172801456758 |
MD5: | f7f9da4923f9c75b8820855db7bf942b |
CRC32: | ff371c99 |
Идентификатор статьи: 814610
EOSSDK-Win64-Shipping.dll
Выберите программное обеспечение
iOS SDK broken ever after reinstall UIKit and Foundation frameworks not found
For the pch file I get these errors:
/Users/matt/Programming/iPhone Monkey Curling lite/iPhone_Monkey_Curling_Prefix.pch:6:34: error: Foundation/Foundation.h: No such file or directory
/Users/matt/Programming/iPhone Monkey Curling lite/iPhone_Monkey_Curling_Prefix.pch:7:24: error: UIKit/UIKit.h: No such file or directory
Here’s the file as it is by default:
I reinstalled Xcode and the iOS SDK but that did not fix the problem. This problem occurred after adding the iAd framework to one of my projects but all of my projects won’t compile.
I’m using the latest SDK (4.1).
The frameworks are there in the project. For some reason, when I try to add a new framework, it lists the OS X ones in an iOS project.
Thank you for any help.
6 Answers 6
On the Apple developer forums I managed to get help on pin-pointing the issue. It turns out somehow a build option was set to something odd.
It was the «Framework Search Paths» option. Make sure this is empty if anyone has a similar problem.
I’d like to add to the Matthew’s answer:
Actually, the Framework Search Paths shouldn’t be empty, but it should include only the paths to the SDK’s Frameworks folders. In my case simulator worked with this path:
and device started working when I added this one:
Thi is for XCode Version 4.5.1 (4G1004).
Check to make sure it’s not a typo. Have had multiple dependencies misspell UIKit with a capital I like this:
Just check the import carefully and make sure.
This happened to me. I am not very good with the Mac’s «Finder.» It doesn’t work quite the same as Windows Explorer. I was wanting to add a couple of image files to my project, and navigating my way to the folder I accidentally double-clicked on the Developer folder, which added over 8,500 files to my project. Thinking it would be sufficient to just remove the folder from my project, I didn’t know that it would change search paths. It did, and in fact, it also change my Library search path. Deleted both, and I’m good again. But not before a great deal of emotional agony.
I add this only to let people know how the problem cropped up for me. Something like that is insidiously easy.
my fix was reinstalling xcode (downloading again from developer portal and replace the old one)
Исследуем iOS SDK и используем недокументированные API
Из этой главы, да и из всей этой книги понятно, что самые лакомые куски программирования под iOS включены в публичные фреймворки, но не в SDK. Неофициальная политика Apple насчет этого проста: вы можете всё это использовать, но только на свой страх и риск. Ваш код может сломаться при следующем обновлении прошивки. Вам самим придётся искать компромисс между риском и прибылью.
Дисклеймеры
Краткая инструкция по поиску в SDK
Оставшиеся, если их не более нескольких десятков, можно попытаться скормить гуглу. Случается, что кто-то уже занимался исследованием API, связанных с найденными символами, и в этом случае задача, считай, решена. В более сложных случаях приходится заниматься реверс-инжинерингом, то есть выяснять, как работают найденные функции, как использовать найденных оповещения и тому подобное.
В большинстве случаев, сгенерированного заголовчного файла достаточно: в нем должны быть довольно хорошо описаны иерархии наследования классов, структуры, методы и т.д, чтобы потратив немного времени можно разобраться с API и использовать его в своём предложении.
К сожалению, иногда информации содержащейся в заголовочном файле недостаточно, чтобы заставить код работать, и тогда приходится анализировать ассемблерный код, сгенерированный otool.
Как узнать сигнатуру неизвестной функции?
1. Найти в интернете, как это не банально. Мне довольно часто попадались китайский сайты, были корейский и японский сайты с очень полезной информацией. Обычно самого кода уже достаточно, чтобы понять что происходит и как используется данная функция, данный класс и т.д. Спасибо многословности и выразительности Objective-C!
2. Для многих простых функций, можно попытаться угадать сигнатуру. Внимание, это может быть довольно опасно.
Использование некоторые простые функции, таких как GSEventSetBackLightLevel, самоочевидно.
void GSEventSetBackLightLevel(float level);
Для многих других я использовал следующий трюк (на примере функции SBGetRingerSwitchState):
В результате этих нехитрых действий получается следующая сигнатура:
Кстати, если в названии функции присутствует слово get, то согласно naming conventions Objective-C эта функция должна возвращать значение по ссылке. Это также видно из приведенного примера.
3. Дизассемблирование. На примере все той же SBGetRingerSwitchState. Используем otool:
Из этого кода, используя даже поверхностные знания arm-ассемблера, можно предположить, что функция принимает два аргумента типа «слово» (word)
Выходит, что у функции два аргумента. Идем дальше, в самый конец.
…
00003964 9e04 ldr r6, [sp, #16]
00003966 6836 ldr r6, [r6, #0]
00003968 9903 ldr r1, [sp, #12]
0000396a 600e str r6, [r1, #0]
// примерно соответствует (в терминах языка си): *r1 = r6; т.е. по адресу, хранящемуся в r1 записывается значение из r6;
// Это значит, что функция возвращает значение по ссылке
0000396c 462e mov r6, r5
0000396e 4630 mov r0, r6
// результат выполнения функции помещается в r0
00003970 b012 add sp, #72
00003972 bdf0 pop
…
В сухом остатке получаем:
Продолжая анализировать этот асcемблерный код, уточняем типы и приходим к окончательному варианту:
Разные прошивки и разные устройства: что может сломаться и как это исправить?
Примеры
Пример 1:
Определение положения бокового переключателя вибро (a.k.a. Ring/Silent switch, Mute switch)
Одной из задач, которые стояли передо мной, было определение положения бокового переключателя, который в оригинале называется ring/silent switch. Этот переключатель используется для переключения между «тихим» и обычном/«громким» режимами в айфоне и айпаде. Поиск по StackOverflow дал решение:
Мои дальнейшие поиски по StackOverflow вывели меня на этот пост. В нем описывается библиотечная функция AudioServicesAddSystemSoundCompletion(), чьё нестандартное поведение рассматривалось разработчиками как баг.
Нестандартное поведение заключается в том, что вызов колбэка MyAudioServicesSystemSoundCompletionProc состоится в конце проигрывания звука в обычном режиме, но сразу после вызова AudioServicesPlaySystemSound в «тихом» режиме. Это создает лазейку для определения текущего состояния переключателя. Если, например, длина аудиофайла что мы проигрываем равна 1 с, то разница во времени вызова MyAudioServicesSystemSoundCompletionProc() в «тихом» и громком режиме составляет 1 c. На этом я построил свое второе, асинхронное решение для определения положения бокового переключателя. Вот оно:
Хотя это новое решение и было рабочим, оно не устраивало меня по нескольким причинам. Во-первых, оно было асинхронным и работало с ощутимой задержкой (около 1/10 секунды). Снижение задержки вело к ложным срабатываниям. Во-вторых, был побочный эффект — сам проигрываемый звук, который звучал достаточно громко чтобы смутить пользователя. Позже я искусственно выкрутил громкость в ноль в аудиоредакторе. В-третьих, это был уже слишком похоже на грязный хак, хотя это, например, не помешало создателям VSSilentSwitch продавать свое решение, по всей видимости основанное на том же эффекте.
Примерно через месяц я вернулся к этой проблеме. Я начал использовать команду nm для поиска символов в объектных файлах, на её основе я написал простейший shell-скрипт, листинг которого можно найти ниже (В разделе «Инструменты»). Скрипт запускается с одним, двумя или тремя параметрами, каждый из которых представляет ключевое слово.
Функция с названием SBGetRingerSwitchState выглядела многообещающе.
Для получения нужного порта использовалась функция:
из того же фреймворка.
Вот что получилось в итоге:
Пример 2:
IMEI (International Mobile Equipment Identity) — уникальный идентификационный
код, присваиваемый каждому телефону, своего рода MAC-адрес телефона (хотя MAC-адрес у телефона также есть)
Я уже и не помню, как я вышел проект Эрики Садун uidevice-extension, но по мере того, как я с ним разбирался он всё больше казался мне этакой программистской «золотой жилой».
Одна из категорий, UIDeviсe(IOKit_Extensions) содержит функции для определения IMEI. Я протестировал эти функции на iPhone 4 c iOS 5.1 и iPad c iOS 4.3, всё работало и я перешел к другим задачам. Но в ходе бета-тестирования выяснилось, что функция для определения IMEI не работает на новых устройствах: iPad 2, the new iPad и iPhone 4S. Для выяснения причин я отправился на StackOverflow, где мои опасения подтвердились. Поиски привели меня тогда к фреймворку под названием CoreTelephony.
Можно предположить что функция (_CTServerConnectionCopyMobileEquipmentInfo(. )) возвращает словарь(CFDictionaryRef) c ключами вида kCTMobileEquipmentInfo* и соответствующими им значениями. К счастью, на этот раз мне не пришлось восстанавливать сигнатуру. Поиск в гугле по запросу _CTServerConnectionCopyMobileEquipmentInfo привел меня на эту страничку, и вскоре функция для определения IMEI была готова.
Этот метод определения IMEI работает на всех устройствах.
Позже я нашел еще один метод определения IMEI (через lockdownd).
Пример 3:
Использование недокументированных оповещений: нажатия кнопок громкости.
Изначально я наивно полагал, что любая символьная константа, заканчивающаяся на «Notification» является названием системного оповещения и её можно использовать, просто зарегистрировав наблюдателя (observer) с помощью [NSNotificationCenter defaultCenter].
Написав тестовую программу, я принялся проверять, какие оповещения приходили в ответ на нажатия клавиш громкости.
Из составленного мной довольно большого списка опопвещений приходили только вот эти 2:
Недостаток этих оповещений в том, что
1) Нельзя напрямую определить, какая из двух кнопок была нажата
2) Нельзя отследить, когда нажата и когда отпущена каждая из кнопок
Ищу по другим ключевым словам:
Четыре оповещения из UIKit сработали не сразу: необходимо было подать связанную с ними команду.
После этого стали приходить оповещения о нажатиях соответствующих кнопок.
Побочный эффект: вызов данной функции приводит к тому, что кнопки громкости больше не регулируют громкость, так что по завершении работы с кнопками следует вызвать
Пример 4:
Использование недокументированных оповещений: отслеживание статуса SIM-карты
Работаем по проверенной схеме:
Наиболее подходящими мне показались оповещения под названиями:
1) kCTSIMSupportSIMInsertionNotification
2) kCTSIMSupportSIMStatusChangeNotification
3) kCTSIMSupportSIMTrayStatusNotification
Простейшая тестовая программа показала, что оповещения под названием (1) приходили только в момент вставки сим-карты (я мог бы догадаться и раньше по названию), (2) приходили именно тогда когда мне нужно (при вставке и вынимании), оповещения (3) не приходили вообще. Позже я узнал, что оповещения (3) относятся к специальному центру оповещений под названием CTTelephonyCenter. Об использовании CTTelephonyCenter можно прочитать здесь.
Как исправить ошибку «Отсутствует (не найден) AppFactory.SDK.IOS.dll»
Чаще всего проблемы AppFactory.SDK.IOS.dll типа DLL, возникают в результате повреждения или отсутствия файла, связанного с NCMB. Обычно, установка новой версии файла DLL позволяет устранить проблему, из-за которой возникает ошибка. Помимо прочего, в качестве общей меры по профилактике и очистке мы рекомендуем использовать очиститель реестра для очистки любых недопустимых записей файлов, расширений файлов DLL или разделов реестра, что позволит предотвратить появление связанных с ними сообщений об ошибках.
Формат Dynamic Link Library, известный как собственный формат Системные файлы, чаще всего имеет расширение DLL. Ниже вы также можете найти последние версии файлов для %%os%% (и для других версий ОС). Если у нас нет необходимой копии версии AppFactory.SDK.IOS.dll, вы можете просто нажать кнопку Request (Запрос), чтобы её запросить. Кроме того, Magellan Holdings LLC также может предоставить вам некоторые редкие файлы, которые отсутствуют в нашем каталоге.
Несмотря на то, что в большинстве случаев после размещения файла AppFactory.SDK.IOS.dll в надлежащем месте на жёстком диске, сообщения об ошибках, связанных с этим файлом, больше не выводятся, следует выполнить быструю проверку, чтобы окончательно в этом убедиться. Чтобы убедиться в том, что удалось решить проблему, попробуйте запустить NCMB, и посмотреть выведется ли ошибка.
AppFactory.SDK.IOS.dll Описание файла | |
---|---|
File: | DLL |
Функция: | 1.0.0 |
Application: | NCMB |
Версия программного обеспечения: | 1.0.0.0 |
Компания: | Magellan Holdings LLC |
Имя файла: | AppFactory.SDK.IOS.dll Запрос |
KB: | 17920 |
SHA-1: | 70929C4F6DE23D5EA9E6D72F3F6DA3345AF64681 |
MD5: | 6E6637136F5C74381EE3D6F1FB3D4FC6 |
CRC32: |
Идентификатор статьи: 999890
AppFactory.SDK.IOS.dll
Выберите программное обеспечение