2012-07-28 12 views
8

प्रीम्बल में विफल रहता है: एसडीके स्तर 16 के बाद, एंड्रॉइड में एक अंतर्निहित ज़ीरोकॉन्फ़ कार्यान्वयन है। जब तक कांस्य युग संगतता चिंता न हो, तब तक jmDNS का उपयोग न करें, इसके बजाय NsdManager का उपयोग करें।जेएमडीएनएस के साथ एंड्रॉइड बिल्ड


प्रस्तावना # 2: NsdManager के प्रारंभिक संस्करणों और लिंक किए गए बग रिकॉर्ड खामियों से भरे हुए हैं अतः getSystemService(Context.NSD_SERVICE) freezes the 5.0 emulator प्रश्न देखें।


मैं jmDNS 3.4.1 मेरे Android परियोजना में शामिल किया है। lib के तहत जेएआर की प्रतिलिपि बनाई गई, फिर "जावा बिल्डपाथ"/पुस्तकालयों के तहत एक संदर्भ जोड़ा गया।

अब अपने निर्माण कंसोल में निम्न संदेश के साथ विफल रहता है:

[2012-07-27 22:59:07 - Yarxi] Dx 
UNEXPECTED TOP-LEVEL EXCEPTION: 
java.lang.IllegalArgumentException: already added: Lcom/strangeberry/jmdns/tools/Browser$1; 
at 

com.android.dx.dex.file.ClassDefsSection.add(ClassDefsSection.java:123) 
    at com.android.dx.dex.file.DexFile.add(DexFile.java:163) 
    at com.android.dx.command.dexer.Main.processClass(Main.java:486) 
    at com.android.dx.command.dexer.Main.processFileBytes(Main.java:455) 
    at com.android.dx.command.dexer.Main.access$400(Main.java:67) 
    at com.android.dx.command.dexer.Main$1.processFileBytes(Main.java:394) 
    at com.android.dx.cf.direct.ClassPathOpener.processArchive(ClassPathOpener.java:245) 
    at com.android.dx.cf.direct.ClassPathOpener.processOne(ClassPathOpener.java:131) 
    at com.android.dx.cf.direct.ClassPathOpener.process(ClassPathOpener.java:109) 
    at com.android.dx.command.dexer.Main.processOne(Main.java:418) 
    at com.android.dx.command.dexer.Main.processAllFiles(Main.java:329) 
    at com.android.dx.command.dexer.Main.run(Main.java:206) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) 
    at java.lang.reflect.Method.invoke(Unknown Source) 
    at com.android.ide.eclipse.adt.internal.build.DexWrapper.run(DexWrapper.java:180) 
    at com.android.ide.eclipse.adt.internal.build.BuildHelper.executeDx(BuildHelper.java:703) 
    at com.android.ide.eclipse.adt.internal.build.builders.PostCompilerBuilder.build(PostCompilerBuilder.java:577) 
    at org.eclipse.core.internal.events.BuildManager$2.run(BuildManager.java:728) 
    at org.eclipse.core.runtime.SafeRunner.run(SafeRunner.java:42) 
    at org.eclipse.core.internal.events.BuildManager.basicBuild(BuildManager.java:199) 
    at org.eclipse.core.internal.events.BuildManager.basicBuild(BuildManager.java:321) 
    at org.eclipse.core.internal.events.BuildManager.build(BuildManager.java:396) 
    at org.eclipse.core.internal.resources.Project$1.run(Project.java:618) 
    at org.eclipse.core.internal.resources.Workspace.run(Workspace.java:2344) 
    at org.eclipse.core.internal.resources.Project.internalBuild(Project.java:597) 
    at org.eclipse.core.internal.resources.Project.build(Project.java:124) 
    at com.android.ide.eclipse.adt.internal.project.ProjectHelper.doFullIncrementalDebugBuild(ProjectHelper.java:1000) 
    at com.android.ide.eclipse.adt.internal.launch.LaunchConfigDelegate.launch(LaunchConfigDelegate.java:147) 
    at org.eclipse.debug.internal.core.LaunchConfiguration.launch(LaunchConfiguration.java:854) 
    at org.eclipse.debug.internal.core.LaunchConfiguration.launch(LaunchConfiguration.java:703) 
    at org.eclipse.debug.internal.ui.DebugUIPlugin.buildAndLaunch(DebugUIPlugin.java:937) 
    at org.eclipse.debug.internal.ui.DebugUIPlugin$8.run(DebugUIPlugin.java:1141) 
    at org.eclipse.core.internal.jobs.Worker.run(Worker.java:54) 
[2012-07-27 22:59:10 - Yarxi] Dx 1 error; aborting 
[2012-07-27 22:59:10 - Yarxi] Conversion to Dalvik format failed with error 1 

और जब मैं संदर्भित पुस्तकालय के तहत पैकेज Explorer में जार सामग्री को देखने, मुझे लगता है कि jmdns में हर पैकेज के तहत हर वर्ग। जार दो बार सूचीबद्ध है। JmDNS.class की दो प्रतियां, JmmDNS.class की दो प्रतियां, और बहुत आगे।

कोई विचार जार के साथ क्या गलत है? मैं प्रोजेक्ट में अन्य जार का उपयोग कर रहा हूं, उनमें से कोई भी इस तरह से कार्य नहीं करता है। कुछ बार सफाई करने की कोशिश की, हटा दिया और जार फिर से जोड़ा - एक ही प्रभाव।

यह ध्यान देने योग्य हो सकता है कि यह एक लाइब्रेरी प्रोजेक्ट है, और जब मैं ऐप बनाता हूं जो लाइब्रेरी को संदर्भित करता है तो त्रुटि पॉप अप होती है।

+0

प्रीम्बल के लिए धन्यवाद। मैंने एनएसडीमेनगर का उपयोग शुरू कर दिया है और सकारात्मक अनुभव किया है। मैं सोच रहा हूं कि क्या एनएसडीमेनगर पूरी तरह से जेएमडीएनएस को प्रतिस्थापित कर सकता है। – Hong

+0

एनएसडीएमनेजर की अपनी समस्याएं हैं: http://stackoverflow.com/questions/27281340/getsystemservicecontext-nsd-service-freezes-the-5-0-emulator –

+0

प्रारंभ में मुझे कुछ समस्या थी क्योंकि मैंने वहां टिप्पणी की थी, लेकिन ऐसा प्रतीत होता है स्थिर क्या एनएसडीएमनेजर कार्यक्षमता के मामले में जेएमडीएनएस को प्रतिस्थापित कर सकता है? मैंने जेएमडीएनएस को बहुत संक्षेप में इस्तेमाल किया, फिर एनएसडीएमनेजर पर स्विच किया, जेएमडीएनएस में बहुत सारे काम हैं। – Hong

उत्तर

15

आपने शायद SourceForge से .jar का उपयोग किया था। उस संस्करण में सभी .class फ़ाइलें .jar में दो बार हैं और इससे आपकी त्रुटि होती है।

मैवेन http://search.maven.org/#browse|1991004139 से .jar का उपयोग करने का प्रयास करें, यह काम करना चाहिए, मैंने इस महीने के शुरू में इसका इस्तेमाल किया था।

+0

अच्छा, धन्यवाद। यह मदद करता है। +1 – uerceg

4

देखें कि उत्तर here मदद करता है या नहीं।

सामान्य शब्दों में, जार फ़ाइल SourceForge Home Page से विकृत है और Android के साथ काम नहीं करता है, Maven Central Repository से एक, या गंदा वैकल्पिक हल this blog post में उल्लेख उपयोग करके देखें।

संबंधित मुद्दे