Ответ 1
Ошибка компилятора. Спасибо, что зарегистрировали его.
num1
и num2
должны гарантировать срок службы указанных объектов. Я подозреваю, что оптимизатор [правильно] повторно использует слоты стека и [неправильно] испускает последовательность release/сохранения, что приводит к этой проблеме.
В ответ на stackmaster; это ошибка компилятора. Весь смысл ARC заключается в том, чтобы перейти Objective-C к точке, где компилятор может проанализировать код со 100% уверенностью, чтобы знать, где хранить записи/релизы, которые вам, разработчику, не нужно. По большому счету, он может достичь именно этого, даже перед лицом потоковой передачи, до тех пор, пока оба кода, которые используют объект в мире MRR, хорошо себя ведут, и разработчик не "убегает" от объекта из управления ARC и сделать что-то непослушное. Два больших ifs, но значительное улучшение по сравнению с MRR.
Наконец, если ваш код не работает при оптимизации (когда ошибки компилятора не вступают в игру) , это потому, что ваш код поврежден. Правильно написанный оптимизатор не сломает правильно написанный код.
В то время как некоторые компиляторы, как известно, ошибочны, LLVM не является одним из них (я не буду претендовать на GCC, потому что я не использовал его в течение многих лет, но я бы сказал, что то же самое можно сказать). Система iOS или OS X выполнит миллионы и миллионы строк скомпилированного кода с оптимизированной поддержкой при каждой загрузке, и система работает достаточно хорошо.
Итак, нет, "оптимизатор включен" никогда не является окончательным разрешением для сбоя.
Как отметил Catfish_man, есть варианты эзотерического оптимизатора, которые специально создадут технически неправильный код. Они не поддерживаются -O или другими "стандартными" оптимизациями. Они в основном сосредоточены на математических упражнениях и, таким образом, обычно не будут приводить к сбоям, а не быстрее ползучести ошибки в вычислениях.