Czy konwencja nazwy pakietu Java jest wadliwa? [Zamknięte]


28

Wszyscy znamy konwencję nazewnictwa nazw pakietów Java. Tj. www.evilcorp.com, Zgodnie z konwencją, wolałby mieć swoje pakiety Java com.evilcorp.stuff.

Coraz bardziej mam tego dość. Jako programista komercyjny ciągle napotykam, że nazwa pakietu oprogramowania jest całkowicie nieistotna z powodu zmiany marki, nabycia lub podobnego.

W świecie open source jest mniej zmian nazw, więc ma to sens. Wydaje mi się jednak, że okres trwałości wielu programów (komercyjnych / wewnętrznych) jest znacznie dłuższy niż czas ich produkcji.

Problem często się pogłębia, gdy projekty oprogramowania podejmują decyzję działu marketingu, by używać nazwy du Jour, której używają, odnosi się do określonego projektu. Nazwa, która bez wątpienia zmieni 3 miesiące później, aby nowe ubrania cesarza wydawały się świeże i nowe.

Z tego powodu najczęściej przestałem używać odwrotnej domeny jako nazwy pakietu. To prawda, że ​​jeśli odbywa się to na dużą skalę, istnieje ryzyko kolizji nazw, ale na pewno można to złagodzić, stosując albo „unikalne” nazwy oprogramowania, unikając słów ogólnych, albo wykorzystując domenę odwrotną do projektów przeznaczonych do sprzedaży / wydania jako biblioteki .

Inne przemyślenia?


2
We're all familiar with the Java package name convention of turning the domain name around.- um .. nie jesteśmy ... :)
dr Hannibal Lecter

8
@dr Hannibal Lecter: Całkiem proste. Java (na stronie Java.com) nazywa swoje pakiety com.java.etc.etc. Apache (na stronie Apache.org) nazywa swoje pakiety org.apache.etc.etc. Widzisz wzór.
doppelgreener


1
„W świecie open source jest mniej zmian nazw” - nawet tam jest problem, często widzę projekty, które mówią teraz github, ale ich nazwy pakietów ujawniają, że kiedyś znajdowały się na odwrocie net.sourceforge.xxx lub com. googlecode.xxx
nafg

@nafg - racja. dlatego mam tendencję do rejestrowania własnej nazwy domeny dla każdego projektu typu open source, w którym zaczynam pracę w tych dniach, ponieważ niekoniecznie chcę powiązać swoją tożsamość z jakąś konkretną korporacją (taką jak sourceforge lub github, która zapewnia jej usługa lub taka jak moja własna firma, która zapewniła oryginalną motywację do jej rozwoju). Musi być swobodny, aby być swoim własnym.
Jules

Odpowiedzi:


23

Przytoczę radę Microsoft dotyczącą przestrzeni nazw (pakietów .NET), która nie ma konwencji nazw domen. Myślę, że to dobra rada także dla pakietów Java, ponieważ nie wierzę, że nazwa domeny reprezentuje solidną i stabilną tożsamość.

Ogólny format nazwy przestrzeni nazw jest następujący:

<Company>.(<Product>|<Technology>)[.<Feature>][.<Subnamespace>]

Na przykład Microsoft.WindowsMobile.DirectX.

Wykonaj prefiks nazw przestrzeni nazw z nazwą firmy, aby przestrzenie nazw różnych firm nie miały tej samej nazwy i prefiksu.

Używaj stabilnej, niezależnej od wersji nazwy produktu na drugim poziomie nazwy przestrzeni nazw.

Nie używaj hierarchii organizacyjnych jako podstawy nazw w hierarchiach przestrzeni nazw, ponieważ nazwy grup w korporacjach są zazwyczaj krótkotrwałe.

Nazwa przestrzeni nazw jest długowiecznym i niezmiennym identyfikatorem. W miarę ewolucji organizacji zmiany nie powinny powodować, że nazwa przestrzeni nazw staje się przestarzała.

Jeśli nawet nazwa Twojej firmy jest niestabilna, możesz zacząć od nazwy produktu.


3
Co Microsoft zaleca zrobić, jeśli inna firma ma taką samą nazwę jak Twoja?

25
@ Thorbjørn - spory sądowe
RevBingo

9
@ Thorbjørn: Przestrzeń nazw, w przeciwieństwie do domeny, nie jest i nie może być własnością nikogo. To tylko logiczny podział lub kategoryzacja kodu. Szanse na kolizję między tobą a inną firmą zbliżają się do zera, chyba że ta inna firma również zdarzy się opracować oprogramowanie, w tej samej technologii i ma podobną ofertę (w skrócie - twoją konkurencję). W takim przypadku skorzystałbym z sugestii RebBingo, chyba że nie masz nic przeciwko posiadaniu konkurencyjnej firmy o takiej samej nazwie jak Twoja firma.
Allon Guralnek

4
Jak wskazano w odpowiedzi @ Thorbjørn, problemem, który rozwiązuje konwencja nazewnictwa Java, nie jest zagwarantowanie stałości, ale raczej unikalność . Zwróć uwagę, że konwencja Microsoft nie gwarantuje .
user359996

4
@ user359996: Tak jak powiedziałem, nie rozumiem, dlaczego uniwersalna wyjątkowość jest problemem wymagającym rozwiązania. Dlaczego chcesz, aby nazwy były unikalne we wzajemnie wykluczających się bazach kodu? Styl Java nie gwarantuje tego, ponieważ własność domen może zmienić właściciela. Deweloper, który jest właścicielem jUtils.com, może opracować bibliotekę com.jutils. *, Z której wielu korzysta, a następnie sprzedać swoją domenę zupełnie innemu deweloperowi, który tworzy inną bibliotekę com.jutils. *, Która jest również popularna, ale ma kolizję z istniejąca biblioteka.
Allon Guralnek

15

Patrzysz na rozwiązanie innego problemu, mianowicie jak uniknąć tego, aby programista X i programista Y stawiali sobie nawzajem palce, umieszczając pliki w tym samym pakiecie.

„Po prostu odwróć nazwę swojej domeny” rozwiązuje to w elegancki sposób, ponieważ jesteś pewien, że jeśli X i Y nie są ze sobą powiązane, nie wybiorą tej samej przestrzeni nazw pakietów.


+1 „Patrzysz na rozwiązanie innego problemu”.
user359996

10

Konwencja nie jest wadliwa. Ludzie mają wady, jak dobrze się zilustrowałeś.

Mogę wymyślić 2 korzyści:

  1. Pozwala to uniknąć kolizji między niezależnymi programistami. Domena jest unikalna. Dwie osoby mogą nazwać dwa różne projekty tak samo, ale domena ma dokładnie jednego właściciela.
  2. Ułatwia to znalezienie opiekuna. Jeśli odziedziczysz bazę kodu, która korzysta z biblioteki typu open source, lepiej umieść ją w pakiecie, który pomoże ci ją znaleźć. Do tej pory nie ma to większego znaczenia, ponieważ z pewnością będziesz mógł google google. Ale 10 lat temu nie było to tak oczywiste.

7

Odwrócona nazwa domeny została użyta, aby uniknąć kolizji nazw w przypadku, gdy różne organizacje używają tych samych nazw klas w swoich bibliotekach. Jest to proste rozwiązanie i off-cource ma pewne wady (np. Co z kolizjami nazw dla klas w tej samej organizacji?).

Nie musisz go używać, jest to konwencja, a nie zasada „zrób lub umrzyj”. Na przykład niektórzy programiści Java nie przestrzegają konwencji Java Code .

Ale rozważ alternatywy. Jak na przykład chciałbyś otrzymać dwie w pełni kwalifikowane nazwy klas dla LogFactory:

a50e8400_e29b_41d4_a716_446655440000.LogFactory
f47ac10b_58cc_4372_a567_0e02b2c3d479.Logfactory

lub

org.apache.commons.logging.LogFactory
com.evilcorp.logging.LogFactory

Tak więc, moim zdaniem, używaj tego, co chcesz, pod warunkiem, że obejmuje to zdrowy rozsądek i uwagę dla użytkowników twojej biblioteki.


4

Kiedy rozpoczynam nowy projekt, zawsze nalegam na wewnętrzną i niezmienną nazwę, którą marketingowcy mogą znać lub nie, ponieważ będzie o niej mowa tylko w kodzie źródłowym. W ten sposób nie muszę się martwić o zmiany nazw projektów i zanieczyszczenie przestrzeni nazw.

Ten scenariusz jest dla mnie odpowiedni, ponieważ kod źródłowy zwykle nie jest ważną częścią produktu, tzn. Projekty są zwykle zamkniętymi źródłowymi, zastrzeżonymi systemami. Jednak w projektach typu open source, w których kod źródłowy jest produktem, może to nie być możliwe.

Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.