Undefined symbols for architecture arm64

前端 未结 30 1838
南旧
南旧 2020-11-22 08:17

I am getting a Apple Mach-O Linker Error everytime I import a file from CocoaPods.

Undefined symbols for architecture arm64:
  \"_OBJC_CLASS_$_FBSession\", r         


        
相关标签:
30条回答
  • 2020-11-22 09:02

    Here are some explanations why build_active_architecture is set to NO. Xcode now detects which devices you have connected and will set the active architecture accordingly. So if you plug a 2nd generation iPod Touch into your computer, Xcode should set the active architecture to armv6. Building your target with the above Debug configuration will now only build the armv6 binary to save time (unless you have a huge project you may not notice the difference but I guess the seconds add up over time).

    When you create a Distribution configuration for publishing to the App Store, you should make sure this option is not set, so that Xcode will instead build the fat universal binary http://useyourloaf.com/blog/2010/04/21/xcode-build-active-architecture-only.html

    0 讨论(0)
  • 2020-11-22 09:02

    I faced the same issue. My solution I found here: Why linker link static libraries with errors? iOS

    Adding $(TOOLCHAIN_DIR)/usr/lib/swift/$(PLATFORM_NAME) to the library search paths fixed the problem.

    0 讨论(0)
  • 2020-11-22 09:03

    I ran into the same/similar issue implementing AVPictureInPictureController and the issue was that I wasn't linking the AVKit framework in my project.

    The error message was:

    Undefined symbols for architecture armv7:
       "_OBJC_CLASS_$_AVPictureInPictureController", referenced from:
           objc-class-ref in yourTarget.a(yourObject.o)
    ld: symbol(s) not found for architecture armv7
    clang: error: linker command failed with exit code 1 (use -v to see invocation)
    

    The Solution:

    1. Go to your Project
    2. Select your Target
    3. Then, go to Build Phases
    4. Open Link Binary With Libraries
    5. Finally, just add + the AVKit framework / any other framework.

    Hopefully this helps someone else running into a similar issue I had.

    0 讨论(0)
  • 2020-11-22 09:03

    I also encountered the same problem , the above methods will not work . I accidentally deleted the files in the following directory on it .

    Folder emplacement:

    ~/Library/Developer/Xcode/DerivedData/

    0 讨论(0)
  • 2020-11-22 09:03

    Given an iPhone 5s and not yet having received a 64 bit version of a third party library, I had to go back to 32 bit mode with the latest Xcode (prior to 5.1 it didn't complain).

    I fixed this by deleting arm64 from the Valid Architectures list and then setting Build Active Architecture Only to NO. It seems to me this makes more sense than the other way around as shown above. I'm posting in case other people couldn't get any of the above solutions to work for them.

    0 讨论(0)
  • 2020-11-22 09:03

    The following worked for me to get GPUImage compiling without errors on Xcode 5.1 for both the 64-bit simulator and retina iPad Mini, without needing to remove arm64 from the Valid Architectures list (which defeats the purpose of owning a 64-bit device for testing 64-bit performance).

    Download the .zip folder from the GitHub page: https://github.com/BradLarson/GPUImage

    Unzip, and navigate to the 'framework' folder. From here, add and copy the 'Source' folder into your Xcode project. Ensure 'Copy items into destination group's folder' is ticked, and that 'Create groups for any added folders' is also ticked. This will copy the generic, iOS and Mac header/implementation files into your project.

    If you don't need the Mac files because you're compiling for iOS you can delete the Mac folder either before you copy the files into your project, or simply delete the group from within Xcode.

    Once you've added the Source folder to your project just use the following to begin using GPUImage's classes/methods:

    #import "Source/GPUImage.h" 
    

    A few things to point out:

    • If you get an error saying 'Cocoa' not found, you've added the Mac folder/headers into your iOS project - simply delete the Mac group/files from your project and the warning will vanish
    • If you rename the Source folder (not the group in Xcode), use that name instead of "Source/GPUImage.h" in the #import instruction. So if you rename the folder to GPUImageFiles before you add to your project, use: #import "GPUImageFiles/GPUImage.h
    • Obviously ensure arm64 is selected in the Valid Architectures list to take advantage of the A7 64-bit processor!
    • This isn't a GPUImage.framework bundle (such as if you downloaded the framework from http://www.raywenderlich.com/60968/ios-7-blur-effects-gpuimage) so it may not the correct way to use GPUImage that Brad Larson intended, but it works for my current SpriteKit project.
    • There's no need to link to frameworks/libraries etc - just import the header and implementation source folder as described above

    Hope the above helps - it seems there were no clear instructions anywhere despite the question being asked multiple times, but fear not, GPUImage definitely works for arm64 architecture!

    0 讨论(0)
提交回复
热议问题