Сейчас много говорят о языке Go - многие на нем даже что-то пишут, звучат призывы переходить на него. Но я бы не советовал. Я вижу больше евангелизма, чем реальных фактов и сравнений.
Go - это выражение идеологии, согласно которой у программиста нужно отнять все "слишком мощные и опасные" инструменты, чтобы исключить для него возможность выстрелить себе в ногу. Go не способствует полету программистской мысли, вместо этого он вынуждает программиста тратить время на решение проблем, которых в других языках попросту нет.
Go игнорирует весь опыт и успехи языкотворчества последних 30 лет. Отсутствие шаблонов, нормального ООП, перегрузки функций и операторов, арифметики указателей - все это не имеет ничего общего с идеей простоты, о которой любят говорить евангелисты Go. Это реакционизм, желание закрыть глаза и не видеть современных задач, решение которых требует современных инструментов. Язык застрял в 70-х - технологии должны стремиться к простоте, но не к опрощению.
Go использует сборщик мусора. В D он тоже есть, но там можно написать свои собственные шаблонные New и Delete и писать в стиле C++, просто игнорируя сборщик мусора. Если вы попытаетесь сделать что-то подобное в Go, вам будут мешать все силы ада. Линус Торвальдс как-то сказал, что язык не может считаться системным, если он пытается скрыть от программиста механизм выделения памяти ("Any compiler or language that likes to hide things like memory allocations behind your back just isn't a good choice for a kernel"). Он, правда, имел в виду C++, но тем не менее.
В Go неэффективная костыльная совместимость с C. Не знаю, как для других, но для меня C.int и C.char - это вырвиглазный ужас. Я уже не говорю о том, что вызов внешней функции в Go влечет переключение контекстов - учитывая, что ни один нормальный проект не обходится без библиотечных вызовов, тут уж просто без комментариев.
Наконец, Go почему-то не разрешает ставить открывающую операторную скобку на новой строке - это как-то связано с отказом от обязательной точки с запятой в конце утверждения. Для кого-то, наверное, это не проблема - это один из общепринятых стилей, но я лично люблю ставить скобку на новой строке, и не понимаю, почему обязан изменять своей привычке.
Подводя итог: хайп вокруг этого языка мне совершенно не понятен. Я не знаю, в каких именно областях хорош Go - какую ни возьми, везде найдется более подходящий язык. Для игр он точно не подходит. Go обычно позиционируется как современная замена C, но когда заходит речь о реальных задачах, которые решаются при помощи C, евангелисты Go кричат, что они не входят в область применения языка. Так чем же она ограничена, эта область? Консольными утилитами? Если выбирать между Go и C, то я уж лучше выберу C.
Go - это выражение идеологии, согласно которой у программиста нужно отнять все "слишком мощные и опасные" инструменты, чтобы исключить для него возможность выстрелить себе в ногу. Go не способствует полету программистской мысли, вместо этого он вынуждает программиста тратить время на решение проблем, которых в других языках попросту нет.
Go игнорирует весь опыт и успехи языкотворчества последних 30 лет. Отсутствие шаблонов, нормального ООП, перегрузки функций и операторов, арифметики указателей - все это не имеет ничего общего с идеей простоты, о которой любят говорить евангелисты Go. Это реакционизм, желание закрыть глаза и не видеть современных задач, решение которых требует современных инструментов. Язык застрял в 70-х - технологии должны стремиться к простоте, но не к опрощению.
Go использует сборщик мусора. В D он тоже есть, но там можно написать свои собственные шаблонные New и Delete и писать в стиле C++, просто игнорируя сборщик мусора. Если вы попытаетесь сделать что-то подобное в Go, вам будут мешать все силы ада. Линус Торвальдс как-то сказал, что язык не может считаться системным, если он пытается скрыть от программиста механизм выделения памяти ("Any compiler or language that likes to hide things like memory allocations behind your back just isn't a good choice for a kernel"). Он, правда, имел в виду C++, но тем не менее.
В Go неэффективная костыльная совместимость с C. Не знаю, как для других, но для меня C.int и C.char - это вырвиглазный ужас. Я уже не говорю о том, что вызов внешней функции в Go влечет переключение контекстов - учитывая, что ни один нормальный проект не обходится без библиотечных вызовов, тут уж просто без комментариев.
Наконец, Go почему-то не разрешает ставить открывающую операторную скобку на новой строке - это как-то связано с отказом от обязательной точки с запятой в конце утверждения. Для кого-то, наверное, это не проблема - это один из общепринятых стилей, но я лично люблю ставить скобку на новой строке, и не понимаю, почему обязан изменять своей привычке.
Подводя итог: хайп вокруг этого языка мне совершенно не понятен. Я не знаю, в каких именно областях хорош Go - какую ни возьми, везде найдется более подходящий язык. Для игр он точно не подходит. Go обычно позиционируется как современная замена C, но когда заходит речь о реальных задачах, которые решаются при помощи C, евангелисты Go кричат, что они не входят в область применения языка. Так чем же она ограничена, эта область? Консольными утилитами? Если выбирать между Go и C, то я уж лучше выберу C.