Duplicate symbol issues

2019-01-31 10:40发布

During a refactor of an iOS project, I ran into this bear of a bug. During the linking phase, I get this message:

ld: duplicate symbol _OBJC_IVAR_$_TinCanViewController.currentViewController in /path/to/TinCanViewController-E98A666B7AF2673A.o and /path/to/TinCanViewController-E98A666B7AF2673A.o

As far as I can tell, it looks like it claims TinCanViewController-E98A666B7AF2673A.o is declaring the specified symbol twice; both paths are pointing to the exact same .o file. I ran nm on that specific file, and it only included that symbol once:

00008150 S _OBJC_IVAR_$_TinCanViewController.currentViewController

I ran nm on all the other .o files in the directory to see if they were somehow declaring this symbol, too, but they're not. This happens to any member I add to the TinCanViewController class - it's not specific to currentViewController.

I feel like I must be somehow linking against the class twice somehow, but I've pretty assiduously gone through and checked all references to this class. In the refactored version, there are basically none. The AppDelegate includes it, but right now it's basically just a passthrough class that loads another ViewController at the start. No other classes in the project include it.

Any suggestions on what might be causing this or how I might debug it better?

8条回答
Bombasti
2楼-- · 2019-01-31 10:53

Make sure delegate.m is only listed once within the Compile-Sources.

查看更多
Evening l夕情丶
3楼-- · 2019-01-31 10:55

I had this happen but my problem was related to merge issues from our repo. The .m file was listed twice in a spot that it should only have been listed once (within the project, but not within the file/group structure, so you could not see the issue in Xcode, only the error). The fix is opening the .pbxproj file inside your project file and locating the duplicate entry in that file. After deleting the duplicate the project built just fine.

查看更多
Lonely孤独者°
4楼-- · 2019-01-31 10:55

I think this is a bug with Apple's latest linker when creating universal static libraries. I can;t find the bug number currently, but this happens because it incorrectly generates armv6 and armv7 without disambiguating them.

To verify if this is the case, change the configuration to build only armv6 or amv7, and you won't have this problem.

查看更多
叛逆
5楼-- · 2019-01-31 10:59

This could also happen if you have a multi-target project and two targets have same file like abc.m and that abc.m is selected for both targets.

What happened in my case was I had two targets named ABC and XYZ and both had their own DiagramViewController.m file which are supposed to run code for their targets. I accidentally had DiagramViewController.m of target ABC had target selected for XYZ also.

Solution :

Click on .m file go to file inspector and unselect additional target.

enter image description here

查看更多
疯言疯语
6楼-- · 2019-01-31 11:02

I had this issue on the latest Xcode 4. Cause: I included file.m instead of file.h

Possibly, you included TinCanViewController.m (should be TinCanViewController.h)

查看更多
Summer. ? 凉城
7楼-- · 2019-01-31 11:06

I happened to have included the .h file and the .m file twice in the project. Once I removed the second copy, the error went away.

查看更多
登录 后发表回答