2009-10-22

Sysinternals Junction

Открыл для себя утилиту Junction от Sysinternals.

http://technet.microsoft.com/en-us/sysinternals/bb896768.aspx
http://download.sysinternals.com/Files/Junction.zip

Замечательная штука!
Для пользователя это полный аналог linux hardlinks.

Lifehack: Минздрав has you Neo

Вчера мне потребовалось купить обычной марганцовки.

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

Я подумал и взломал систему:

В аптеках продаются наборы походных аптечек для «Мамы и ребенка» и «Авто».

В нескольких из них была обнаружена марганцовка.

Я купил самую дешевую аптечку (это оказалась «Мама и ребёнок» - её остальное содержимое в хозяйстве пригодится).


Стоимость аптечки ~ 200 руб., т.е. в несколько раз дороже пакетика марганцовки, но за удовольствие обмануть систему приходится платить.

2009-03-13

Karaoke SelfMade

Как сделать из почти любого mp3 - караоке т.е. только звук без вокалиста:

  1. качаем утилиты http://sox.sf.net и http://www.mpg123.de
  2. достаем их из архива в PATH
  3. sox.exe копируем в play.exe
  4. mpg123 -w имя_файла.wav имя_файла.mp3 - перекодировать имя_файла.mp3 в имя_файла.wav
  5. play имя_файла.wav oops
Где oops:
Out Of Phase Stereo effect. Mixes stereo to twin-mono where each mono channel contains the
difference between the left and right stereo channels. This is sometimes known as the ‘karaoke’
effect as it often has the effect of removing most or all of the vocals from a recording.

2009-01-21

Java идеальна для системного программирования

Копия моего поста http://community.livejournal.com/ru_java/750688.html

Смотрите на мир незашоренными глазами:
Java идеальна для написания системных утилит.
Java действительно прекрасный выбор для системного программирования.

Главное понять, что некоторые различия ОС не обработаны заботливым изготовителем JRE и не поданы на блюдечке, а их потребуется обрабатывать вручную, точно также как это делают в Delphi/C++.

Т.е. отсуствующие в JRE методы реализуете вызовами к ОС (проверяя что за ОС).
  • Стандартный способ JNI: слишком много писать - это как писать в машинном коде.
Как надо:
  • Если надо работать с процедурным API (ex: WinAPI) то есть:
  1. https://jna.dev.java.net/
  2. http://www.jinvoke.com/
  3. http://fivedots.coe.psu.ac.th/~ad/winJava/ (несколько глав книги Windows Programming Using Java - они используют JInvoke, но думаю будет полезно и для JNA и для Linux ;-)
  • Если надо работать с ООП API (ex: COM) то есть:
  1. https://com4j.dev.java.net/
  2. http://jacob-project.sf.net

https://jna.dev.java.net/
JNA provides Java programs easy access to native shared libraries (DLLs on Windows) without writing anything but Java code—no JNI or native code is required. This functionality is comparable to Windows' Platform/Invoke and Python's ctypes. Access is dynamic at runtime without code generation.

JNA allows you to call directly into native functions using natural Java method invocation. The Java call looks just like it does in native code. Most calls require no special handling or configuration; no boilerplate or generated code is required.

The JNA library uses a small native library stub to dynamically invoke native code. The developer uses a Java interface to describe functions and structures in the target native library. This makes it quite easy to take advantage of native platform features without incurring the high overhead of configuring and building JNI code for multiple platforms.

While some attention is paid to performance, correctness and ease of use take priority.


http://www.jinvoke.com/
J/Invoke - easy Java native interoperability

J/Invoke enables Java developers to easily invoke native methods (such as the Win32 API or C-based Windows DLLs and Unix dynamic libraries) with pure Java code.

Unlike error-prone JNI programming that is hard to use and deploy, J/Invoke lets you access native libraries by simply declaring native methods, and calling them from pure Java.

Java programmers can save time, avoid errors and increase productivity by using J/Invoke to

* Call native libraries from pure Java, without using JNI
* Use OS features and APIs (like the Win32 API), not available through Java
* Integrate Java applications with native libraries (Windows DLLs, Mac OS X, Linux and Solaris dynamic libraries)
* Provide Java API for native DLLs or other non-Java libraries

Do all this and more with pure, simple Java - no need to mess with C/C++ programming with error-prone and hard to use JNI, deploying intermediate DLLs, and dealing with parameter conversions between Java and native types.


Q: Хм.. Для меня системное программирование — это программирование систем, возможно операционных!

A:
1) http://www.jnode.org/
Java New Operating System Design Effort.
JNode is a simple to use & install Java operating system for personal use.
It runs on modern devices.
Any java application will run on it, fast & secure!
(open source, LGPL)

2. http://en.wikipedia.org/wiki/JavaOS

3. http://www-jpc.physics.ox.ac.uk/
JPC is an x86 PC emulator written entirely in Java. Open Source!
АААААААААААА111111111111!!!!!!!!!!!!

Researchers at Oxford have built an x86 emulator that runs purely on Java, making it ideal for security researchers who want to analyze and archive viruses, host honeypots and defend themselves against buggy or malicious software without hosing their machines. The JPC also emulates a host of other environments, giving technophiles the ability to play Asteroids and other software that's sat on shelves for years collecting dust.

What's more, JPC will run on any device with a Java virtual machine, so cell phones, set-top boxes and RISC systems are all fair game, according to researchers in the university's physics department, where the project was developed.

"Some might see JPC as part of a nefarious plot by mad scientists who want to harness every last CPU in the world for their research - but we prefer to see JPC as Java-hardened protection against their buggy programs," they say. JPC's Java-based architecture gives it cross-platform capability, the security of running code in the Java sandbox and the flexibility of configuring virtualization platforms and software libraries.

The researchers boast its x86 emulation, at 10 per cent native speed, puts it among the fastest x86 emulators. (Note: an earlier version of this story incorrectly reported JPC emulated other environments.)

Весь креатив в Москве...

Дорога на Абаву


Вероятно с Белорусского вокзала...

2007-11-17

Дешевый межгород с sipnet.ru

Все необходимое для подключения, настройки и контроля находится на страничке http://www.sipnet.ru/

Прежде всего нужно зарегистрироваться:
https://customer.sipnet.ru/cabinet/register
тонкости:
  • нужно заполнять все поля (можно совершенно левой информацией, главное заполнить и запомнить Имя/Логин, Пароль, Электронная почта т.к. туда придет активация и Контрольное число)
  • даты вводятся в формате дд/мм/гггг. Пр: 23/02/2007
После регистрация на указанный email придет письмо с ссылкой для активации (проверка что вы не робот).

После этого вы можете заходить в свой "личный кабинет": справа-внизу на главной странице http://www.sipnet.ru/ есть поля для ввода имени и пароля.

В личном кабинете наверху указан ваш SIP ID - по сути ваш "номер телефона". Например мой: 2983927
На него можно позвонить из других SIP сетей в Internet набрав:
2983927@sipnet.ru
Внимательно запишите его на бумажку т.к. именно его надо указывать для зачисления денег на счет в Евросети.

В личном кабинете идете в раздел: Скачать файлы.
Выбираете SIPpoint (Программный агент для SIPNET). Скачиваете, запускаете для установки.

Запускаете SIPPoint. Заходите в Файл|Параметры.
Вводите ваш SIP-адрес: sipid@sipnet.ru, в моем случае: 2983927@sipnet.ru
Учетное имя: sipid, в моем случае 2983927
Пароль: пароль указанный при регистрации
OK. После чего телефон должен зарегистрироваться на сайте - иконка станет зеленой и в строке статуса будет "В сети".
Переходите на закладку "Телефоны", вводите номер в формате код_страны код_города номер, например: 74951234567 или 79173411111 и звоните, звоните, звоните!

У них идет акция и звонки на стационарные телефоны
Россия, Москва $0.000
Россия, Санкт-Петербург $0.000
На счету сразу есть 1$, но я рекомендую положить туда рублей 100. Иначе иногда в разговор будет вставляться реклама ;-)
Чтобы позвонить другому пользователю SIPNET, например мне, надо набрать его sipid.

Для качественной связи нужна гарнитура (наушники и микрофон) или USB-телефон (продаются в той же Евросети), например такой: http://skypemate.ru/catalogue/?wid=4 .

Если SIPPoint Вас утомит, то есть другие варианты программных телефонов:
http://www.sipnet.ru/orderandpay/software.html

Инструкция по их настройке есть в Internet, но по сути главные параметры там: sipnet.ru, sipid@sipnet.ru и пароль.

PS: не забывайте о том, что голос генерирует довольно большой трафик. Многое зависит от того, куда и с какого телефона Вы звоните. Поэтому рекомендую провести несколько тестовых звонков, чтобы оценить качество и посмотреть какой счет выставит Вам Ваш Internet-провайдер.
Скорее всего, на текущий момент развития Internet в России, качество будет приемлимым, а совокупная стоимость звонка (плата sipnet + плата за трафик) заметно ниже стоимости такого же звонка с городского или мобильного телефона.

Mobile World War!

http://code.google.com/android/

http://www.openhandsetalliance.com/

Blog:
http://android-developers.blogspot.com/2007/11/android-first-week.html

оттуда интересная статья:
http://www.onlamp.com/pub/a/onlamp/2007/11/12/google-calling-inside-the-gphone-sdk.html

http://devphone.com/category/android

Поднимается очень сильный ветер...

2007-10-14

Преимущества Java для разработки server side jobs.

Преимущества:

1. Широко известная возможность Java программ работать на разных платформах БЕЗ ПЕРЕКОМПИЛЯЦИИ.
Т.е. тщательно оттестированная программа, с большой вероятностью (если зависимости от платформы не внес по небрежности сам программист, но это находится и правится)
будет работать везде, где есть эта и выше версия JRE.
С использованием .conf-файлов, можно вынести все платформозависимые части из исходников (ex: пути к shell скриптам, regexp для разбора вывода shell скриптов, etc).
С использованием wrappers, таких как: http://wrapper.tanukisoftware.org/ можно запустить программу как сервис Windows или демон Linux/Solaris/HPUX/etc.

2. Дополнительный уровень абстракции (JVM и байт-код), позволяют меньше беспокоиться о том, что
- сервис “завалит” всю платформу или
- будет найдена уязвимость позволяющая получить права root unsafe коду.
Использование JDBC драйверов написанных полностью на Java, позволяет сократить количество ПО, которое требуется установить на сервер.

3. В отличие от (обычно) монолитного .exe файла, в который слито все, что нужно для работы. Классы Java образуют истинную модульность, позволяя модифицировать (обновлять) небольшие куски приложения, ДИНАМИЧЕСКИ определять что будет загружено и догружать по мере необходимости (в том числе из БД, сети).

4. Для Java существует большое количество функционально богатых широко протестированных библиотек логирования, с возможностью удобно группировать логируемую информацию по категории (обычно полный.путь.к.классу.Класс) и важности (trace, debug, info, warn, error). Без каких-либо изменений в исходном коде, логирование может быть отфильтровано, перенаправлено на консоль, по почте, в syslog, БД, файл, и даже лог windows. Новые библиотеки, такие как http://slf4j.org/ позволяют варьировать фактическую библиотеку логирования на конечной системе и практически до нуля снизить потерю производительности от логирования (параметризованые сообщения и отключение лишних логов).

5. Исключения Java помимо традиционных ТИПА исключения и поясняющего сообщения (message) содержат:
а) полный стек на момент создания исключения (stackTrace), включающий названия классов, методов, исходных файлов и номера строк в них;
б) «причину» (cause) - другое исключение (которое также может содержать cause), которое явилось причиной создания этого, что позволяет не тащить на верхние уровни абстракции низкоуровневые исключения, но при желании иметь возможность детально разобраться в том, что случилось.

6. Наиболее важным достижением (можно сказать уникальным на сегодняшний день) Java можно считать т.н. checked exceptions.
Если Вы встретите того, кто уверяет, что checked exceptions это плохо, смело плюньте ему в глаза.
Для разработки надежных устойчивых приложений checked exceptions полезны чрезвычайно!

Поясню на примере: в простом коде, открывающем соединение к БД, выполняющем запрос и генерирующем по полученным данным файл, порядка 80% строк могут сгенерировать исключения (драйверов БД нет, ошибка подключения к БД, ошибка работы с БД, ошибка работы с файлом и т.д.).
В случае Java и checked exceptions компилятор предупредит Вас обо всех проблемных участках и предложит что-то сделать (игнорировать, передавать наверх в чистом виде, передавать наверх «обернув», обрабатывать), т.е. полученный код сразу, после того как скомпилируется, будет устойчив к большинству ошибок! Это разительно отличается от ситуации, например, в Delphi, где любой вызов стандартной библиотеки, библиотеки логирования, библиотеки доступа к БД и т.д. может закончиться неожиданным исключением. Частично Вы найдете описание генерируемых исключений в документации, частично будете отлавливать в течении длительного времени, в процессе рабочей эксплуатации.

7. Мелкая радость для тех, кто в теме: sleep, wait, join и т.д. можно прервать из другого потока и они сгенерируют InterruptedException. На Delphi у меня была собственная библиотека с наследником Thread и заменой sleep (используя события).

К замеченным недостаткам Java можно отнести:
1. Крайне потребительское отношение к оперативной памяти. Java очень любит память ;-(

2. Меньший объем предложений хостинга в сравнении с PHP и Perl.

p.s.
Мелкие хотелки по синтаксису языка (syntax sugar ;-)
1. is вместо instanceof.

2. Объект as Тип вместо (Тип)объект т.к. приходится почти всегда делать ((Тип)объект).метод.

3. in для любых типов и .. для перечислимых типов, т.е:
чтобы можно было писать if (myStr in ("bla", "БЛА", "BLA", "бла")), if (myInt in (1,5,7..300)),
case 1..300: case 400:.

4. чтобы в switch () case могли участвовать любые объекты, а не только целые и enum.