Справочник функций

Ваш аккаунт

Войти через: 
Забыли пароль?
Регистрация
Информацию о новых материалах можно получать и без регистрации:

Почтовая рассылка

Подписчиков: -1
Последний выпуск: 19.06.2015

C# глазами Java

Автор: Яков Сироткин
www.telamon.ru

Есть два подхода к сравнению языков программирования: религиозная война и «a нам всё равно». Я постараюсь втиснутся между ними и начну с общего. Ключевой особенностью и Java, и C# является автоматическое управление памятью. Конечно, оба языка из-за этого совершенно не подходят для написания ядра операционной системы, но зато существенно упрощают разработку прикладных программ, потому что:

  • остаётся меньше возможностей для memory leak;
  • не надо писать код для освобождения памяти;
  • можно написать f(g(x)) и не думать об освобождении памяти от результата g(x).

Итак, мы имеем две массовых платформы для разработки программного обеспечения, на каждой из которых работают миллионы программистов; за каждой стоят мировые софтверные гиганты, но ни одна не имеет революционных преимуществ.

Влияние Microsoft

Исторически Java появилась раньше .NET и потихоньку захватывала рынок не только серверного ПО, но и GUI-приложений для корпоративных клиентов, потому что C++ сложноват для рисования формочек, Visual Basic не похож на язык для крутых девелоперов, а Borland инвестировал в Java больше, чем в Delphi.

Но чем больше приложений на Java, тем меньше потребность в Windows, поэтому Microsoft решил не поддерживать Java, а создать .NET, чтобы стимулировать разработку программ для Windows. Кончено, какая-то кроссплатформенность у .NET есть, но, с точки зрения Windows, .NET стремится стать частью операционной системы, как Internet Explorer. Карьера .NET-разработчика предполагает тесные партнёрские отношения с Microsoft, включая использование среды разработки Visual Studio, базы данных MS SQL и системы контроля версий Visual SourceSafe.

Нужно отдать должное маркетингу Microsoft, многие компании предпочитают думать о программном обеспечении не выходя за рамки видения Microsoft. Иногда из-за этого приходится откладывать в сторону любимую Java и брать в руки C#. Хорошая новость в том, что накопленный в Java опыт помогает и в .NET, а развитие .NET стимулирует прогресс Java.

CVS vs. VSS

Большинство Java-разработчиков привыкли к CVS, после этого переход на Visual SourceSafe в сочетании с реализацией интеграции с ним в Visual Studio и концепцией solutions-projects воспринимается весьма болезненно. Справедливости ради стоит отметить, что переход на CVS в большом проекте теоретически возможен, но вызовет крайне негативную реакцию людей, привыкших к VSS.

В этом месте можно было бы немного помахать кулаками на тему «почему CVS лучше VSS», но я этого делать не буду, потому что CVS тоже не идеален, и есть такой проект как Subversion, который открыто позиционируется в качестве замены CVS. Microsoft тоже не считает VSS своим флагманским продуктом и готовит ему замену в виде Visual Studio 2005 Team System.

Влияние VB.NET

Программы на многих языках могут быть скомпилированы в байт-код для JVM, но практически абсолютно всё программное обеспечение для платформы Java написано именно на Java. Для .NET примерно с равной вероятностью проект может разрабатываться как на C#, так и на VB.NET, причём очень часто используются сразу оба языка.

Понятно, что C# и VB.NET практически не имеют между собой отличий, кроме синтаксиса, но вносят раздробленность в сообщество разработчиков. Даже если использовать только на C#, то в результатах поиска по документации всегда будут путаться материалы, относящиеся к VB.NET. В десктоп-версии MSDN можно настроить фильтр по языку программирования, но всё равно, на мой вкус, документация по Java значительно удобней и понятней.

Разработка GUI

Разработка GUI на C# являет типичным примером RAD, как Delphi. На Java GUI, как правило, делается при помощи Swing. Хотя Swing весьма объёмен и сложен, хорошая продуманность и расширяемость архитектуры в сочетании с доступными исходными кодами позволяет разрабатывать GUI любой сложности.

Разработка веб-приложений

Я съел собаку на разработке веб-приложений на Java, но никогда не использовал ASP.NET; тем не менее, я вполне допускаю, что ASP.NET имеет определённые и весьма существенные преимущества при создании небольших сайтов. Однако, эти преимущества выделяют веб-приложения в отдельный сегмент, очень многие .NET-разработчики специализируются либо только на GUI, либо только на веб. На Java веб-приложения можно создавать без использования каких-либо специфических технологий вроде JSP, JSTL или Struts: extends HttpServlet — и вперёд!

Конечно, рынок разработки сайтов Java без боя не отдаст, можно ожидать новостей от JavaServer Faces или от Fabrique. В любом случае, делать веб-странички — это не самый сложный класс задач для современных языков программирования.

Is everything object?

В Java очень популярен лозунг "Everything is object", в C# это не так. Первое, что бросается в глаза — наличие структур в C#. Очевидно, что есть мотивы использовать структуры для повышения производительности, но мне кажется, что современные компьютеры достаточно производительны, чтобы не добавлять ещё одну сущность в язык.

Также, вместо анонимных классов в C# используются делегаты, это такая идея о том, что если у метода есть определённый набор аргументов и заданный тип возвращаемого значения, то совершенно не важно, как он называется, является ли он статическим и прочие глупости — можно его дёргать.

Если уж зашла речь о delegate, то нужно упомянуть и об event — они действительно сокращают размер кода при разработке GUI, хотя и ценой отступления от идей ООП.

В определённой степени C# менее лаконичен, не вдаваясь в подробности, ограничусь упоминанием ключевых слов virtual, override, ref, out и param, не имеющих аналогов в Java.

Влияние платформы на самосознание программистов

Безусловно, больше всего на качество программного обеспечения влияет качество самих разработчиков, а не язык программирования. Тем не менее, мой опыт говорит о том, что в подавляющем большинстве проектов на Java для build management используется Ant, а в .NET очень часто билды делаются встроенными средствами Visual Studio, хотя аналогичные инструменты существуют и для .NET. Кроме этого, в C# нет чётких правил наименования классов и их размещения на диске, что часто вносит дополнительную путаницу (конечно, квалифицированные программисты успешно борются с этой проблемой).

В С# нет checked exceptions, есть даже объяснение почему. Такое решение имеет свои резоны, но если компилятор не контролирует обработку checked exception, то нужно больше рассказывать об обработке ошибок через другие коммуникационные каналы, иначе появятся программисты, которые вообще не будут знать, что такое exception.

Тигры рвутся вперёд

Есть области, в которых Java доминирует безусловно, например, игры для мобильных телефонов или технология JavaCard. Однако, борьба между C# и Java за долю на рынке будет идти ещё долго, обе платформы будут совершенствоваться, например, в Java 5 и .NET 2.0 появится поддержка generics.

Очевидно, что успех каждого конкретного проекта зависит не от языка программирования, а от понимания задачи, умения давать методам понятные названия, способности избегать дублирования кода и других общечеловеческих ценностей.

Благодарности

Огромное спасибо Дмитрию Жемерову, благодаря которому вам не пришлось читать всю ту ерунду, которую я написал сначала, компании DataArt, которая дала мне возможность заниматься изучением C# в рабочее время, коллегам из компании DataArt, которые оказывали мне интеллектуальную и моральную поддержку, а также компании JetBrains, которая очень вовремя начала делать ReSharper, который позволяет получать на C# многие виды удовольствия, привычные пользователям IntelliJ IDEA. Особая благодарность Алексею Пчелинцеву за заботу о букве Ё.

Ссылки

  1. The C# Programming Language for Java Developers
  2. J2EE fundamentals for .NET developers

Оставить комментарий

Комментарий:
можно использовать BB-коды
Максимальная длина комментария - 4000 символов.
 

Комментарии

1.
57K
25 января 2010 года
zheka001
0 / / 25.01.2010
+3 / -2
Мне нравитсяМне не нравится
25 января 2010, 13:37:57
Alex / 10 февраля 2006, 11:14:03 Почему тогда в Java нельзя наследовать строки?
Потому что класс String в java - терминальный, чтобы их обезопасить от таких как ты.
"Ограничений по работе с примитивными типами в Java гараздо больше чем в C#.". Не знаю в чем там ограничения, но если не устраивают простые, то в java есть интерфейсные типы (не путать с интерфесами), те же что и простые только они уже классы
1.1.
94K
15 октября 2014 года
probefx
0 / / 15.10.2014
+5 / -11
Мне нравитсяМне не нравится
15 октября 2014, 20:05:33
Вот почему Джава такой отстой, сразу не могу понять никак, непрофессиональная разработка, бейсикоподобный язык. Че тут сравнивать и скорость работы маленькая.
2.
57K
25 января 2010 года
zheka001
0 / / 25.01.2010
+0 / -4
Мне нравитсяМне не нравится
25 января 2010, 13:30:39
ap3rus fascinating! Aren't you clever?
3.
25K
06 января 2007 года
ap3rus
0 / / 06.01.2007
+10 / -7
Мне нравитсяМне не нравится
24 мая 2007, 12:40:45
Saying that Java is nice because it works on all OS's is like saying that anal sex is nice because it works on all genders (c)
3.1.
94K
15 октября 2014 года
probefx
0 / / 15.10.2014
+5 / -4
Мне нравитсяМне не нравится
15 октября 2014, 20:06:09
русские кривляются по английски. да фуфло джава фуфло
4.
29K
21 апреля 2007 года
il!
0 / / 21.04.2007
+2 / -3
Мне нравитсяМне не нравится
21 апреля 2007, 23:57:57
"приходится откладывать в сторону любимую Java" - с любимыми не расставайтесь... :)
Яков, ощущение, что вы поверхностно знакомы с .Net
Больше ни слова - меня тошнит от воин и я тоже люблю старушку
4.1.
94K
15 октября 2014 года
probefx
0 / / 15.10.2014
+0 / -6
Мне нравитсяМне не нравится
15 октября 2014, 20:06:56
и че хоть такого прекрасного в джава? просвятите, мандроид?
5.
Аноним
+3 / -4
Мне нравитсяМне не нравится
10 февраля 2006, 11:14:03
М-да... Более предубежденной статьи я еще не видал. На ASP.NET в 100 раз удобнее разрабатываеть web-приложения. Советую автрору статьи прежде чем делать замечания из разряда "ASP.NET имеет определённые и весьма существенные преимущества при создании небольших сайтов" приводить примеры проблем, которые появляются при разработке "больших" сайтов на ASP.NET. Если необходимо быстро стартовать какой-нибудь проект Java сильно уступает. Компания, не успевшая сделать свой "пилот", проигрывает и теряет заказ. Что может быть хуже?

PS: "Everything is object?" ну это вообще... Почему тогда в Java нельзя наследовать строки? Ограничений по работе с примитивными типами в Java гараздо больше чем в C#.
6.
Аноним
+2 / -2
Мне нравитсяМне не нравится
8 мая 2005, 20:42:23
Я написал вторую версию статьи C# глазами Java:)
http://www.telamon.ru/articles/csharpfromjava.html
7.
Аноним
+1 / -3
Мне нравитсяМне не нравится
15 апреля 2005, 20:02:25
<blockquote><small>Цитата:<hr size=1>... я вполне допускаю, что ASP.NET имеет определённые и весьма существенные преимущества...[/quote]

ИМХО, нет. Преимущество, однозначно, за сервлетами и JSP.
8.
Аноним
+2 / -3
Мне нравитсяМне не нравится
20 марта 2005, 19:06:11
Первое, что бросается в глаза — наличие структур в C#.

Хм.. Структуры тоже унаследованы от System.Object. Но они являются ValueObject.
В C# int i; - i есть Объект, в Java же нет.
Реклама на сайте | Обмен ссылками | Ссылки | Экспорт (RSS) | Контакты
Добавить статью | Добавить исходник | Добавить хостинг-провайдера | Добавить сайт в каталог