roboforum.ru

Технический форум по робототехнике.

число в строку

Все здесь

Re: число в строку

Сообщение =DeaD= » 07 ноя 2010, 11:54

Grem писал(а):Итого 176/54=3,259, т.е. в 3 с четвертью раза медленнее эта "штатная штука", которой грех не воспользоваться. Вот и неэффективность вылезла.

Всегда радовало это "Ваша операция вызываемая раз в году и занимающая 1/1000 секунды в 3 раза медленней, чем моя!" :D
Проект [[Open Robotics]] - Универсальные модули для построения роботов
Аватара пользователя
=DeaD=
 
Сообщения: 24218
Зарегистрирован: 06 окт 2004, 18:01
Откуда: Ебург
прог. языки: C++ / PHP / 1C
ФИО: Антон Ботов

Re: число в строку

Сообщение loid » 07 ноя 2010, 16:19

Michael_K писал(а):Хватит парня учить кодить - пусть учится программировать.
Такую функцию писать - десять минут.

Пожалуйста научите, с радостью послушаю. У меня вопрос по поводу функции itoa, её нет в библиотеке cvavr, если её скопировать из другой версии СИ она будет работать?
Аватара пользователя
loid
 
Сообщения: 349
Зарегистрирован: 16 окт 2007, 11:57
Откуда: Минycинck

Re: число в строку

Сообщение Michael_K » 07 ноя 2010, 16:31

Вреальном железном мире "скопировать" часто не работает. Вы ее понять пробовали, прежде чем копировать?
Аватара пользователя
Michael_K
 
Сообщения: 6028
Зарегистрирован: 07 окт 2009, 00:29
Откуда: СПб

Re: число в строку

Сообщение Romikgy » 07 ноя 2010, 21:20

loid писал(а):
Michael_K писал(а):Хватит парня учить кодить - пусть учится программировать.
Такую функцию писать - десять минут.

Пожалуйста научите, с радостью послушаю. У меня вопрос по поводу функции itoa, её нет в библиотеке cvavr, если её скопировать из другой версии СИ она будет работать?

попробуй ф-цию sprintf .... с параметром "%d"
die Wahrheit ist irgendwo da draußen
Аватара пользователя
Romikgy
 
Сообщения: 750
Зарегистрирован: 15 ноя 2009, 13:37
Откуда: Porto Franco "Odessa"

Re: число в строку

Сообщение ALHIMIK » 07 ноя 2010, 21:53

хм и не одного предложения по разрядного вычитания...
Аватара пользователя
ALHIMIK
 
Сообщения: 997
Зарегистрирован: 05 окт 2008, 14:41
Откуда: СПб
прог. языки: C,Python

Re: число в строку

Сообщение Grem » 08 ноя 2010, 02:11

Angel71 писал(а):компилятор, цикл (как сам в общем, так и в частностях), железо, софт, время

1, 2, 3, 4 - да, и в правду, пока первый цикл закончился - поменялась JVM, конфигурация ноута, но вот софт тут причем? Или если я WoW удалю, то разницы нифига не будет? :D
Время в каком смысле? Днем разницы уже не будет? Или утром наоборот, разница возрастет?
В общем бред, а не признаки. Всегда и все так замеряли время, а тут вы р-раз и всё - нельзя теперь так. Да, немного не точно, но опять же немного.
Всегда радовало это "Ваша операция вызываемая раз в году и занимающая 1/1000 секунды в 3 раза медленней, чем моя!

Если вы используете конкатенацию раз в году, то я искренне за вас рад, а вот когда будут формироваться SQL запросы по 5-10мс... в общем смеется тот, кто смеется последний с премией, а не в очереди на собеседование.
на этом мой флуд здесь заканчивается
"There is nothing better than sliding down snow and flying through the air" (с) Shane McConkey.
Lieber ein Brett am Fuß als eins vorm Kopf, aber lieber ein Brett vorm Kopf als zwei am Fuß.
Аватара пользователя
Grem
 
Сообщения: 1530
Зарегистрирован: 16 май 2009, 12:50
Откуда: Россия
прог. языки: Java, C

Re: число в строку

Сообщение loid » 08 ноя 2010, 04:17

Нет не пробовал. Я в СИ можно сказать начинающий. Многого не знаю.
Аватара пользователя
loid
 
Сообщения: 349
Зарегистрирован: 16 окт 2007, 11:57
Откуда: Минycинck

Re: число в строку

Сообщение Romikgy » 08 ноя 2010, 11:51

ALHIMIK писал(а):хм и не одного предложения по разрядного вычитания...

зачем изобретать лисапед ?....хотя все зависит от возможностей
die Wahrheit ist irgendwo da draußen
Аватара пользователя
Romikgy
 
Сообщения: 750
Зарегистрирован: 15 ноя 2009, 13:37
Откуда: Porto Franco "Odessa"

Re: число в строку

Сообщение boez » 08 ноя 2010, 12:55

Romikgy писал(а):попробуй ф-цию sprintf .... с параметром "%d"

Во, нашелся разумный человек :) Я ручками переводил число в строку только когда писал для 2313, а для атмеги пользовался sprintf. Не знаю как в cvavr, а в arv-libc подключение sprintf отъедает пару килобайт флешки, но один раз, дальше можно пользоваться функцией сколько угодно.
boez
 
Сообщения: 1981
Зарегистрирован: 27 авг 2008, 10:45
Откуда: Харьков
прог. языки: С/С++

Re: число в строку

Сообщение =DeaD= » 08 ноя 2010, 13:02

Grem писал(а):Если вы используете конкатенацию раз в году, то я искренне за вас рад, а вот когда будут формироваться SQL запросы по 5-10мс...

Только сравнивать тогда надо будет "age="+xInt с "age="+Integer.toString(xInt), не так ли? ;)
И это не избавляет от принципа "оптимизируй то, что работает часто, а не всё подряд" :)

А вообще напечатать uint забив на производительность можно алгоритмом а-ля:
Код: Выделить всёРазвернуть
uint val=548;
String res="";
if(val){
  while(val){
    res=(char)(val%10)+res;
    val=val/10;
  };
}else{
  res="0";
};
Проект [[Open Robotics]] - Универсальные модули для построения роботов
Аватара пользователя
=DeaD=
 
Сообщения: 24218
Зарегистрирован: 06 окт 2004, 18:01
Откуда: Ебург
прог. языки: C++ / PHP / 1C
ФИО: Антон Ботов

Re: число в строку

Сообщение Vooon » 08 ноя 2010, 13:10

> когда будут формироваться SQL запросы
Конкатенация Int'ов с SQL? Вставка параметров напрямик?
У вас, там что, в джабе, нет шаблонов для SQL?
Linux user | Firefox user
Аватара пользователя
Vooon
Site Admin
 
Сообщения: 3339
Зарегистрирован: 09 фев 2006, 15:36
Откуда: Москва
Skype: vooon341
прог. языки: Python, C, Bash, JavaScript, C++, PHP
ФИО: Владимир Ермаков

Re: число в строку

Сообщение Виталий » 08 ноя 2010, 14:00

Решите другую задачу.
Дано число (125).
Выведите на экран цифры которые составляют это число в следующем формате:
'one', 'two', 'five'
Все новости о моих проектах http://savethebest.ru
Аватара пользователя
Виталий
 
Сообщения: 2114
Зарегистрирован: 08 окт 2004, 16:43
Откуда: St. Petersburg
Skype: quark-bot
ФИО: Клебан Виталий

Re: число в строку

Сообщение Angel71 » 10 ноя 2010, 02:58

2Grem
признаки/факторы/пункты/... называйте как хотите. вам намек был на самостоятельно изучение направлений, по которым у вас почти нулевые познания в ключе данного вопроса. спешил хотяб полтора часика поспать перед отъездом, похоже слишком лаконично ответил. лады, исправляюсь.
самая большая проблема в вашем тесте - время. т.е. длительность теста (не забывая, что ява вообще не самая идеальная штука для микротестов, по крайней мере до того, как будет изучен сгенерированный компилятором код), а не сарказм в виде времени суток. его явно недостаточно чтоб вообще о чём либо утверждать. увеличив время теста на порядки, можно почти до максимума увеличить точность и спокойно "забить" на всё остальное. а абсолютно точные данные имхо вообще нереально получить (да и глупо это делать для таких вещей). а все, не все... от того, что я быстренько и не понимая нюансов слабаю скрипку, не поможет избежать того, что первый попавшийся музыкант явно захочет разбить это недоразумение об чью-то голову. так и у вас - цикл есть, понимания нет.
Grem писал(а):1, 2, 3, 4 - да, и в правду, пока первый цикл закончился - поменялась JVM, конфигурация ноута

сами взялись утверждать, что "в 3 раза" это "вообще, всегда и везде". :wink: вполне реально, что в других условиях данные будут прямо противоположные и/или на порядки отличаться. в общем случае, один только выбор jit`а, между c1 и c2 может переворачивать всё с ног на голову. это не забывая о том, что сами данные иногда могут влиять на скорость работы алгоритма и чтоб понять, влияет ли в данном случае, нужно разбираться в коде этих 2х реализаций. самих алгоритмов преобразования числа в строку тоже немало, кто сказал, что в другой версии jvm алгоритм будет такой-же?
следующий момент, эт железо. нюанс с точностью и разрешающей способностью таймеров/счётчиков (системного таймера, часы реального времени, регистр счётчик-время,...) на конкретной железке имхо можно забыть, не настолько маленькие интервалы. даже можно забыть, что точность таймера и точность получаемых данных это далеко не одно и тоже. а вот архитектура процессора в виде всяких предсказаний ветвлений, предвыборки данных и инструкций, блоков организации внеочередного и повторного исполнения, кеша, ... кто вам сказал, что jit способен всегда и из любого куска кода создавать машинный код, который будет эффективно выполняться на конкретно взятом проце? современные jit`ы генерируют в общем очень эффективный код, но это в общем, в частностях бывает всё очень печально.
в случае с профилем c1 (очень похоже, что в данном случае именно c1) много требовать явно не стоит - очень поверхностная оптимизация. а так, у другого чел-ка, с другими настройками или другой версией явы легко и непринуждённо может быть произведена и более агрессивная оптимизация кода. очень сложно гарантировать, что цикл не будет преобразован во что-то на подобии
Код: Выделить всёРазвернуть
int i = 999999;
String xStr = "" + xInt;

или в
Код: Выделить всёРазвернуть
int i = 999999;
String xStr = Integer.toString(xInt);

или в
Код: Выделить всёРазвернуть
int i = 999999;
String xStr = "126";

я не за конкретно этот кусок кода, а в общем. ваш код с циклами врядли в подобное преобразует, более вероятно, что при агрессивной оптимизации просто выкинет эти циклы. но гарантировать, что на различных версиях и с различными настройками, всегда всё будет именно так как вы себе понапридумывали и понатестили... анриал. как говориться, небольшой тюнинг настроек и тест легко может начать выдавать диаметрально противоположные данные.
ещё есть момент с различными типами компиляции - синхронный и параллельный. последний в свою очередь, в купе со всякими сборщиками мусора и некоторыми особенностями многозадачности в операционках, тем более на слабом проце (или на ноутовских процах со всевозможными приколами, предназначенных для снижения энергопотребления) вполне может объяснить даже такие тайминги и при выкинутом куске кода с циклами. есть еще такая не всегда приятная штука, как семплирование. и т.д. и т.п. читайте тематическую доку и вникайте. очень доходчиво многие вещи описаны у касперского. по яве полезно заглядывать в jls. так же предостаточно талмутов по оптимизации программ на яве, в некоторых очень подробно рассматриваются вопросы оптимизации, производимые компилятором и проблемы микротестирования. ...
:D а wow можете смело удалить, он похоже реально кому-то мешает. вам даже в голову не пришло (или пришло, но решили сарказмом пострадать?), что софт в данном контексте это в первую очередь ОС, с её многочисленными тонкостями (потоки, квантование, планировщики, приоритеты, переключение контекста, ...) и всеми исполняемыми во время теста процессами (счёт идёт как минимум на десятки, а иногда и на сотни. и хз, какой, когда и насколько повлияет на тест). масенькое обращение к диску, мышкой дёрнули, в jre в фоне что-то выполняется, ... если вы не заметили, в фоне всегда что-то проц грузит. и ничего, кроме внесения погрешностей в "миллисекундных" тестах это не приносит.
П.С. и ни немного неточно, а очень неточно и громадными такими "поправками на ветер".
Аватара пользователя
Angel71
 
Сообщения: 10668
Зарегистрирован: 18 апр 2009, 22:18
Предупреждения: -1

Re: число в строку

Сообщение EIN_ENGEL » 10 ноя 2010, 03:50

itoa в Кодевижине есть.
прицепи stdlib.h к проекту.
Аватара пользователя
EIN_ENGEL
 
Сообщения: 496
Зарегистрирован: 06 янв 2006, 03:02
Откуда: Москва
прог. языки: VHDL, C++, Matlab
ФИО: Павел

Пред.

Вернуться в Свободное общение

Кто сейчас на конференции

Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 4