Вместо шапки — https://github.com/sosachbot/cppthreadhat/wikiОтветы на все вопросы — http://en.cppreference.com/w/ http://www.cplusplus.com/reference/Прошлый — >>1081237 (OP)
>>1085579 (OP)Ты перепутал ОПпик.
>>1085581Проверь у себя за щекой.
>>1085582
>>1085634Это тебя мы хуями в прошлом треде крыли? Ты на впоросы так и не ответил
>>1085634Двачую. Петушиный угол. Хуже только JS тред.
>>1085581Вот исправленная версия>>1085662>>1085634>Эта жопная боль
>>1085668Гордится, что пишет на шаблонной параше, с недоразвитым ООП.Когда языки типа Lisp и Smalltalk умели все это намного лучше еще 50 лет назад.
>>1085668О, следующий оп-пик
>>1085668Охуеть, макака на pure c наезжает. Совсем охуела? Тебя в детстве мало пиздили?
>>1085696>pure c Ебать говноед
>>1085696Ещё один le maquaque лурочки обчитался.
>>1085783>>1085788Ты че зашквареный питушара тут раскукарекался? Иди говно за своими шаблонами чисти блять.Объебок ПТУшный.
>>1085798Чтобы твоё сообщение стало по-настоящему унизительным и оскорбительным, тебе надо всего лишь приложить свой гитхаб, чтобы мы оценили твой кругозор. Давай, покажи, что заставит нас заплакать. Мы ждём.
Вообще зря вы так. У С++ есть одна полезная функция: Он показывает, каким не должен быть хороший язык программирования. Это как бы такое воплощение всех антипаттернов в одном месте.
>>1085820>Он показывает, каким не должен быть хороший язык программирования.>Это как бы такое воплощение всех антипаттернов в одном местеТы путаешь с PHP.
>>1085820>>1085798Шел третий тред, неосиляторы продолжали рваться.
>>1085829PHP даже в этом (весьма незавидном) качестве сосет у других языков; в частности - у С++.
>>1085829>с PHPhttp://hacklang.org/
>>1085833>Постит с анимеговном>Думает, что его мнение кто-то воспримет всерьез.
>>1085839>униженный пыходаун продолжает рваться>ВАШЕ МНЕНИЕ НЕВАЖНА МОЕ ВАЖНА
>>1085836https://eev.ee/blog/2012/04/09/php-a-fractal-of-bad-design/
>>1085675Тем временем, диваны тактично сманяврировали и проигнорили, как их облили говном с ног до головы двумя простыми фактами.inb4:>РЯЯЯЯЯЯЯЯ СКОРАСТЬНу ты же один хуй напишешь говно, которое будет по скорости уступать любому скрипту на лиспе.А если ты и вправду нуждаешься в скорости есть С.
>>1085843https://tnx.nl/php.html
>>1085803У меня NDA.
комментим?https://www.stack.nl/~dimitri/doxygen/manual/docblocks.html
Плюсач, как мне написать функцию типа шарповской double.tryParse(string, out double), чтобы в случае успеха давала число в out, а в случае ошибки парсинга - false? Без clr и буста.
>>1086563ты хочешь узнать как она устроена?
Этот тред зашквареный, тот кто пишет без сажи тоже шкварится, так что не советую тут спрашивать.Ну так уж и быть, помогу ньюфане.http://en.cppreference.com/w/cpp/string/basic_string/stolделаешь свою функцию, обертываешь std::stoi в трай-катч и все.
>>1086563http://coliru.stacked-crooked.com/a/daa02fc1bc8e71f5
>>1085579 (OP)Почему в С++ так мало метапрограммирования? Надо добавить больше, чтобы можно было метапрограммировать во время метапрограммирования:http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2017/p0707r2.pdf
>>1086684Саттер выглядит самым охуенным из всей коммитетской пиздобратии.
>>1086684Понимаешь, с++ это такая помойка в которую отрыгивают все самые безумные идеи, а на разработчиках с++ тестируют их как на подопытных кроликах.
>>1086703Это как раз очень здравая идея, в D работает на ура. Уж точно лучше того каличного варианта рефлекшена на шаблонах, который до этого предлагали.
>>1086703может специально в новые стандарты добавляют максимум наркомании чтобы повысить порог вхождения чтобы меньше говнокода было
>>1085668Давай так лучше
>>1086563Им дали манады optional: используй, нет хочу через аргумент возвращать значение.
>>1085579 (OP)Сначала прочитать липпмана, а потом седжвика по алгоритмам, или читать все параллельно?
>>1086644Хуита.[CODE]double kek = 0; if (tryParse("31-11", kek)) { std::cout<<kek; }[/CODE]Результат 31, шарповский tryparse тут даёт false. Если я буду писать какой-нибудь парсер, то здесь сломаюсь, зачем мне это тут
>>1086634Да, и хочу написать с/с++ функцию, которая работает точно так же.
>>1086563>Плюсач, как мне написать функцию типа шарповской double.tryParse(string, out double)Посмотреть на код этой функции и переписать на C++.
>>1086936Открытый дотнет как-то некрасиво выглядит
На чем там можно быстро набросать интерфейс для лабы? Препод говорит о cli/clr, но при использовании этой штуки у меня ломается iostream и fstream, потому что они переопределяются где-то внутри cli библиотек. При использовании Qt нужно носить с собой штук пять dll по пять мегабайт каждая и подключать сигналы к слотам, подключать еще раз, слоты сами по себе не заработают. GTK на хуй похож.
Есть класс, есть конструктор, принимающий как аргумент std::string. Если я оберну код в try/catch, сделаю условие, при невыполнении которого делаю throw, объект будет создан, или нет?Допустим, если в строке есть буква j, объект не будет создан. Так можно сделать?капча 843843
>>1086974Имею ввиду проверку прямо внутри конструктора.
>>1086975Объект будет создан
>>1086976Допустим, есть у меня// ...Base("xyu");Base ("pizda");// ...Можно ли как-то не создавать второй объект, ведь там присутствует 'z', или лббая другая хуйня? Или нужно думать, как сделать без этой ебли?
>>1086974нет нельзя. раз конструктор вызван - объект создан. и вообще бросать исключения в к-ре это зашквар
>>1086974> Допустим, если в строке есть буква j, объект не будет создан. Так можно сделать?Да. Объект считается созданным только при успешном завершении работы конструктора.Бросай исключение и твой объект не создастся.>>1086980>раз конструктор вызван - объект создан.Иди нахуй.> и вообще бросать исключения в к-ре это зашкварИди нахуй — 2.
>>1086983двачую адеквата
Суп. Надо разобраться в небольшом С++ проекте. Работаю в пердоликсе. Слышал, есть средства для автоматического построения UML диаграмм. Какую программку скочать, чтобы было легко построить диаграмму без регистрации и смс? Например, AutoDia - годна?
>>1086973>GTK на хуй похож.это значит что ты пидор
Есть проект, в нём в интерфейсе метод объявлен public'ом, но во всей последующей цепочке реализазующих классов этот же метод уже protected, соответственно и вызвать его можно только через указатель на интерфейс (так он, в общем, и используется).Это паттерн такой или самодеятельность писателей? Просто первый раз увидел пободное в этом проекте (да и вообще), куча всего другого спокойно в публиках реализует интерфейсы.
Подскажите долбаебу, почему такая разница?ideone.com/DLFyvU
>>1087115Оператори индексирования (subscript) у вектора ( [ ] ) равнозначен аналогичному оператору у обычного указателя и не модифицирует внутреннее состояние/не проверяет границы.
Надо написать функцию, которая будет возвращать некий тип данных dtype. Но бывают случаи, когда возвращать нечего.Если M={множество возможных возвращаемых значений} является подмножеством множества всех значений типа dtype, при возникновении ошибки можно возвратить значение, не входящее в M. Ну там вернуть nullptr, если обычно функция возвращает указатель на что-то, или вернуть -1, если нормальное возвращаемое значение - неотрицательный int. Что делать, если у меня возвращаемый тип dtype - это класс или структура? Сделать функцию выбрасывающей исключение, если возвращать "нормально" нечего?
>>1087071cpp2dia, но вообще в виду наличия шаблонов лямбд и прочего говна генерация UML по крестам не сильно хорошая затея.
>>1087120Ну, как вариант:template<typename T>static T <star> bad_value() {static T _bad_value ;return &_bad_value;}
На каком этапе изучения крестов стоит переходить к стандарту?
Думаю, в случае с С++ не стоит его дальше развивать вообще — слишком много унаследованных проблем. Вместо этого комитету стоило бы создать рабочую группу по разработке принципиально нового языка, базирующегося на классическом си-подобном синтаксисе и включающем все лучшее из С++, C#, D, Go, Rust, Swift и некоторых других языков. И предусмотреть некий стандартизированный механизм взаимодействия кода на двух языках — чтобы можно было переходить постепенно, добавляя в старые проекты на С++ новые файлы с кодом на новом языке.Вот такое решение было бы пожалуй оптимальным — с одной стороны и "совмесимость" в каком-то виде осталась бы, с другой — можно все написать с нуля, учтя ошибки прошлого.
>>1087120boost::optionalСкоро (C++17) его и в стандарт внесут.
>>1087169Еще один.>комитету стоило бы создатьУказывать другим это так мило. А главное жопу от дивана отрывать не нужно.
>>1087175>Скоро (C++17)Ты обосрался, жди C++20, C++17 уже выпустили
>>1087179Людям нужен новый язык, совмещающий в себе простоту C# или Java, и производительность Си. Но, нет, мы будем выпускать одно и то же говно с новыми слоями каждые 3 года вместо того.
>>1087182>Людям нужен новый языкc хуяли? это как каждые полгода нужен новый телефон? хипстеры неосиляторы блять. языки, которым десятки лет, им сложна. им нужно новые.
>>1087199>c хуяли?Потому что размеры стандарта С++ стали уже намного больше, чем может выучить человек за свою жизнь. Обычный человек в принципе уже не может осилить С++
Бля, решил посмотреть курс по плюсам на степике, оказалась такая параша. Лектор заикается и запинается чуть ли не каждую минуту, постоянные паузы. Такое чувство, что чел не знает ничего о программирование и крестах, а просто пытается пересказать заученный текст, ничего не понимая. Лучше книжки липпмана еще ничего не придумали, все курсы это хуйня
Суп, читаю статью https://habrahabr.ru/post/157961/Там такой код:template<typename T>class Widget { ... Widget(Widget&& rhs); // тип rhs - rvalue ссылка, ... // но rhs является lvalue};С таким комментарием:>В конструкторе Widget rhs является rvalue ссылкой, так что мы знаем, что оно связано с rvalue (т.е. было передано rvalue), но само rhs является lvalue, поэтому мы должны преобразовать его обратно в rvalue, если мы хотим получить преимущества от того, что rhs связано с rvalue.В первом выделенном жирным участке вроде как должно быть "тип rhs является rvalue ссылкой"? Или так и должно быть?
>>1087203Ты теоретик мамин что ли.Нахуй учить ВСЕ? Я пишу на чем необоходимо в данный момент. Или, если есть выбор, на чем удобнее для данной задачи. И только теми фичами языка пользуюсь, который мне в данный момент нужны. И могу забыть а потом снова вспомнить. Главное что концепции в голове есть. Остальное все хуйня. А еще я бы убивал пидорасов, которым прямо НЕОБХОДИМО что-то новенькое, типо жабы 8-й, чтобы красиво получалось, модненько. Но java оффтопик конечно, но вы поняли. Все уже давно написано, хватит изобретать хуйню, работайте лучше.
Антуаны, если у меня есть ожидание condition_variable, то в другом потоке надо сначала разлочить мютекс, а потом кинуть нотифай или не? Типа такого:void thread1() {...cnd.wait(lk, checker);...}void thread2() {unique_lock lk(mtx);...lk.unlock(); // надо анлочить или пох?cnd.notify_one();}Если конкретней, то у меня очередь ивентов, вставка в неё сигналит ждущему потоку, что бы тот обработал очередной ивент.
>>1087203>размеры стандарта С++ стали уже намного большеА читается он намного легче, чем стандарт C.Где в стандарте C чему-то посвящено одно предложение и потом думай-гадай как оно связано и взаимодействует с другими частями языка, в стандарте C++ расписано на пару параграфов с examples и notes.
>>1087222Если говорится про ссылку, то ясно, что речь о типе.
>>1087280unique_lock сам разлочит
>>1087286В смысле в деструкторе.
>>1087286Ну что он разлочит я знаю, я именно про момент с нотифаем интересуюсь. Нет ли такой хуйни, что ты сиглалишь, в этот момент просыпаеться второй поток, смотрит что мютекс залочен и засыпает вновь. В итоге нотифай просран.
>>1087123>>1087175А возвращать вместо одного элемента структуры пару из этого элемента и bool значения не комильфо? Ну то есть если это bool-значение равно false, то это как раз будет значить, что "нормального" элемента, чтобы возвратить, не нашлось?
>>1087315Тоже вариант.
>>1087311Нет такой хуйни.
>>1087311http://eel.is/c++draft/thread.condition#condvar-10
Когда передача аргументов в функцию по ссылке оправдывает себя, и почему я не могу делать это во всех функциях, где аргумент не должен меняться? Мне кажется, что type &var быстрее хотя бы потому, что не вызывает копирующий конструктор
>>1087350>>1087352Пасиб, плюсаны.
>>1087361>плюсаны
Крестаны, хочу в качестве доклада на C++ Russia 2018 подготовить охуенный обзор Folly. Как вы думаете, за час времени лучше выбрать несколько киллер-фич, и про них рассказать, или наоборот, по слайдику на фичу, и дохера фич просто рассказать что они есть?
Вы мне объясните, можно на C++ написать прогу, которая будет определять движок сайта, заходить в админку и пытаться брутить простыми паролями? Или лучше в python с таким вкатиться?
>>1087380да
>>1086919>шарповский tryparse тут даёт false. Ёбт, откуда я знаю, что шарп выдаёт? Затюнь сам. Тебе нужно, чтобы прочитана была вся строка? Используй gcount().>>1086927Тогда прочитай документ в котором она описана, блядь.>>1086973>и подключать сигналы к слотам,Что ещё ты хотел в императивном языке?>>1086974> объект будет создан, или нет?Нет, и весь код размотается до следующего уровня catch с вызовом всех деструкторов в обратном порядке.>>1086977Можно. Вопрос только в "нахуя".>>1087082Нужно больше примеров, тогда можно будет понять, зачем так сделано. Это нужно для того, чтобы код, использующий интерфейс, нигде не зависел от реализаций.>>1087115reserve не меняет число элементов, это делает resize. Обращение к элементу не раздвигает массив до этого элемента.>>1087120>Что делать, если у меня возвращаемый тип dtype - это класс или структура? Сделать функцию выбрасывающей исключение, если возвращать "нормально" нечего? Либо возвращать костылём наподобие std::variant или optional, либо предусмотреть в dtype специальный буль empty.>>1087159Каждый раз, когда тебе что-то непонятно, кроме ответов на свои вопросы читай и кусок стандарта, в котором это описано.>>1087182>Людям нужен новый языкГораздо больше, чем новый язык, людям нужно использовать многолетние наработки.>>1087222Когда ты говоришь "тип" ты подразумеваешь всё, кроме звёздочки и амперсандов. Ссылка на тип, указатель на тип и т.д. Пример:int a, &b=a;Тип общий, а сущности разные: объект и ссылка на объект.>>1087380Можно, но в питоне это будет выглядеть короче. Нужно ли ради этого "вкатываться" в питон? Сам думай.
Друзья, появилось желание конкретно вкатиться в Айти. Заинтересовался геймдевом и созданием приложений под десктоп. Выбор пал на C++. Когда учился в колледже, то изучал Pascal и Delphi 3 курса(печально). И на последнем курсом мимокроком брали Java, но не изучали толком. Так вот, у меня вопрос, есть ли смысл вкатываться сразу в кресты? Просто некоторые советуют с чистой сишки начинать всё изучение. Или вообще другие мне советуют питон как первый серьёзный язык...
>>1087413>Это нужно для того, чтобы код, использующий интерфейс, нигде не зависел от реализаций.Для этого интерфейс и есть, да, тут вопросов нет. Но забрасывание метода в protected/private в реализациях к этому никак не относится же.>Нужно больше примеров, тогда можно будет понять, зачем так сделано. А больше нет, в том-то и дело, пока лишь в одном месте (из многих десятков встретил). Потому и спросил, собственно, может кто сталкивался. Просто напрямую к реализации всё равно никто не обращается, на то интерфейсы и есть, а делать какую-то дополнительную "защиту" от дурака, ну, не знаю, довольно бесполезная штука, на мой взгляд.При этом по гайдлайнам protected у нас вообще рекомендуется не использовать, лол.
Анончики. Я уже не знаю, что делать. Нужно принять функцию вида T()(Args...) или T(SomeClass::)(Args...) и превратить её в std::function<std::string(std::string...)>. Все работает для функций объектов, для свободных функций и для std::function<T(Args...)>, но проблема в том, что для каждого из этих случаев мне приходится писать новый вариант шаблона, а вместе с ним еще две вспомогательные функции, для случая где T=void и T!=void. Но при этом в случае для std::function и свободных функций, код полностью совпадает.А теперь вопрос: Можно ли обойтись одним шаблоном? Хотя бы для свободных функций, function и bind.
Сап. В функции типа:int foo(){ std::list<int> lis[777]; // единственная переменная //маняпуляции с числами return lis[42];}Какбэ по ходу действия, сначала значение lis[42] будет положено в стек, а потом место в памяти, выделенное под lis, будет помечено как пустое, так ведь (то есть утечки памяти не будет)?
>>1087463С одним стеком утечку памяти не сделать, по определению. Всё, что бы в функции создано, будет в конце удалено, включая указатели на вручную аллоцированную память, и вот только тут и могут быть утечки.
https://pastebin.com/enFv8CFCя не прошу сделать за меня просто помочь скомпилироватьи да я знаю что недоделано
>>1087484Почему нельзя было не обосраться?https://pastebin.com/g2RTX0kc
>>1087484У тебя объявления функций не совпадают с определениями. Надо все исправлять
Как в VS17 отключить использование Precompiled Header??Жутко горит с того, что в инете есть иструкции 5ти летней давности типа:(ALT + F7) > Configuration Properties > C/C++ > Precompiled Headers > Create/Use Precompiled Header : Not Using Precompiled HeadersА в VS17 такого пункта нет , честно.
>>1087491пример с лабыhttps://pastebin.com/wBtT15VXто есть этот пример с ошибкой?значит я должен в каждой функции менять тип переменных на void .ну ладно понятно
спасибо
>>1087495В идеале main.cpp и реализации твоих глобальных функций нужно разнести по разным файлам, а не лепить всё в один.А если уж ты пишешь всё в одном, реализация функции должна быть до того, как ты ею пользуешься
>>1087495нет, ты объявляешь много функций void vivod, но в объявлении у тебя одни параметры, а в определении - другие. Исправь в объявлении параметры на те, которые у тебя в определении, иначе будет ошибка линковщика
>>1087495Есть ты объявил функцию (называется сигнатура) какvoid vivod(int a[], int b);То и её определение должно быть точно таким же:void vivod(int a[], int b) { a+b}(Названия a и b могут не совпадать, но это потом уже узнаешь.)У тебя же объявлены функцииvoid vivod1(int a[], int b);А определены ужеvoid vivod1(int a[], int b, int c, int d){}Ни на какие void'ы ничего менять не надо, откуда ты это вообще взял. Тебе нужно поменять объявление функций, чтобы оно имело ту же сигнатуру, что и определение. Об этом >>1087491 и >>1087504 говорят.Ну и main должен int возвращать, компилятор прямым текстом об этом сообщает.
>>1087413>Когда ты говоришь "тип" ты подразумеваешь всё, кроме звёздочки и амперсандов.Потому что ты так скозал?
>>1087450> Так вот, у меня вопрос, есть ли смысл вкатываться сразу в кресты?SICP потом С потом кресты.>>1087589См. simple-declaration вhttp://eel.is/c++draft/gram.dclСсылка - это квалификатор.http://eel.is/c++draft/dcl.ptr#1Указатель - часть типа.>>1087453MCVE в студию.>>1087484Сообщение сам прочитать можешь хоть?>>1087492https://www.google.ru/search?q=vs2017+precompiled+header
>>1087644>MCVE в студию.Забавно, я наоборот хотел вдаваться в детали, что бы анончики, если у кого вдруг случалось, вспомнили из своего опыта схожую ситуацию. Ну а так вот что у меня получилось.https://pastebin.com/eaZa2VEfНужен шаблон, которые бы свернул, как минимум два последних в один, а как максимум еще и первый, и что бы еще принимал результат std::bind.У меня дальше по коду эти шаблоны сварачиваются в один при помощиtemplate<typename... Args>bool RegisterFunction(std::string Funcname, OBJTYPE ReturnType, Args... Functhigns){auto& Fnc = FomralizeFunction(Functhigns...);//return something.}Но std::bind так и не поддерживается, да и в целом это не очень красиво.
>>1087660>хотел не вдаваться в детали
Можно ли объявить std::vector<int> и const, и static одновременно?Допустим, у меня естьhttps://wandbox.org/permlink/jvR26xEti4e1dyw4Хочу вынести в отдельную структуру переменные, а потом их использовать. Внутри класса использовал static, чтобы не было привязки к экземпляру, но методом можно было пользоваться внутри его. Короче, есть куча методов в классе, void B(), std::vector<short> C, ... Z(), и мне в каждом нужно объявлять пустой, или непустой вектор. Как сделать всё максимально удобно, или забить хуй и тупо в лоб инициализировать? Эта вся хуйня не компилируется, понятно, почему. потому что я долбоёб
>>1087675Простите, сажа слу363о прилипла.
>>1087675Так, бля. Такая затея лучше?https://wandbox.org/permlink/HnsTyQfJAlaAS7TS
>>1087644>См. simple-declaration в>http://eel.is/c++draft/gram.dclПосмотрел. И?>Ссылка - это квалификатор.Это ты увидел слово ref-qualifier и сделал такой вывод?>http://eel.is/c++draft/dcl.ptr#1>Указатель - часть типа.Часть какого типа?
>>1087680Ты же в итоге все равно этот вектор копируешь, не так ли? Заччем тогда его вообще выносить? Или тебе просто лень каждый раз писать?В общем если это так и ты просто хотел сделать приватные статические константные вектора, то вот они.
>>1087450>Друзья, появилось желание конкретно вкатиться в Айти. Заинтересовался геймдевом и созданием приложений под десктоп. Выбор пал на C++Зря. Иди качай Unity/UnrealEngine, изучай его и по мере необходимости изучай плюсы/шарп. Полноценное изучение плюсов тебя к цели не приведет
>>1087660И всё равно я, блядь, не понял, в каком месте твоих шаблонов будет больше трёх.> как минимум два последних в один,1) Вторая перегрузка лишняя, ведь функция конвертится в std::function неявно, и результат bind такая перегрузка должна принимать по той же причине.2) Первая перегрузка выражается через третью с помощью bind.>но проблема в том, что для каждого из этих случаев мне приходится писать новый вариант шаблонаНихуя не понял. У тебя всего три перегрузки, это много? Что значит "писать новый вариант"? Чем эта надобность вызвана? Код ни о чём не говорит.>>1087700http://eel.is/c++draft/dcl.init.ref#1Окладно, забей.>>1087222>В первом выделенном жирным участке вроде как должно быть "тип rhs является rvalue ссылкой"? Или так и должно быть? Тип определяет все видимые во время компиляции свойства объекта, так что "X имеет тип Y" и "X является Y" полностью взаимозаменяемо.
>>1087719Да, лень писать. Спасибо.
>>1087729>Вторая перегрузка лишняя, ведь функция конвертится в std::function неявно, и результат bind такая перегрузка должна принимать по той же причине.При инстанцировании шаблона, тип создается именно такой, какой был передан. Иными словами если у тебя естьtemplate<typename T>void Fnc(T param);template<>void Fnc(std::string str){printf("%s", str.c_str());}Напишешь Fnc(std::string("Val")); Будет выведено Val; Напишешь Fnc("Val"); Компилятор скажет, что не может найти вариант шаблона под const char*В случае с шаблонами ничего ни во что не переводится.
>>1087729>http://eel.is/c++draft/dcl.init.ref#1Ссылки надо инициализировать — вот это новость!> Окладно, забей.Чому?
>>1087732У борды проблемы с pastebin или это я такой тупой и забыл дать ссылку?https://pastebin.com/w7CYfE2c
https://wandbox.org/permlink/Unybdy7Juz7930yqЧто делает данный код?
>>1087767Содержит UB.
>>1087767Переводит комп в режим отопления помещения?Отрубить бы автору руки за такой говнокод. auto и decltype в каждую щель, просто пиздец. А это создание потоков, на один меньше чем надо. А использование volatile, типа thread safe переменная...
Есть такой код - https://repl.it/NoCEКомпилятор почему-то ругается (warning'ами), что, мол, "missing initializer for member 'Obj::b'" и "missing initializer for member 'Obj::c'". Чинится заменой на { {0, 0, 0} }, конечно, но так ли я неправ с инициализацией одни нуликом? Да и при смене формата структуры (во время разработки) придётся эту хрень туда-сюда менять.
Как пере-запилить уже гоовую программу на ведройд?
>>1087874https://wandbox.org/permlink/CRAL4r1l1qWGDsJx
>>1087735Тогда сорян, у меня просто практики мало. В таком случае могу посоветовать только if constexpr, который более читаемый, чем СФИНАЕ-лапша.>>1087737В стандарте прямо так и написано:>A variable whose declared type is “reference to type T” Т.е. ссылка - часть типа, поэтому моё изначальное утверждение не имеет вообще никакого смысла, я был неправ.>>1087755Потому что я учусь, помогая, а дауну моя пощомь не поможет вытеснить меня с рынка.
>>1087893Хм, и правда, ++11 же. Спасибо.
>>1088097>Т.е. ссылка - часть типаЯ вообще не понял, зачем было лезть в declaration/declarator.Есть же очевидный http://eel.is/c++draft/basic.types, где в первом параграфе http://eel.is/c++draft/basic.types#1.note-1 кратко сообщается, что типы делятся на 2 класса: fundamental и compound. Ну и указатели со ссылками это виды compound-типов http://eel.is/c++draft/basic.types#basic.compound-1.3 http://eel.is/c++draft/basic.types#basic.compound-1.4А то, что в declaration звёздочка с амперсандом входят в т.н. declarator... Ну и что?
>>1087363Будет еще один нахуй никому не нужный и не интересный доклад.На прошлом-то цппараша '17 только парочку достойных было. А так я только пожалел, что потратил кучу времени на многообещающие названия, которые обернулись хуитой
Может кто объяснить различие в этих двух суммах?
>>1088264Вынесение общего множителя за скобки вроде в 5 классе проходят.
>>1088276Ты молодец, но суть в том, что я не понимаю, что такое сумма сумм, а инфы в нете кот наплакал, нашел ед. книгу где это объясняется и та без примеров.
>>1088283>сумма сумм(1+2+3+4)+(1+2+3+4)+(1+2+3+4)+(1+2+3+4)
>>1088264А разница есть?
>>1088283Тебя скорее всего смущает наличие двух знаков суммы. Берешь и подставляешь вместо n и m целые числа, пусть будет 3 и 3.Суммируем по l.Получается сумма по k_от_1_до_3 от выражения( k^3(k-1) +k^3(k-2) +k^3(k-3))Теперь суммируешь по k, каждый элемент 3 раза. 3*3 дает девять слагаемых без параметров.Иногда сумма факторизуется, т.е. ты можешь отделить компоненты одного ряда от от другого.Здесь так сделать нельзя.
>>1088315>Теперь суммируешь по k, каждый элемент 3 разаОговорился, имелось в виду, что что суммируешь по k каждый компонент ряда.самофикс
>>1088317>>1088297Спасибо вам ребята.
Так, сап плюсовые.Есть пара вопросов касательно MAPЕсть один map<string, int>1) Как мне в с'ауте вывести только второй ключ2) Как мне обратиться только ко значению или к ключу3) Как изменить только значение
>>1088351http://www.cplusplus.com/reference/map/map/begin/ты как будто вчера только плюсы включил
>>1085579 (OP)Где взять исходники aptitude? Хочу понять как делат ьтакое же консольное меню.
Антоны, можете придумать салаге, которая возомнила себя достойной учить кресты, какую-нибудь задачу?
>>1088811Среди активных стримов перископа автоматически находить те, где красивые девушки пытаются эротишно танцевать.
>>1088811я в универе когда учился написал типа загрузчик уровней quake3 из bsp файлов, библиотекой directxбез текстур и шейдеров, но зато можно было камерой по уровню летать
Вопрос не в том разделе, но все же спрошу. Поясните, почему где-то требуются разработчики именно на чистом С, если есть С++, который полностью включает в себя С. В чем принципиальное преимущество обычного С над плюсами?
>>1088854>преимущество обычного С над плюсами?не нужно тянут с собой Visual Studio C++ Redistributable 2012 x86-64
>>1088854В том что Си простой, маленький и быстрый язык, а чтоб писать на С++ надо быть терминатором-задротом с 5 летним стажем который выучил дохуя подводных камней языка и правильно умеет ими пользоваться. Это тебе не игрушки.Сам пишу на Си, выучил после него C# на приемлимом уровне за 6-8 месяцев, но вот C++ нихуя не шарю ибо язык очень большой и сложный да и нахуй мне не нужен. Захочу что то системное, напишу на чистом Си, а ежели веб или десктоп то на шарпе.
>>1088854У C++ жирный рантайм. Для обработки исключений.
>>1088854>который полностью включает в себя С. Это утверждение не верное. Есть вещи из Си которые нельзя делать в С++. К примеру Си не очень типизированный язык, а С++ в этом плане строгий.
>>1088854Банально может не быть компиляторов для C++ под платформу в ембеддеде. Да и компилятора C может не быть, а может быть что-то подобное C, но в каких-то деталях отличающееся от стандарта.
>>1088792aptitude использует ncurses
>>1088862Ты всегда можешь скомпилировать с++ в с.
>>1089021>>1088859Да ещё требует поддержки со стороны компилятора. Ну или придётся в setjmp/longjmp транслировать.
>>1088854Разница в том, что С++ говно, а С няшка. И нормальные образованные разработчики это понимают.
>>1088859-fno-exceptions and -fno-rtti
>>1089221Сразу-x cтогда, что мелочиться?
>>1089216>С++ говно, а С няшкаПочему?
Ребята, нужна помощь. Нужно в массиве найти минимальный эл-т, и обнулить стоящие справа от него эл-ты.int main(){ int N; cin >> N; int A[100]; for (int i = 0; i < N; i++) { cin >> A; } int Min = A[0]; for (int i = 0; i < N; i++) { if (Min > A) Min = A; } cout << "Min = " << Min << endl; //for (int i = 0; i < N; i++) //{ //A = 0; //} for (int i = 0; i < N; i++) { cout << "A[" << i << "] = " << A << endl; } system("pause"); return 0;}Минимальный эл-т нашел, не могу обнулить, где в комментариях он обнуляет не с минимального эл-та, а с элемента с минимальным значением. В общем, помогите сделать, если возможно, то без задания массива через функцию и без указателей.
>>1089475>где в комментариях он обнуляет не с минимального эл-та, а с элемента с минимальным значениемЧуть не так сказал. Коро че, если Min - минимальный, то обнуляет не с эл-т с мин. значением, а с A[Min]
>>1089479Скинул в личку.
>>1089507Спасибо Ванга, я думал ты коней двинула.
>>1089475Ты когда элемент ищешь, записывай ещё и индекс его. А затем в лупе пройдись начиная с i=min_idx. Пиздец ты описываешь свои проблемы, конечно.
Сап ананасы, не могу, сука, допереть, как делается эта херня. Переписывал уже раз пять, везде что-то да не работает. Нашел в этих ваших какой-то код, но он тоже работает как криворукий https://ideone.com/xRMgC2С меня как всегда
>>1090103К этому же сабжу. Чел скинул такое https://ideone.com/gdE2oR , но работает оно вообще никак
>>1090103>С меня как всегда С нас тоже.
>>1090112>С нас тоже. Или так: с нас то же.И так, и так корректно будет.
У меня достаточно здоровый проект, напилено куча говна. Обнаружил, что в основном окне при вызовеtry { throw 1;} catch ( ... ) {}происходит креш, причем в новом проекте с тем же сетапом(qt, mingw, boost) все гладко работает, с чем это может быть связано?Invalid parameter passed to C runtime function.Invalid parameter passed to C runtime function.Error - RtlWerpReportException failed with status code :-1073741823. Will try to launch the process directly
как сделать вот это говно автоматом?я уже блядь заебался геттеры писать, если ещё один геттер увижу- переебу кому-то. пикрелейтед работает, но такая декларация засирает класс ещё мощнее.макросами как-то можно получить имя класса? может дружбу по другому можно организовать?
>>1090510А не пиши геттеры и сеттеры. Это по сути плохо.Если у тебя есть классClass A {int A1;int A2;public:void setA1(int val);void setA2(int val);int getA1();int getA2();};То это по сути просто Class A {public:int A1;int A2;};Какая разница-то?)Думай как делать класс в проекте так, чтобы не драть из него значения, а чтобы объект ими сам распоряжался.Чтоб не unit.setHealth(unit.getHealth() - damage);А unit.takeDamage(damage);Хотя, иногда геттеры всё же нужны. Но их не должно быть так много чтобы ты ЗАЕБАЛСЯ ИХ ПИСАТЬ.
>>1090440А ты в студии делаешь или в креаторе? Просто интересно
>>1090558>ПРОСТО используй костылиспасибо капитан очевидностьпердоликооправдания.>Думай как делать класс в проекте так, чтобы не драть из него значенияу тебя есть класс, который ты суёшь в вектор. значения в него записываются единожды, но потом их иногда нужно посмотреть. твои действия, пердолик?-напишешь геттеры-нипишешь один геттер-тупль и получишь струю мочи в лицо-сделаешь вместо одного класса десять разных на 150000 строк кода-просто ёбнешь туда публикконст не пойдёт, т.к. он убивает копи ассайнмент, а без него в векторе не эрейзнешь.>геттерыпердолик сам придумывае хуйню и сам себе объясняетблядь, я бы в сисярп только ради ридонли перекотился, если бы сисярп не был непортируемым костыльным спермоговном. как же блядь заебали геттеры.
>>1090566Qt и MinGW в студии - это пиздец. Ясен хуй, он не в стуидии это делает. VCRT - это жирная диэлэлка, с которой некоторые проги линкуются, к студии отношения не имеет.>>1090440Поподробнее бы. Загрузил бы символы для винды и посмотреб бы хотя бы на стек вызовов.>>1090571>конст не пойдёт, т.к. он убивает копи ассайнментИзъебнуться можно!http://coliru.stacked-crooked.com/a/04bde07502bf1c89http://coliru.stacked-crooked.com/a/5a81a73b77be4d56И по-моему это даже не UB.Проблема с констом очевидна, почему до сих пор не решили - не знаю.
>>1090690>http://coliru.stacked-crooked.com/a/5a81a73b77be4d56В 12 строке вызов деструктора, но это я так, выебнулся, а нужно ли его вызывать - зависит от того, что ты там написал.
>>1090510>>1090571А в чем вообще смысл написания кучи геттеров и сеттеров без какой-либо внутренней логики? Чем это лучше наличия публичной переменной? Просто некрасиво или есть какие-то объективные причины?
Насколько актуальна книга Лафоре по плюсам за 2004 год? После некоторого времени ее чтения заглянул сюда и с удивлением обнаружил, что язык регулярно обновляется, а мой учебник помечен как частично устаревший.
>>1090718>без какой-либо внутренней логики>есть какие-то объективные причины?А вдруг потом логика появится!
>>1090718>А в чем вообще смысл написания кучи геттеров и сеттеров без какой-либо внутренней логики?Ни в чём. Просто ООП головного мозга.
>>1090734почти неактуальна, бери что-нибудь с раскрытиемтемы c++ 2017
>>1090718экономия на рефракторинге когда логика появится. в норм языках есть computed properties,в с++ не завезли
>>1090692вообще это уби, насколько я помню>>1090718пердоличек, не придумывай сеттеры, сеттеры твои никому нахуй не нужны сейчас. я привёл ситуацию, когда нужно ограничение доступа для ясности, и вот тут или вылезают геттеры, или просто забивается хуй на контроль.
>>1090789>вообще это уби, насколько я помнюНе UB, это просто не exception safe.
>>1090692>В 12 строке вызов деструктора, но это я так, выебнулся, а нужно ли его вызывать - зависит от того, что ты там написал. Вызывать нужно.Можно создать поверх данного объекта другой, либо вызвав сперва деструктор старого объекта, либо не вызывая его, но тогда деструктор не должен вызываться неявно. А он вызывается неявно в конце main.
>>1090787Что-нить типа такого спасет отца русской демократии?https://github.com/tower120/reactive
>>1090787Или даже такhttps://gist.github.com/Arkanosis/632294
>>1090809Сейчас начнётся "ко-ко-ко, макросы"
>>1090811Сам уже заметил.
Двощ, есть ли какие нибудь приложения, преобразующие .exe файл в код? Естественно, если приложение без защиты
>>1090823Конечно, это называется декомпилятор. Нет, никакого осмысленного человекочитаемого кода так не получить.
>>1090823Вот беглый пример того, как это выглядит:https://derevenets.com/examples.htmlСам понимаешь, что там будет, если еще шаблоны навернуть хотя бы.
>>1090789>вообще это уби, насколько я помнюПоподробнее бы.>>1090794Это стандарт так говорит?
>>1090898 If, after the lifetime of an object has ended and before the storage which the object occupied is reused or released, a new object is created at the storage location which the original object occupied, a pointer that pointed to the original object, a reference that referred to the original object, or the name of the original object will automatically refer to the new object and, once the lifetime of the new object has started, can be used to manipulate the new object, if: the type of the original object is not const-qualified, and, if a class type, does not contain any non-static data member whose type is const-qualified or a reference typeвектор сломает, по-моему.
Что можно написать ньюфагу на крестах?
>>1090898>Это стандарт так говорит? Да. http://eel.is/c++draft/basic.life#5>>1090911Ты не совсем то скинул.
>>1090789>ограничение доступа>для ясностиЧто-то проиграл с этого архитектора. Ты членораздельно и без истерик и можешь объяснить что тебе было нужно и зачем ты это сделал?
>>1090930>и без истерик и можешь>и можешьу тебя просто деменция. всем всё ясно кроме тебя.
>>1090931На вопрос ответь.
>>1090911Вектор тут вообще ни при чём. Очень правильно подметил, кстати: видимо, изменение конст-членов чревато, см. ниже.>>1090924Он как раз то самое и скинул, прочти внимательно: ссылкой на объект можно пользоваться снова, если у объекта нет ссылок и констов.Нет слова "только" перед "если", но зато есть явное указание на необходимость использования launder в сноске:http://eel.is/c++draft/basic.life#8.4а про name не сказано вообще ничего.http://eel.is/c++draft/support.dynamic#ptr.launder-5Про то, на что сослался ты: https://stackoverflow.com/questions/41385355/is-it-ok-not-to-call-the-destructor-on-placement-new-allocated-objects/41385381 То есть, формулировка размыта. Кроме того, у тривиального деструктора нет сторонних эффектов.
При чём в 8.4 в примере тот самый велосипед, который я переизобрёл.
Итак щеглы, которые прожат в визул студио, как оно вам живется с этим??? Наверно теперь понимаете как ловят тру хачкеровhttps://www.reddit.com/r/cpp/comments/4ibauu/visual_studio_adding_telemetry_function_calls_to/
>>1091020так давно уже конпулятор микрософт добавлял идентификатор процессора в бинарники
>>1091020как вообще можно использовать спермостудию когда есть кмейк и кутекуриэйтор? она ж кусок говна.
Как настроить таймаут дисконнекта синхронного коннекта буст сокета?Везде пишут, что не предусмотрено, или что синхронный таймаут не канон.Я тестирую таймаут бесконечным циклом ( connect -> send http -> receive http -> disconnect ) с помощью выдергивания шнура, где-то 20-25 секунд все висит, после кидает boost::system::eror_code. Навязывается вывод, что он где-то же все-таки есть.http://pubs.opengroup.org/onlinepubs/009695399/functions/setsockopt.htmlhttps://msdn.microsoft.com/en-us/library/windows/desktop/ms740476(v=vs.85).aspxНичего не нашел, может плохо искал.В документации есть пример с асинхронным, но он кривой, и вообще, по сути, без запуска io_service в самом коде, что есть пиздец и без создания внешнего класса такое не провернешьhttp://www.boost.org/doc/libs/1_52_0/doc/html/boost_asio/example/timeouts/blocking_tcp_client.cpp>>1090690Как это сделать? Я в человеческий дебаг не могу. Пикрл - все, на что способен. Думаю, придется комментить до победного конца, но все же может получится нормально сделать.
>>1091038Как вообще можно использовать эту красноглазую залупу, когда есть MSVC?
>>1091038У тебя опечатки в слове CLion.
>>1091043
>>1091073Хуита хует. Очевидно, падать на этом оно не должно. На всякий случай: а оно точно пересобирается? Посмотри в лог компиляции. Для чистоты эксперимента закомменти ещё и QApplication.Олсо, это точно твоя программа падает, а не qmake или компилятор?
>>1090918Конпелятор
>>1091060>CLion>>вырвиглазная тормозящая залупа на jvmno, thanksproud Visual Studio Code user
>>1090807какое же уродство, ппц просто
Нашел источник проблемы. С чем это может быть связано?new project -> qt _bs_ -> QMAKE_LFLAGS += -static-libgccQMAKE_LFLAGS += -static-> pic
>>1090967Ок, про ссылки верно.
>>1091112Я тоже им пользуюсь, но это же не IDE.
>>1091112Вместо этого ты пользуешься вырвиглазной тормозящей залупой на электроне, найс.
>>1091114Необязательно передавать лямбды, если не нравится. Будет выглядеть примерно такhttps://github.com/schlangster/cpp.react
>>1091155Хуй знает даже. Пиши багрепорт. Я правильно тебя понял, линкуешь статически и получаешь ошибку?
>>1091155Причём багрепорт пиши разрабам MinGW-w64, наверное.
>>1091283Да, но сборка Qt не статическая. Также ломается на хуевом ноуте, не очень могу в багрепорты, научишь?
>>1091305>но сборка Qt не статическая. лол
>>1091307Ну пиздец, либы std линкуются статически, либы Qt - динамически, типо не канает?
>>1091315нетъ
>>1091317Почему тогда к многим прогам идут .dll, если невозможно линкануть одновременно некоторые либы статически, а некоторые - динамически
>>1091319при динамической сборке твой проджект работает?
>>1091321Да, и не токлько в моей прогу, в любой проге. Только добавляю те флаги, трай-кетч крешит.
>>1091323и че ты тут нам мозг тогда ебешь? статический кут проект конпилится только со статическим кут.
>>1085579 (OP)Анон, ньюфаг-неосилятор итт. Есть код: class Type{...Type foo(...){ type ans(...); ... return ans;}...}Что вообще возвращает foo()? ans был локальной переменной, в какой момент запуститься её деструктор? если, скажем, в main будет будет что-то типа type x = y.foo(...) (operator= определили, например поля простые int'ы и тупо все копируется, к утечкам не приводит) - это вообще на низком уровне что такое? И что такое конструирование объекта во время return, типа foo() { return Type(...) } и чем бы это отличалось от foo() { type a() return a } ?Не ссытите на лицо плз, несколько часов эксперементирую и не понимаю что происходит.
>>1091419Возвращается копия, но компилятор оптимизирует и копирование постарается убрать. Ты же не указатель/ссылку возвращаешь.
>>1091426>Возвращается копияКопия делается по ans конструктором копирования? Но у меня он не срабатывает почему-то судя по отладочному выводу, который я в него добавил. Главный вопрос в том, сколько тогда эта копия живет? В type x = y.foo(...) эта копия должна раньше присваивания похерится или как?В моих тестах сначала проходило присваивание, потом вызывался деструктор, однако если усложнить выражение, т.е. начать к y.foo() применять, например, какие-нибудь операторы и потом уже делать присваивание, то самописный деструктор показывал мне вызов деструктора ans (именно ans, его адрес выводил, а не копии какой-то return'овской) раньше присваивания, и я ничего не понимать. UB что ли?
>>1091426>копирование постарается убратьда, очком читал, понятно тогда почему у меня не срабатывал конструктор копирования. Тогда что вообще возвращается, если и не копия?
>>1091419>в какой момент запуститься её деструкторhttp://eel.is/c++draft/stmt.return#3>несколько часов эксперементирую>В моих тестах > Не ссытите на лицо плзТы серьёзно просишь не ссать на лицо, когда вместо лазанья в стандарт запускаешь какие-то тесты?
>>1091450> Тогда что вообще возвращается, если и не копия?ничего не возвращается. эта оптимизация называется copy elisionсуть:T f(){ T in_f{}; return in_f{};}int main(){ T out_f = f();}если оптимизация сработает, то внутри функции f() переменная in_f никогда не создастся, компилятор сразу создаст out_f и будет внутри фунции работать с ней, как будто она in_f.однако, эта оптимизация гарантированна лишь начиная начиная с c++17, который ты вряд ли пользуешь, и при определённых условиях. то бишь, компилятор может эту оптимизацию и не применить на режимах до --std=c++17если хочешь нормально раздебажится, то запрети компилятору делать оптимизации вообще через -O0 флаг на шланге/гцц, в вижуалке где-то в менюшках оно спрятанону, и покажи свой конструктор копирования. вдруг ты там какую-то хуето делаешь.да, не забывай про правило 3 до c++11, начиная с c++11 это правило 5
>>1091478>>если оптимизация сработает, то внутри функции f() переменная in_f никогда не создастся, компилятор сразу создаст out_f и будет внутри фунции работать с ней, как будто она in_f.>однако, эта оптимизация гарантированна лишь начиная начиная с c++17Врать-то не надо. Никакой copy elision в C++17 не гарантируется для твоего кода.
>>1091481ты далбик или как? http://open-std.org/JTC1/SC22/WG21/docs/cwg_defects.html#2022
>>1091485К чему вообще этот defect report?
>>1091457The standard is not intended to teach how to use C++.>>1091478всё, спасибо большое, анон, за нужные теги, нужное мне нагугли
>>1091490Определись, тебе teach или понимать, что когда происходит?
>>1091493я понимаю, что когда ты крутой, то выглядит естественным открыть чистую документация и просто прочесть, и ты вероятно забыл, что начинающей в этой статьей найдет столько непонятных слов, разбираться с которыми right here right now не очень продуктивно.
>>1091439>Копия делается по ans конструктором копированияЧто значит предлог "по"?>Но у меня он не срабатывает почему-то судя по отладочному выводу, который я в него добавил.>В type x = y.foo(...) эта копия должна раньше присваивания похерится или как?Copy elision. Стандарт допускает.>>1091487Там ссылки на пункты стандарта есть с цитатами, ленивая ты жопа.
Нужен c++ программист (cocos2d-x) в мобильный геймдев на удаленку с перспективой релокейта в Вильнюс. Как его найти? Уместно ли запостить вакансию здесь?
>>1091697Пиши bluemaxgame на гмыло.
>>1091703Написал.
>>1091647И всё-таки, при чём тут defect report про constexpr?
Реквестую книг по погромированию на крестах под шиндус
>>1085579 (OP) Сап, программач.Я офисоклерк, решивший вкатиться в кресты. За плечами сначала были макросы в AutoHotkey, потом клепал их уже на VBA в Excel для облегчения рутинных задач.Вопрос вот в чём: хочется иметь у себя компилятор, но на работе у меня нет админских прав. Некоторое время я использовал ideone и repl.it, как рекомендовано в шапке, но ощущения не те. Visual Stodio мне не поставят, инфа сотка. Думал использовать VSCode + Clang, но последний требует студию для работы. Для MinGW нужны админские права.Есть ли какие-нибудь компиляторы или IDE не требующие права, программач? И если есть, то какие?
>>1091889http://copy.sh/v86/
>>1091889>Я офисоклерк, решивший вкатиться в крестыРасскажи, как работает std::move и std::forward и как работает паттерн Visitor.
>>1091889Инсталлёр cygwin вроде как с --no-admin можно запускать.
>>1091889> Clang, но последний требует студию для работы.Уверен?
Анончики, в std::map при дефолтной инициализации значения по ключу мне гарантируют инициализацию void* нулём, или undefined behaviour, так как если бы я создавал переменную на стеке? (MSVC 11)
>>1090784а переиздания лафоре 2014?
>>1091889https://nuwen.net/mingw.html#install
>>1091997> АнончикиХуёнчики.> std::map при дефолтной инициализации значения по ключу мне гарантируют инициализацию void* нулёмstd::map::[] при вставке делает value initialization. http://en.cppreference.com/w/cpp/language/value_initialization> undefined behaviour, так как если бы я создавал переменную на стеке? Создавать переменные на стеке — не undefined behavior
>>1092074Спасибо.Т.е.int i;мне гарантирует 0? Я думал, любая хуита может быть. Хотя на плюсах не писал почти никогда.
>>1092079>int i;>мне гарантирует 0?Нет.
>>1092080> Создавать переменные на стеке — не undefined behaviorНу или типа я даун и не то выражение использовал для случая, когда значение переменной не определено?
>>1092084UB при чтении неинициализированной.
>>1091731Он просто первым в гугле его увидел, и по упомянутым причинам он тоже подходит, как источник информации.>>1091889>Есть ли какие-нибудь компиляторы или IDE не требующие права, программач?Почти никаким программам не нужны админские права, и большинство программ будут работать после копирования файлов и ключей реестра.Для Qt Creator, например, нужно только две папки: папка с программой (можно скопировать в ЛЮБОЕ место) и папка из AppData/Roaming (скопировать в похожую папку на целевой машине). Запусти установщик дома. Ну и компилятор (MinGW W64).С другой стороны, кутэкреатор посоветовать не могу, там ебалайка с библиотеками, надо в PATH папку bin из мингв добавить. В винде без админских прав это делается из окошка "Учётные записи".https://www1.qt.io/download-open-source/https://sourceforge.net/projects/mingw-w64/files/?source=navbar> Для MinGW нужны админские права.штоблядьЗип качни и распакуй, где там права нужны?>>1092079Речь о мапе идёт, блядь.>>>std::map::[] при вставке делает value initialization>>>std::map::[] при вставке делает value initialization>>>std::map::[] при вставке делает value initialization
>>1091326А вот у меня вопрос, какого хуя он не пожаловался об этом сам? И кто виноват, если у ОПа крашился try-catch вообще без кода Qt? Хотя он так и не закомментил куаппликатион, так что мы уже не узнаем, кто виноват.
>>1092086> Создавать переменные на стеке — не undefined behavior
>>1092090Зачем ты отвечаешь мне? Я умею читать. ОП вопроса явно пропустил то, что речь именно о мапе, и из-за этого делает явно идиотское предположение:>>Т.е.>>int i;>>мне гарантирует 0? Я думал, любая хуита может быть.
Аноны, как в vs2012 включить long double? Там есть встроенное решение, или нужно собирать и подключать gcc-шные либы?
Вот функция, переводит десятичное число в двоичное, выводит на экран. Анон, расскажи быдлокодеру, что делает строчка binary(number>>1)?void binary(int number){int remainder;ind--;if(number <= 1) {cout<<number;return;}remainder=number%2;b[ind]=remainder;binary(number>>1);cout<<remainder;}
>>1092140ты далбик или как? зачем тебе переводить число, если оно уже хранится в двоичной системе счисления
>>1092140(number>>1), операция правого сдвига.Значением выражения является битовое представление левого операнда, сдвинутое вправо на количество разрядов, равное значению правого целочисленного операнда. При правом сдвиге на i разрядов первые i разрядов левого операнда заполняются нулями, если левый операнд имеет беззнаковый тип или имеет неотрицательное значение, в противном случае значение определяется реализацией. Последние i разрядов левого операнда теряются.Тобишь binary(number>>1); осуществляет рекурсивный переход, передавая значение, вдвое меньшее чем number.
>>1092145Ди нахуй, индус.
>>1092137установи расширение для визуалки https://www.haskell.org/ghc/download_ghc_7_6_1.html#windows
>>1092149Так ведь это не расширение, а другой компилятор
>>1092137>Аноны, как в vs2012 включить long double?Вариант "никак" ты рассматриваешь? Тебе нужен 80-битный формат x87?
Есть ли сакральный смысл в назначении конкретных значений для членов перечисления (enum которое)? Или это делается из тех же соображений, из которых желательно инициализировать каждую переменную при объявлении (ну тип чтобы в случае чего рандом-ошибки не отлавливать)? Но ведь правила назначения значений по умолчанию членам enum везде одни и те же.
>>1092180>Есть ли сакральный смысл в назначении конкретных значений для членов перечисления (enum которое)? Обратная совместимость.
Точнее, гарантия независимости этой совместимости от добавления новых \лементов и перестановок.
Анон, помоги мне найти баг в проекте на Qt, который сейчас я пишу в MSVS. Ошибка следующая:main.obj : error LNK2001: неразрешенный внешний символ ""public: virtual class QSharedPointer<class AbstractEmployee> __cdecl EmployeeFactory::makeEmployee(struct EmployeeRecord const &)" (?makeEmployee@EmployeeFactory@@UEAA?AV?$QSharedPointer@VAbstractEmployee@@@@AEBUEmployeeRecord@@@Z)"Реализация фабрики у меня такая:employee_record.hhttps://ideone.com/wBRIK9employee_record.cpphttps://ideone.com/0nZYFpemployee_factory.hhttps://ideone.com/Hk1SJxemployee_factory.cpphttps://ideone.com/LAQLoyКомпилируются все файлы, проблема возникает на этапе линковки. Фабричная функция определена. Не могу понять, как мог проебаться символ фабричной функции.
>>1092392Я могу ошибаться, но это из-за того, что определение шаблона должно быть в том же файле, что и объявление, в record.cpp у тебя подключается factory.h, а тело реализации не подключается, надо переносить из factory.cpp в factory.h
>>1092392P.s. а фабричная функция определена, да только для юнита сборки factory.cpp.
>>1092404>Я могу ошибаться, но это из-за того, что определение шаблона должно быть в том же файле, что и объявлениеНо у меня там нет шаблонов.
>>1092410Не понимаю, почему не подключается реализация из factory.cpp. Когда я перенес определение фабричной функции в тело класса и закомментириовал ее реализацию в .cpp-файле, ошибка линковки исчезла.
>>1092392Лог компиляции на pastebin кинь.
>>1092443Пиздец, после того, как я внес определение функции в тело класса и удалил ее оттуда, проект стал собираться корректно.https://pastebin.com/qYYP1N3n
>>1092450Ёбт, да я догадался до того, что если перенести определение в заголовок, то всё ок, ты мне лог с ошибкой покажи.
>>1092450И это, verbosity выкрути на уровень побольше, чтобы команды компиляции было видно.
>>1092451>ты мне лог с ошибкой покажиУже не могу воспроизвести ошибку. Когда я снова удалил реализацию из тела класса и перенес ее в .cpp, все стало норм. Что за хуйня?
>>1092453Аааааааааа, теперь понял. Значит, либо таймстамп не тот, либо глюк в студии. Всегда делай ребилд, если есть проблема, так как средства разработки не компилируют то, что уже компилировалось, и для этого сравнивают время изменения объектников и сурсов.
Есть структура с полями данных: вектором и итератором(и пусть итератор в данный момент указывает на первый элемент вектора). Если сделать копию структуры "по-умолчанию", то итератор не испортится?inb4: нет.
>>1092515Итератор всего лишь будет указывать на элемент из источника копии. Даже если итератор хранил бы в себе данные об объекте, в котором он итерирует, то узнать о том, что ты ожидаешь от него указания на совсем другой вектор, он не может, такого механизма в языке нет (хоть это и возможно формализовать с помощью кода более многословно, с помощью определения своего вектора и своего итератора).
>>1092515Испортится.Делай свой конструктор копирования и восстанавливай итератор вручную. Для ассоциативных берешь элемент на который указывает итератор и ищешь такой же элемент в новом контейнере. Для вектора просто находишь смещение от begin.
>>1092515>итератор не испортится?Исходный — нет.Как и его копия. Только она указывать будет на старый вектор.
>обращение к экспертамНа сервере лежит .dll библиотека, в которой есть некие функции.Можно ли запуская программу у себя на компьютере как-то работать с функциями этой библиотеки, которая лежит на сервере?
>>1092697Скачиваешь@работаешь. А как иначе? Либо она запущена на сервере, а ты уже через какой-то RPC дергаешь вызовы.
Анон, подскажи плиз. Вкатываюсь в QT и немного не понимаю чяднт с формами. Создаю две формы, одна при запуске вызывает появление другой. Другая внезапно появляется без границ и верхней панели. 1 пик - то как это выглядит в qt-дизайнере2 пик - как это выглядит после запуска. 3 пик - код вызова второй формы из первой. 4 пик - код создания экземпляра второй формы, я погуглив пытался изменить свойства формы. My weapon does no effect!Чего я хочу. Чтобы вторая форма появлялась в отдельном окне, у неё была рамка, верхняя строка и её можно было таскать.В чём моя ошибка?
>>1092882Ты бы хоть код нормально оформлял, серунька безмозглая.Что это блядь за переменная asd ?Тут экстрасенсы сидят по твоему?По делу, ту делаешь владельцем второго окна первое окно, а ты не делай.
Анон, использую stod для конвертации строки в число, исключения ловлю. На каждое сработавшее исключение программа пишет в дебаг, что сработал std::invalid_argument exception. Их много, так что я не могу нормально лог читать. Как можно убрать сообщения о std эксепшонах из кода?
>>1092903Весь лог засрало чем-то типаException thrown at 0x00007FFEAD999D98 in Linoleum.exe: Microsoft C++ exception: std::invalid_argument at memory location 0x000000BF5BBC4B10.Меня это расстраивает
>>1092903>Как можно убрать сообщения о std эксепшонах из кода?Ну. Руками.
>>1092909Я не так выразился. Как убрать вывод этих сообщений из Debug Log?
>>1092901О, спасибо. asd - ну можно конечно обозвать бессмысленную переменную которая существует только для теста мультиоконности как-то вроде "testWindow" но зачем? Ведь строчек кода мало и всё читаемо. Или нет?
>>1092925grep не завезли?
>>1087363обзоры либ, дожили. нахуй ей нужен обзор? у неё что, нет документации?понимаю у юнити, раньше по крайней мере, док не было и чтобы узнать как сделать ёбу надо было мотать двадцать минут рассуждений индусского школьника о том, что такое фор и чем он лучше копипаста одного и тоже N раз
Найдётся ли в этом треде достаточно не заёбаный залётными долбоёбами человек, который согласится скомпилировать этот проект для 32 битной системы?https://github.com/aseprite/aseprite/releases/tag/v1.2.4
>>1093055Под венду, конечно же.
>>1088811просмотрщик пикчей (бмп, жпг, пнг, гиф) с отрисовкой руками без либ. а то каждый может сделать:libaname::load("yoba.jpg");libaname::show();
>>1088854> Поясните, почему где-то требуются разработчики именно на чистом С, если есть С++, который полностью включает в себя С. > если есть С++, который полностью включает в себя Ссразу видно, что ты ни того, ни другого языка не знаешь.попробуй скомпилять этот C код плюсавым компилятором: https://ideone.com/JaWLdfа теперь лососни тунца за щёку, пидр
>>1093055Собирал как то, могу завтречка.
>>1088811Напиши скачивалку сайтов. Http правда, с https без либ заебешься...
>>1093085Круто, буду очень благодарен. Закинь в тред ссылку на какой-нибудь яндекс-диск или типа того, буду чекать завтра периодически. Заранее спасибо, няша.
Нужно написать эмулятор андроида, чтобы туда можно было ставить приложения из гугл плей, какие есть варианты на с++?
>>1093268рекомендую начать с ассемблера
>>1092925Дебуг лог - это в студии?
>>1093268Кому нужно? У меня уже есть Nox.
>>1093268Танненбаума наверни, там само пойдёт.
>>1093094Лови, ничего сложного, по гайду, но геморно.http://dropmefiles.com/Vbw56Правда я сейчас заметил что собрал последнюю дев-версию, а не ту что ты кинул, принципиально?
>>1093268Предлагаю начать с получения хорошего образования в области системной инженерии, разобраться с архитектурой ЭВМ, наборами инструкций ARM и x86, моделями памяти, теорией трансляции, параллельно получать второе образование в области менеджмента и международных отношений. Дальше сделать форк QEMU, разработать драйвера виртуальных переферийных устройств, ну, параллельно ты с плюсами сам разберёшься. Лет через 8-10 будет готовый продукт.Пиздец ты клоун
>>1092882>В чём моя ошибка?Вот тут: new QtGuiClass( this ). Когда указываешь виджет в конструкторе, новый виджет становиться у него дочерним.
>>1093268Зачем?
>>1093417Заебися. Спасибо, няша, держи тонны нефти и 2 чая. То, что версия дев - ничего страшного, мне просто хотелось свежую и просто скинул ссылку на стабильный релиз.Ещё раз спасибо большое.
>>1093453Насколько в арчике все проще.
>>1093435Че так много то?Тот же Bluestacks эмулятор, что ли дохрена сложный в разработке был?
Как передача параметров в функцию в обратном порядке помогает получить возможность использовать неопределенное множество параметров?Какая разница как их складывать, если я заранее не знаю, сколько их у меня будет, ведь stack pointer будет указывать всё равно не на первый (в порядке подачи в функцию) аргумент функции, а на всякую служебную информацию, типа адреса возврата, память, куда запишется возвращаемое значение и состояние регистров до передачи управления функции
>>1093496Да вообще фигня, говорю же, форкаешь QEMU, пишешь драйвера...
Нужна помощь анОнасы. Такая задача. Помоги подправить.Найти в массиве самую длинную убывающую последовательность, расположенную после максимального элемента включительно. Вывести на экран номера ее первого и последнего элементов.https://pastebin.com/JSFR1XAy
>>1093563>Найти в массиве самую длинную убывающую последовательностьнашел, куда писать?
как сделать так чтоб счетчик копий между array и list не считал копии дважды? т.е [2,1,3,5] p[3,2,3] 3 должно посчитать как копию только 1 раз а не 2. (в аррей копий нет, только в лист). этот код работает но считает каждую копию, что надо добавить?. анон, помоги бомжуint count_array_list(int A[], int n, plist p){int count = 0;int i;if(n == 0 || p == NULL) return 0;else while(p != NULL) { for(i = 0; i<n; i++) { if(A == p->info) count++; } p = p->next; }return count;}
>>1093549Я не знаю, про какую ОС и архитектуру ты спрашиваешь, и calling conventions и направления роста стека я уже ни для чего не помню. Могу нагуглить за тебя и объяснить.
>>1093569Представь себе, что ты платишь мне бабки за каждый вопрос, и за каждый попытку задать тот же вопрос ты платишь вдвое больше. Представил? Теперь задай свой вопрос ещё раз так, чтобы я понял, что тебе нужно.
>>1093590это типа философский ответ или ты нихуя не понял?
>>1093584Я думал, что это возможно при любой архитектуре.. Ну, x86, например.
Почему указатель на первый элемент массива можно вычесть из указателя на 3ий и получить 2?int m[10] = {1,200,3,4,5}; int p = m; int q = &m[2];std::cout <<p << std::endl; std::cout << q << std::endl; std::cout << q - p << std::endl;Это ведь не вычитание адресов друг из друга 8 это не 2
>>1093647Потому что, вычитая указатели, ты получаешь смещение в элементах, а не разницу адресов.>>1093598Да.>>1093606Никаких объяснений не не нашёл, вывод только один: наследственность, как и little endian.
>>1093699>Потому что, вычитая указатели, ты получаешь смещение в элементах, а не разницу адресов.Почему тогда их нельзя складывать?
>>1093710Потому что это не определено.
>>1093549>Как передача параметров в функцию в обратном порядке помогает получить возможность использовать неопределенное множество параметров?Так, что из первого (второго или любого другого фиксированного) ты можешь узнать, сколько у тебя параметров идёт следом, т.к. первый параметр, при передаче аргументов задом на перёд, будет идти первым на стеке и известно, как к нему получить доступ.
>>1093710Ты ещё спроси, почему на ноль делить нельзя.
>>1093714>Так, что из первого (второго или любого другого фиксированного) ты можешь узнать, сколько у тебя параметров идёт следомОт того, в каком порядке ты пушишь параметры, нихуя не зависит. Так же, как ты узнаёшь о том, что параметры кончились, ты можешь узнать и о том, какого размера список параметров.
>>1093710Потому что ты можешьPtr2 - Ptr1 = смещениеPtr1 + смещение = Ptr2А что ты ожидаешь от Ptr1 + Ptr2?
>>1093728Параметры могут вычитываться по ходу из строки форматирования как у принтфаСимволом последнего параметра может идти NULL
>>1093569Просто поменяй внутренний и внешний цикл.У тебя что написано?Для каждого p: для каждого a: если равно, посчитать;А будет:Для каждого a: для каждого p: сравнить; если равно, посчитать и пропустить остаток цикла по p.
>>1093728>От того, в каком порядке ты пушишь параметры, нихуя не зависит.Зависит их расположение в стеке.> Так же, как ты узнаёшь о том, что параметры кончилисьРасскажи, как, имея произвольный кусок стека, узнать, есть ли там параметры и когда они кончатся.
#include <algorithm>#include <array>#include <functional>#include <iostream>#include <iterator>int main() { std::array<int, 9> arr{ { 0, 1, 4, 1, 7, 3, 0, 6, -1 } }; auto seq_max = std::max_element(arr.begin(), arr.end()); auto seq_next_min = std::adjacent_find(seq_max, arr.end(), std::less<int>()); std::cout << std::distance(arr.begin(), seq_max) << ".." << std::distance(arr.begin(), seq_next_min); return 0;}
>>1093563>>1093742
>>1093733>>1093731Да ради бога, но у функции есть указатель на стек и указатель на стек вызвавшей функции, это всё, что необходимо для вычисления размера списка параметров.
>>1085579 (OP)Почему C++ такой лживый и делает вызов constexpr-функции, которая только возвращает число 42, вместо подстановки числа 42 во время компиляции?
>>1093787Компилятор недопилен значт.
>>1093787Может у тебя не все требования выполнены? Нельзя виртуальные функции, функции с нетривиальными параметрами, еще какая-то херня.
>>1093773>размера списка параметровМы про число параметров говорим.
>>1093787constexpr не гарантирует вычисление в компайл-тайм.
>>1086684Метапрограммирование - хорошая штука. Высокий порог вхождения, выше зарплата (на 20% лол), защита от индусов, экономия перформанса на виртуальных вызовах (т.е. на спичках).Есть один существенный минус - медленно конпелируется и ещё медленнее линкуется на средних и больших проектах.При этом, насколько мне известно, ничего ни подкрутить ни подхачить нельзя, чтобы у тебя компилилось быстрее, а у индусов медленнее.Ведь если ты выполняешь задания быстрее чем они, значит твоя зарплата выше. Верно?
>>1093877Ссылку не читай, сразу отвечай.
>>1093885Пока откроешь и раскуришь твою ссылку - уже успел баг в кодеблоксе исправить.Пока ты с интерфейсом сокета разбираешься - индусы успевают десяток рэст сервисов на нодэжс с экспрессом сделать, готовых, законченых, с асинхронностью, правильным парсингом урлов, хедеров и прочего говна.Пока ты будешь дрочить свой Си++ - ни одна тня тебе не даст.Придумаешь как забрать работу у индусов и азиатов - тебе любая даст, и даже две одновременно.
>>1086684Метаклассы - это не совсем шаблоны, точнее, на мой взгляд, совсем не шаблоны. Это некоторое новое расширение языка для компиляторов, которое позволяет делать то, что шаблоны пока что не могут. Плюс, не похоже, что тут есть вещь, присущая шаблонной вакханалии - адское время компиляции.ИМХО, метаклассы - это, конечно хорошо и очень здорово, но я бы предпочел рефлексию на основе reflexpr или как его.
>>1086684Мне очень понравилось, сразу столько бойлерплейта на свалку. Но. Блять. $почему $сука, $почему.
Посоны, хочу вкатиться в QT, ну и видимо придется вкатываться в C++ PYQT - говно. Работаю в автоматизации, программирую постольку поскольку, чтобы было что кушать, сейчас смотрю на QT и понимаю, что это то, что мне нужно. Есть какие-то книжки, чтобы охватывали сразу и C++ и QT, чтобы отдельно не учить C++ за 21 день и QT, а сразу прочесть книгу и уже можно писать какие-то проекты?
>>1085579 (OP)Анон, помоги написать шаблонную функцию удаления n-го элемента контейнера, которую можно было бы использовать в erase-remove идиоме, и которая была бы эффективной по времени и работала в том числе с некорректными входными данными.https://ideone.com/4WLJD5
Продублирую задачку плюсовикам. Тут есть один граф, представлен в виде 2D массива, который во входящих данных у меня есть. Значения ячеек могут принимать как отрицательные так и положительные числа. Как мне из стартовой точки до финишной посчитать максимальный профит? Я даже хуй знает с какой стороны к этой задаче подходить. Если код на питоне будет - вообще замечательно. С C++ тоже разберемся. Ах да, при прохождении через ячейку она обнуляется, поэтому в строке можно ходить туда-сюда. Влево и вправо. Перемещаться по высоте можно только вниз.
>>1093921>Пока ты будешь дрочить свой Си++ - ни одна тня тебе не даст.И так не даст, а тут хотя бы подрочить можно.
>>1094017>> if (std::distance(p, q) == 0) return p;>> if (std::distance(p, q) < n) return q;дичь какая, ты, надеюсь, понимаешь, что q указывает на элемент контейнера, следующим за последнимдальше не читал
>>1094030алсо, когда ты подсчитал distance, ты сам себе за шиворот насрал
>>1094032>когда ты подсчитал distance, ты сам себе за шиворот насралПочему?>дичь какая, ты, надеюсь, понимаешь, что q указывает на элемент контейнера, следующим за последнимВместо q прописал std::prev(q) и получил неправильный ответ. Если оставить q, получаю тайм лимит.
>>1093921Вернись в /b/.
>>1093921мартыха, на вебе программирование не заканчивается.>>1093948Синтаксис гарантированно поменяется
>>1093948Теперь код на C++ будет похож внешне на PHP код с этими баксами, лолец)
>>1094010По QT есть только Макс Шлее, но вообще, надо изначально C++ знать, чтобы смочь в qt. Если тебе надо что-то на гуйне писать - посмотри шарпы или жабу (если надо кроссплатформенность).
Анон, выручай. В си у меня познания крайне дерьмовые, мне просто нужно заставить этот чёртов мк под управлением libopencm3.
Есть ли тут кто-нибудь, кто знает C++11 и ищет работу в Дс2?
>>1094150Есть.
>>1094151Ну ты контакты оставь или на почту резюме кинь.someonefrominternet@yandex.ru
>>1094150Скинь вакансию.
>>1094154Нормальная миддловая вакансия, чего выебуешься?
>>1094071>> Почему?Потому что подумай, как быстро посчитается distance для элементов list, он будет перебирать их по-очереди, пока не достигнет конечного элемента.Далее, смотрим, что ты меняешь позициями итераторы p и std::prev(p), если у тебя итератор однонаправленный (судя по всему из описания аргумента шаблона), тогда prev ты не возьмешь!Ну и вообще, надо было так делать: https://ideone.com/JTIcSH
>>1094127Да я сейчас на шарпе гуйню пишу, мне интересна то направление работы, над которым я работаю, но менее интересно программирование, хочу сменить место работы на более интересное, а все вкусные вакансии с пометками QT, ну в общем видимо придется серьезно взяться за плюсы, раз хочу делать качественную работу.
>>1094018Считаешь максимальный профит для каждого элемента каждой строчки последовательно, начиная с первой. Код пиши сам.
>>1094135Покажи хоть одну строчку с алиасом.>>1094150Удалёнка интересна, вариант?
>>1094247Нет, увы, но немного помогаем с релокейтом.
>>1094247#pragma weak wwdg_isr = blocking_handler#pragma weak pvd_isr = blocking_handler#pragma weak tamper_isr = blocking_handler#pragma weak rtc_isr = blocking_handler#pragma weak flash_isr = blocking_handler#pragma weak rcc_isr = blocking_handler#pragma weak exti0_isr = blocking_handler#pragma weak exti1_isr = blocking_handler#pragma weak exti2_isr = blocking_handlerИ т.д. заглушки, да.
Антоны, как засунуть динамический массив в параметры функции? Например searchHui(massiv[x])
>>1094318searchHui(const std::vector<T>& massiv)
>>1094153>Ну ты контакты оставьanime.debil.1999@mail.ru
Анон, есть такая структура данных, которая хранит элементы в списке векторов. Чтобы разобраться в том, как она работает, достаточно разобраться в функции size(). Нужно написать для этой структуры итератор, который выводит все элементы. Итератор проходит по всем векторам, заглядывает в их содержимое, а когда вектор заканчивается, переходит к следующему вектору. Я попытался это реализовать, но класс итератора не компилируется. Не знаю, как написать конструктор, какое поле будет храниться в итераторе и как сделать обход элементов. Помоги написать итератор.https://ideone.com/Vd0Vjs
>>1094372> class Iterator : public std::iterator<std::forward_iterator_tag, ValueType>Такое задепрекейтили в C++17. Ну и уже давно, до депрекейта, рекомендуется делать через iterator_traits.
Витжуальные девелоперы, помогите! У меня есть несколько проектов. Часть из них используют один и тот же код, как быть?1) Создать библиотеку.2) Использовать "Проект общих элементов"Первый метод мне не нравится из-за того, что один из проектов должен потом компилироваться через gcc, а это значит, что мне в нем еще придется компилить библиотеки.Второй метод приводит к тому, что при подкулчении проекта общих элементов, он компилится целиком, вне зависимости от того, действительно ли мне нужны все его элементыЕсть ли еще способы?
void shift(int* a) { for (int i = 0; i < sizeof(a)/sizeof(a[0]) - 1; i++) { int tmp = a; a = a[i+1]; a[i + 1] = tmp; }}int main(){ int m[] = {1,200,3,4,5,7,6,88,99,66}; const int N = sizeof(m) / sizeof(m[0]); shift(m); return 0;}Почему в main эта херня считает правильно 10 элементов, а сделав в функции тоже самое в for оно выдаёт 1 ёбаный элемент??сори за разметку, просто в пастбин никто читать не будет
>>1094431ну вот, на всякий случай с отступамиhttps://pastebin.com/3B5ZkkC3
>>1094437Отступы делаются табами, а пробелами — выравнивание.
>>1094431>Почему в main эта херня считает правильно 10 элементов, а сделав в функции тоже самое в for оно выдаёт 1 ёбаный элемент??Потому что так работает язык.
Кто прогал на Qt? Есть пара вопросиков.Большие бинарники под винду получаются, если standalone и без всяких зависимостей от библиотек?
Смотрю сейчас на степике курс по программированию на c++https://stepik.org/lesson/540/step/5?course=%D0%9F%D1%80%D0%BE%D0%B3%D1%80%D0%B0%D0%BC%D0%BC%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%B8%D0%B5-%D0%BD%D0%B0-%D1%8F%D0%B7%D1%8B%D0%BA%D0%B5-C%2B%2B&unit=863вот на этом видео появился вопрос, зачем делать указатель на указатель в данном случае ? В чем выигрыш ?Или он просто хотел показать, что "так можно"?
>>1094449>вот на этом видео появился вопрос, зачем делать указатель на указатель в данном случае ?Подорвать твою нюфажную жопу.
>>1094453Ясно)
>>1094449> зачем делать указатель на указательОх, как же хорошо, что я забил на кресты еще много много лет назад.Какой же это инфернальный пиздец.
>>1094491Это удобно, когда, например, есть динамический массив указателей (записная книжка из фамилий C-style строк), тогда да, ты создаешь указатель на начало массива из этих указателей, получается указатель на указатель.>>1094449Здесь же конкретно, я не очень понимаю мотивации лектора, возможно это надо для того, что бы просто продемонстрировать такую возможность языка>забил Не осилил универский курс крестов?
>>1094307Пиздец, я-то думал, что у тебя там using. Ни разу эту хуйню не видел.Так, блядь, а .c у тебя тоже компилируется? У тебя ошибки компиляции не того файла, с которого ты скриншот сделал, а того файла, в котором алиасы написаны. Читни про раздельную компиляцию. Как решить:а) если из vector_nvic.c не должно ничего экспортироваться, исключаешь его из сборкиб) в противном случае добавляешь в vector_nvic.c extern void blocking_handler(boid);>>1094392>Есть ли еще способы?Ебануть интерфейс на С-функциях и сделать C++-адаптор на заголовочном файле.>>1094431Потому что размер С-массива известен только тому коду, в котором он определён с размером. Передаёшь массив туда, где нужен указатель - нога мертва. Это сипласплас, блядь, юзай вектор.>>1094447Где-то сравнение видел - большие (есть некоторая экономия в сравнении с динамическими либами, но не такая большая, как хотелось бы). Олсо, где-то видел статейку о том, что можно размер либ сильно сократить, так как, например, библиотека юникода тащит слишком много.>>1094449Заголовок прочти.> В чем выигрыш ?Можно не использовать исключения для сообщения об ошибке. В некоторых случаях это важно, так как у исключений есть оверхед.
>>1094500>Не осилил универский курс крестов? Просто другие дела появились. Университетский то осилил.А потом, не возникало ни желания, ни необходимость, мучить себя этим пиздецом.А сейчас то, есть rust, например, в C# завезли работу с SIMD, нет никаких оснований использовать кресты хоть для чего-то.
>>1094372Анон, хэлб.
>>1094511Ты хочешь сделать так, чтобы итератор проходил через каждый элемент каждого вектора? Тогда тебе нужен итератор не только для ВекторЛиста, но и итератор для вектора. Ты не можешь сделать перечисление всех элементов, храня в итераторе только итератор контейнера векторов.
Напишите функцию поиска первого вхождения шаблона в текст. В качестве первого параметра функция принимает текст (C-style строка), в которой нужно искать шаблон. В качестве второго параметра строку-шаблон (C-style строка), которую нужно найти. Функция возвращает позицию первого вхождения строки-шаблона, если он присутствует в строке (помните, что в C++ принято считать с 0), и -1, если шаблона в тексте нет. Учтите, что пустой шаблон (строка длины 0) можно найти в любом месте текста. Требования к реализации: при выполнении данного задания вы можете определять любые вспомогательные функции, если они вам нужны. Вводить или выводить что-либо не нужно. Реализовывать функцию main не нужно.Я написал свою вариацию наивного алгоритма поиска подстроки, но почему-то платформа степик со своими скрытыми тестами считает решение неверным(не понимаю зачем они это делают, если еще учесть, что у них нет встроенной IDE, а просто текстовое поле для отправки, это вообще дно, они, как кстати большинство отечественных вузовских преподавателей объясняют техническую отсталость оборудования дополнительной хардкорностью, мол это что бы вам было сложнее и вы благодаря этой сложности лучше учились, на самом деле это ошибка.) соре за батхёрт, но накипело:https://pastebin.com/LjUzxSuF
>>1094505>Это сипласплас, блядь, юзай вектор.Я прохожу курс, где есть упражнения с С-подобными строками.>Можно не использовать исключения для сообщения об ошибке. В некоторых случаях это важно, так как у исключений есть оверхед.Спасибо>>1094507>А потом, не возникало ни желания, ни необходимость, мучить себя этим пиздецом.Ну если ты уже работаешь и тебе это непосредственно по работе не нужно и тебе это не интересно самому, то конечно смысла нет.
>>1094505>Читни про раздельную компиляцию.Спасибо няш, кое-как перетрусил проект, повтыкав только необходимые .с-шки, вываливать перестало и скомпилировалось правда, нихуя не заработало, но с этим уже сам как-нибудь разберусь.
sup. В этом вашем С++ можно задавать количество и имя объектов с клавиатуры?В шараге написать задание что описать класс который содержит информацию о вашей библиотеке етц.Вот можно чтобы нажал кнопку оно одну книгу записало, нажал второй раз и ещё одну?да тупой вопрос но я ничего не нагуглил
>>1094613лабы идут на хуй
>>1094613Все можно. В этом и есть смысл классов и объектов.
>>1094632Круто, а как это сделать-то?
>>1094634Тащем-та никаких секретов тут нет, просто садишься и делаешь без задней мысли.
>>1094644У вас тут совсем всё хуёво, да?
>>1094646Какой вопрос, такой и ответ.
>>1094650Ясно, спасибо.
>>1094646Да.Съеби.
>>1094634В общих чертах так:class Book { string name, author, прочая поебень }class Library { Book []books }int main() {int num;cout << "Kol-vo knig?\n";cin > num;Library lib;lib.books = new Book[num];for(int i = 0; i < num; i++) {Book book = new Book();cout << "Kniga №" << i << " Nazvanie?\n";cin >> book.name;cout << "Avtor?";cin >> book.author;lib.books = book;}}Если можно векторы, то можно еще такclass Book { string m_name, m_author; Book(string name, author) { m_name=name; m_author = author; }class Library { vector<Book> books; }int main() {while(1) {string name, author;Library lib;cout << "Nazvanie? (ENTER to quit)\n";cin >> name;if(name == "") break;cout << "Author?\n";cin >> author;lib.books.push_back(new Book(name, author));}}
>>1094665А да, и я наебался, cin же читает до ближайшего пробела.Так что лучше читать строку такstring name;readline(cin, name);
std::array<std::string, 10> numbers = {"zero","one","two","three","four","five","six","seven","eight","nine"};std::string number = "";std::cin>>number;bool exists = std::find(std::begin(numbers), std::end(numbers), number) != std::end(number);Вот у меня есть массив и я решил узнать, есть ли в массиве элемент, совпадающий с number, на что мне выдает ошибку на этапе компиляции.Ошибка 1 error C2678: бинарный "!=": не найден оператор, принимающий левый операнд типа "std::_Array_iterator<_Ty,_Size>" (или приемлемое преобразование отсутствует)https://pastebin.com/vMBrWDmy - на всякий.
>>1094869>bool exists = std::find(std::begin(numbers), std::end(numbers), number) != std::end(number);>std::end(number);Опечатку исправил?
>>1094927БляяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяяВот это я даун.
>>1094928Удачи
>>1094929Спасибо.
https://ideone.com/jWpXl9Ньюфаг в треде, как лучше реализовать это, cin работает не так, как я думал, есть ли безкостыльный вариант?
>>1094940Какая задача ставится?
>>1094941Блин, я думал все мои мысли умееют читать, сорян.Ну вот пользователь вводит число, соответственно записывается в int через std::cin, если это не число, то он будет продолжать вводить, пока наконец-то не введет валидное число, ну и соответственно ему говорится, мол ты вводишь не число, вводи еще раз.
>>1094942Все, уже нашел солюшн. В теле цикла ставлюstd::cin.clear();std::cin.ignore(std::numeric_limits<std::streamsize>::max(), '\n');
>>1094947Проверку .eof() не забудь.
Аноны, есть чувство, что я овощ.Короче, дефолтная задачка, вычислить сумму ряда с точностью до eps через рекурсию.Написал на C++ и Паскале.На паскале все считает, на сипипи всегда ноль выводит.Где я проебался?С++#include "stdafx.h"#include <iostream>//Найти сумму ряда с точностью eps , общий член которого равен An = 1/((3n-2)(3n+1))#define eps 0.01using namespace std;double sum(int n){ if ((1 / ((3 n - 2)(3 n + 1))) < eps) return 0; else return (1 / ((3 n - 2)(3 n + 1))) + sum(n + 1);}void main() { cout << "sum = " << sum(1) << endl;}Pascalprogram summa;const eps: real = 0.01; function sum(n: integer): real;begin if ((1/((3n-2)(3n+1)))<eps) then sum := 0 else sum:= (1/((3n-2)(3*n+1))) + sum(n+1);end;beginwriteln(sum(1));end.
>>1095073Ага, блядь, в разметке я тоже проебался.
>>1095073Снят с аукциона.1.0 не равно 1.Всё дело в том, что я делил единицу.Ну, пиздец.Прошу прощения.Овощ.
На C++ возможно написать бот для вк и парсинг сообщений вк?
>>1095210Покопай в сторону curl, больше ничего не могу сказать
>>1095210Возможно
Где можно почитать четко и доходчиво про взаимодействие итераторов, дабл-линкд листов и нодов. С примерами хорошего кода, а не ебаной мешаниной из нерабочего кода со стак оверфлоу. Мне сдавать ассайнмент в среду, а я уже 3 день нихуя не могу разобраться, как правильно делать ебаный insert в отсортированный линкд-лист. Помогите, пожалуйста.
>>1095278>> insert в отсортированный линкд-листТы поехавший что ли?! В linked list проще выполнять сортировку вставками, чем то, что ты предлагаешь. Тебе нужен skip list если ты хочешь воспользоваться преимуществами двусвязного списка и одновременно быстрым нахождением нужного элемента. А если не хочешь городить велосипеды, то используй std::set и все нахуй
>>1095210>парсинг сообщений вк?Нахуя? Есть готовые библиотеки для работы с ВК.>>1095278Документацию наверни, лолик.http://en.cppreference.com/w/cpp/container/list/insert
Ну и про iterator invalidation не забудь читнуть.
Тут на код ревью (не моего кода) один человек настойчиво пытается донести, что struct'ами в с++ пользоваться зашквар (Frankly, I cannot see any reason to create structs when coding in C++.), прикрывается рекомендательными гайдлайнами (имеющими слово preferred). Собственно, каково ваше отношение к структурам? В данном случае так получается, что есть источник данных, передающий в стурктуре А данные драйверу, который из этой структуры переносит данные в структуру Б от некой сторонней либы (на си написанной), и, собственно, этой сторонней либе эту структуру и посылает. Вот структуру А он хочет на класс заменить. На кой чёрт тут могут понадобиться классы-то? "Ну тип в будущем там может геттеры и код инициализирующий менять не надо, если поля добавятся" не очень катит, так как если что-то и изменится, то код использующий это поменять-таки придётся. Чем так плохи вообще struct'ы-то могут быть? Это ж хороший и удобный контейнер для разнотипных данных, не? Ему ещё и C array'и не нравятся, но это ладно.
И снова вопросы:boost::asio::ip::tcp::socket.Во-первых: у меня есть сразу несколько потоков, которые вызывают io_service::run(), следовательно асинхронные вызовы могут быть исполнены параллельно. Не сломается ли все, если я разом кину и async_write и async_read? Заботиться ли asio о разделении сокета самостоятельно, или это должен делать я?Во-вторых: Информация, которую я передаю, может различаться по важности. Иными словами может так быть, что я захочу прервать передачу какого-то куска данных, что бы вместо него отправить более важный кусок. Как такое вообще делается?
>>1095502Так, еще раз, чем class отличается от struct, за вычетом дефолтного спецификатора доступа? И что это за гайдлайн?
>>1095502Ну хуй знает, структуры это какая-то неюзабельная тема по-моему, даже с точки зрения синтаксиса. То есть в классах всё приятно и понятно, в том числе реализация наследования и полиморфизма (а это обычно очень даже необходимые штуки). То есть структуры -- это си-стайл, и в твоих личных программах можешь хоть как их использовать, но вот в промышленном коде за такое привлекут, конечно.
>>1095512>Так, еще раз, чем class отличается от struct, за вычетом дефолтного спецификатора доступа?Э, ну, если ты намекаешь на то, что это почти одно и то же, то я не против и относительно в курсе.>И что это за гайдлайн?Компании.>>1095513>в том числе реализация наследования и полиморфизма (а это обычно очень даже необходимые штуки). Там нужно собрать вместе 6 комплектов по 4 циферки и закинуть их в железку, зачем тут какие-то полиморфизмы и раследования?>структуры это какая-то неюзабельная тема по-моемуНо чем? Меня, например, даже в питоне напрягает порой отсутствие структур, благо namedtuple есть, спасает.>даже с точки зрения синтаксиса.Но он идентичен же, лол.>То есть в классах всё приятно и понятноЕсть хуёвинка с полями, в которых данные лежат. Куда понятнее-то?>То есть структуры -- это си-стайлНу так оно для дублирования си-стайл интерфейса и сделано же. Я так-то не против классов, меня вот именно в этмо месте это очень смущает, по-моему, идёт вразрез с "нужно уметь выбирать инструмет под задачу".Не подумайте, что я сопротивляюсь и линию свою гну, просто аргументы привожу в надежде к просветлению прийти.
>>1095520>Не подумайте, что я сопротивляюсь и линию свою гну, просто аргументы привожу в надежде к просветлению прийтиКакой же ты молодец.И все же, раз struct и class - одна хуйня, просто пройдитесь автозаменой. struct <ClassName>{ -> class <ClassName>{public:К чему спорить из-за того, что не имеет смысла?
>>1095532И зачем это делать? Просто чтобы прогнуться перед рандом индусом с суевериями против POD struct? Наоборот же намерение лучше выражено в коде.
>>1095533Он о вас ведь так же думает. И кому-то придется погнуться. У вас там нет традиции решать вопросы битвой?
Не шарю в крестах, но даже мне очевидно что структуры нужны, например, для ffi. мимо
Вот что за хуита? А? Что за хуита?
>>1095539Прикрепить текст забыл.
>>1095540Кое-где минус на плюс надо поменять. мимо бегемотик
>>1095540бляfor(i=0;i<n;i++) if(myvector>myvector[i+1]) {}Ну ты шо дядя
>>1095542Спасибо.>>1095541Сука, спалил моих бегемотов.
>>1095542>>1095542А что не так?
>>1095544Оу. Ну в массиве Н элементов, а человек обращается к Н+1. А его нет как бы. Вот и вылетает аут оф рэндж
>>1095545А, понял. Типо когда i = (число элементов) вылетает шайтан-буква.
>>1095547Да. Потому что нумерация в плюсах с нуля начинается
Пацаны, я работал в программе с памятью и у меня комп полетел? Это взаимосвязано?
>>1095506>Заботиться ли asio о разделении сокета самостоятельно, или это должен делать я?Смотря в каком смысле. data race при одновременном доступе к сокету из разных потоков не будет.А если тебе нужен определённый порядок отправки/чтения данных — для этого есть strand.
>>1095548Я заебал, наверное, но он все равно выдает шайтан буква, даже после исправления.
>>1095549Нет
>>1095551так а что ты исправил? обращение по индексу i+1 как было, так и есть. Короче скинь сюда код просто, попробую помочь.
>>1095553Я же сделал условие, что вызывается к i + 1, только если i != n.https://ideone.com/vMYRWh
>>1095540cin >> myVector Ну хуйня же. У тебя нет i-го элемента, а ты в него что-то записываешь.
>>1095554Оно должно сортировать массив, я правильно понимаю?
>>1095557Да, пузырьковым методом.
>>1095558#include <cstdio>#include <cstdlib>#include <iostream>#include <vector>using namespace std;int main(){ setlocale(LC_ALL, "Russian"); int n; cout << "Введите количество чисел в массиве: "; cin >> n; vector<int> myVector(n,0); for (int i = 0; i < n; i++) { cout << "Введите число массив: "; cin >> myVector; } while (true) { for (int i = 0; i < n-1; i++) { if (myVector > myVector[i + 1]) { int value = myVector ; myVector = myVector[i + 1]; myVector[i + 1] = value; } } bool ifSorted = true; for (int z = 0; z < n-1; z++) { if (myVector[z] > myVector[z + 1]) { ifSorted = false; } } if(ifSorted == true) goto escape; }escape: for (int i = 0; i < n; i++) { cout << myVector; } system("PAUSE"); return 0;}
>>1095559Cпасибо! Два чаю тебе.
>>1095558Обосрался со вставкой. Может так увидишь: https://ideone.com/DP0FOhТолько это нихуя не пузырьковый метод, это какая-то срань. Ты направильно свапал(перечитай свой кусок и подумай) и во второй цикле херню написал
>>1095539Там же написано: out of range
>>1095550Нет, порядок мне не нужен, мне просто хотелось, что бы при выполнении асинхронных записи и чтения, они не интерферировали.Спасибо за хорошую новость.
>>1095559Можешь весь код, кроме ввода/вывода на std::sort(myVector.begin(), myVector.end()); заменить.За одно и сложность с O(N^2) снизишь до (N*log(N))
Есть ли жизнь на VS 2017?VS15
>>1095799Только на Clion.
>>1095799Да, конечно. Брат жив, батя щастлив, скоро последние мажорные фичи С++17 завезут.
Есть ли смысл пытаться куда-нибудь устроиться джуном в дс на неполную занятость 25-30 часов, ибо уник еще ? Или бросить эту гиблую затею и пойти дальше окунаться в божественный океан джабы
>>1095862>мажорные фичи С++17Что там такого мажорного? Сделали std::byte вместо unsigned char, как будто раньше нельзя было сделать typedef?
Смешно то, что наверняка std::byte это не встроенный тип, а тайпдеф внутри библиотеки. Нахуя?
>>1095874constexpr if - вот, что я ждал, в общем то и все
>>1095874typedef не запретит арифметические операции.
>>1095876Да, пиздец смешно xDDDDКатаюсь по полу, братиш
По какому имени гуглить такой прием, когда с экземпляром класса мы работаем через специальный "типа-интерфейс" (экземпляр специально созданного класса)?
>>1096034Адаптер, что ли?
>>1095871
>>1085579 (OP)Почему не получается обработать исключение в списке инициализации конструктора?https://ideone.com/Ab9BBi
>>1096249Исключение ловится, но потом оно автоматически перебрасывается выше. http://eel.is/c++draft/except.handle#14Такое исключение значит, что объект не будет создан, поэтому оно и перебрасывается. Если бы этого не происходило, то после, программа пыталась бы использовать не созданный объект.
Читал книгу Ахо А.В., Хопкрофт Д., Ульман Дж.Д. Структуры данных и алгоритмы.Возникло несколько вопросов,1 Чем отличается абстрактный типа данных от класса? Класс это частный случай АТД?2 Почему в С и во многих других языках индексация массивов начинается с 0, а не с 1, как в Паскале, Фортране итд. Ведь если она начинается с 1, то удобно задавать нулевой указатель, как 03 Что такое тип данных "курсор" и чем он отличается от указателя?4 Если брать C++, например, то какие аналогичные структуры данных там есть 3м основным:ячейка - переменная и массив,запись - объединение,а файл в плюсах это что?Заранее спасибо
>>1096465>>1 Чем отличается абстрактный типа данных от класса? У ADT операции внешние (свободные функции), у классов это методы.
>>1085579 (OP)Привет, погромисты!Хочу вкатиться, для начала просто до уровня "я что-то в этом понимаю", а потом, быть может, и посерьезнее взяться за программирование, если хорошо пойдет. Но вот вопрос - с какого языка начать? Думаю между JS и C++ как самыми ходовыми и распространенными, но сам решить не могу. Помогите с выбором, что ли. Какие плюсы, минусы, где используется и какие перспективы. С меня как обычно.
>>1096500Начни с Хаскеля.
>>1096469Статический метод что ли, как в Джаве?
>>1096511Свободные функции.
Посоны, ньюфаг в треде.Как конвертнуть из "12.5cm" в double(12.5) и string(cm)?
или еще лучше, без конвертации в "cm" сразу из std::cin определить что там cm или нет.
>>1096531Гугли регулярные выражения.
>>1096531>>1096535А все, std::cin умнее меня, если стоит std::cin>>double>>string, то при вводе 12.5cm, он записывает 12.5 в double и cm в string, охуеть.
>>1085579 (OP)Анон, помоги мне написать функцию, которая принимает число в виде строки и конвертирует его в произвольный тип T. Нужно, чтобы при ошибке конвертации функция бросала исключение bad_from_string, но я не знаю, как это сделать.https://ideone.com/imtnao
>>1085579 (OP)Посоветуйте для изучения несложную консольную программу, чтобы работала в несколько потоков (делающих разве задачи), которые бы между собой синхронизировались. Без Qt, лучше на Boost. Вообще, предлагаю хорошо написанные программы заносить в список, а список - в шапку.
>>1096656Просто перехватывай дефолтное и кидай свое, если я правильно понялhttps://ideone.com/d6HEB2
>>1085579 (OP)Пытаюсь написать MapReduce. https://ideone.com/jnlMj2Почему компилятор ругается на вызов std::async?Как вообще реализовать эту концепцию, чтобы преобразование подпоследовательностей происходило в отдельных потоках, результаты потом сворачивались, и при этом исходная последовательность не изменялась?
Хочу сделать какое-то свое небольшое декстоп приложение для гитхаба на C++. Может кто-нибудь подсказать идею? Обязательно должна использоваться многопоточность. Есть примерно два месяца свободного времени.
>>1096896>>Почему компилятор ругается на вызов std::async?Пот омуч то нужна функц ия, ане шаб лон функици
>>1085579 (OP)Анон, какое корректное определение имеют шаблоны C++? Я видел два определения, претендующих на строгость:1) Шаблон это проект или формула для создания классов или функций2) Шаблон это семейство классов или функций, параметризуемое типамиКакое определение точное, правильное и непротиворечивое?
>>1097233> какое корректное определение имеют шаблоны C++?http://eel.is/c++draft/temp#1>претендующих на строгостьВ каком смысле?
>>1097233> какое корректное определение имеют шаблоны C++?Лучше так http://eel.is/c++draft/temp#def:template
>>1097240>В каком смысле?Ну меня просто замучил один уебан, который требовал от меня строгие непротиворечивые определения на собеседовании.
>>1097250Систему аксиом и правил вывода он тебе предоставил, чтобы ты мог проверить строгость и непротиворечивость им?
Мега тупой вопрос, но я встрял.https://ideone.com/NvGAaOКак пропустить пустую строку и читать дальше?
>>1097296en.cppreference.com/w/cpp/io/basic_istream/ignore
>>1097296представь что ты ешь еду, макарошки там с сосисочкой. поел, и начал пить чай, а потом понял, что у тебя был кетчуп. ты берёшь шприц, заливаешь в него кетчуп, втыкаешь шприц себе в желудок и вводишь.вот так же и у тебя: ты читаешь ввод пользователя в main и в последующих ветках кода, хотя можешь делать только один getline, парсить строку и дальше по распаршенным данным что-то делать.поменяй это, и тогда легко сможешь решить проблему с пустой строкой.
>>1097299Да, я так и делал сначала, просто думал. что можно как-то всё это без распарса сделать.проиграл
Аноны, застрял казалось бы на простой задачке по ООП.Создайте программу, которая бы запрашивала у пользователя целые числа(до тех пор, пока не будет введено отрицательное число) и размещала ихв коллекции типа множество и мультимножество . Реализуйте два варианта программы: первый вариант должен выводить содержимое коллекции по возрастанию, а второй — по убыванию.1) Как использовать push_back и push_front одновременно?2) Как реализовать коллекцию, чтобы я вводил целые числа и они выводились в коллекции?
Ваше говно еще не сдохло?
>>1097394Нет, ты еще жив и воняешь.А вообще, какая существует замена C++ общего назначения? В продакшене одно говно с ВИРТУАЛЬНЫМИ МАШИНАМИ и огромным рантаймом. Или вовсе недоязычки, выполняющиеся в бравузере.
>>1097396CRustGoDJavaScalaErlangElixirClojureHaskellPythonЛюбой из этих языков лучше в своей сфере, чем этот ебаный франкенштейн.
>>1097398Ну и катись отсюда в свой Го, говноед. В каком еще языке может такое функциональное метапрограммирование шаблонов в compile-time?
>>1097415Так нахуя это кому вообще надо в реальной жизни? Protip: никому.Алсо, твои кривые шаблоны сразу выдают в тебе ньюфажика.
>>1097417>Так нахуя это кому вообще надо в реальной жизни?Нахуй кому нужна реальная жизнь?>твои кривые шаблоны сразу выдают в тебе ньюфажикаЧто с оими шаблонами не так?
>>1097420>Нахуй кому нужна реальная жизнь?Ой маня маня..Еще и аваторофаг.
Почему компилятор вычисляет 46-е число Фибоначчи на порядки быстрее, чем это делает обычная рекурсивная функция?
Привет анон. решил почитать рекомендуемую в шапке книжку Страуструпа, но наткнулся на проблему, что в MINGW походу нет библиотеки std_lib_facilities.h. Какой тогда лучше скачать компилятор, чтоб при обучении не сталкиваться с проблемой отсутствия библиотек, используемых автором?
>>1097444Лучше читай Липпмана.
>>1097446А какую IDE с компилятором посоветуешь для 32-битной винды?
>>1097451Очевидная студия 17 года или QtCreator.Палю годноту https://stepik.org/course/7
ну же> Есть ли смысл пытаться куда-нибудь устроиться джуном в дс на неполную занятость 25-30 часов, ибо уник еще ? Или бросить эту гиблую затею и пойти дальше окунаться в божественный океан джабы
Планирую начать изучать мультиплеер в играх и отличное от http post get сетевое взаимодействие. С чего начать?
>>1090510https://ideone.com/XH1TMFне?
>>1095549> JSБраузерный фронтенд, скрипты, ГУЙ для плюсовых программ, куда там ещё пытаются впихнуть его.> и C++ОС, эмбеддед, высокопроизводительные программы, игры. Гуй тоже можно писать.Отличия от JS: строгая типизация и строгое структурирование программы, стандарт соблюдается лучше, RAII вместо GC, многие вещи описываются более многословно, шаблончики могут вскрыть мозг.В обоих случачаях твоей ступне не поздоровится. Язык нужно использовать тот, который используется в книге, которую ты читаешь. Начинать можешь с C.>>1097253THIS>>1097382>1) Как использовать push_back и push_front одновременно?>в коллекции типа множество и мультимножество В set и multiset есть только insert, ЧСХ. (multi)set - сортирующий контейнер. Ещё есть unordered_set.>>1097382>2) Как реализовать коллекцию#include <set>>они выводились в коллекции?штоблядь>>1097435Бенчмарк в студию.>>1097444Прочти внимательно предисловие:http://www.stroustrup.com/Programming/std_lib_facilities.hЭто не либа компилятора, блядь.>>1097479В мывамперезвонимтреде или ньюфаготреде спроси.
>>1097420>Что с оими шаблонами не так? Они для C++98
Сап. Чё за хуйня такая?#include <iostream>#include <list>#include <iterator>#include <vector>int main(){ typedef std::vector<int> conteiner; typedef conteiner::iterator itereter; conteiner azaza={1,2,3,4,5}; auto it =azaza.end(); std::cout<< *it << std::endl; return 0;}На cppreference как про std::vector::end(), так и про std::list::end() говорится, что "attempting to access it results in undefined behavior. "Но код выше выводит:%численная поебень%5А если заменить vector на list, выводит:55Разыменование std::list<int>::end() с полученим значения реального последнего элемента в листе - это баг или фича? Или это свойство моего конкретного конпелятора?
>>1097610Это свойство undefined behaviour, блядь.
Почему такая ересь скомпилировалась и нормально работает, это же ошибка, потому локальная переменная и в функции foo и bar должны уничтожиться по завершению функции, а я спокойно присваиваю несуществующую переменную другим переменным в mainhttps://pastebin.com/4L4hA6tb
>>1097657>Почему такая ересь скомпилировалась и нормально работает, это же ошибкаЭто UB, а UB не относится к нарушению diagnosable rules. Так что компилятор не обязан выдавать диагностических сообщений и прерывать компиляцию.
>>1097762а почему это работает?
>>1097766>>1097762>Это UB
Анон, подскажи пожалуйста. Моя цель - в процессе работы программы вывести данные объектов-детей(childFirstClass, childSecondClass, etc) одного класса(parentClass) в таблицу (а пока в дебаг). Сейчас я пытаюсь это сделать следующим образом: В процессе работы в контейнер объявленный как std::map <unsigned long, parentClass> storage;записываются данные следующим образомfor (int i = 0; i < 99; i++) { childFirstClass tb = new childFirstClass(); storage.insert(std::make_pair((unsigned long)storage.size(), tb)); qDebug() << tb->extract_readable_data(); // (1) qDebug() << storage.at(i).extract_readable_data(); // (2)}Соответственно в выводе дебага я получаю в случае (1) правильные данные, вызывается версия функции принадлежащая объекту класса-ребёнка, а в случае (2) я получаю вызов функции класса-родителя. Как мне сделать так чтобы и в случае (2) вызывалась функция класса-ребёнка?Мне кажется, я иду вообще не верным путём. Какой путь верный?extract_readable_data() выглядит так:class parentClass{private:public: parentClass(); ~parentClass(); virtual QString extract_readable_data() { return QString("Data is unreadable: parent class"); };};class childFirstClass{private:public: childFirstClass(); ~childFirstClass(); QString extract_readable_data() { return QString("Successful read"); };};
>>1097778Знаки указателей съела вакаба
https://2ch.hk/pr/res/1077271.htmlhttps://2ch.hk/pr/res/1077271.htmlhttps://2ch.hk/pr/res/1077271.htmlhttps://2ch.hk/pr/res/1077271.htmlhttps://2ch.hk/pr/res/1077271.html
>>1097795Динахуй.>>1097778Самый надёжный и типобезопасный путь - сделать метод виртуальным. Оверхед незначителен, если только ты не вызываешь этот метод хуйзнаетсколько раз и ничего в этом методе не делаешь. В таком случае тебе лучше делать static_cast, но он нетипобезопасен (компилятор и рантайм не шлёпнут тебя по руке за приведение не к тому типу).
>>1097815>сделать метод виртуальнымНу я так и делаю, но явно косячу.class parentClass{virtual QString extract_readable_data() {return QString("Data is unreadable: parent class");};class childFirstClass : public parentClass{QString extract_readable_data() {return QString("Successful read");};>static_castТоже не подходит, потому что классов-детей может быть много и нужно как-то определять к какому классу-потомку делать статик_каст. Возможно моя ошибка в >std::map <unsigned long, parentClass> storage;? Какой есть лучший способ хранить объекты разных классов в одном контейнере? Шаблоны?
>>1097973> но явно косячу.У тебя правильно написано.>Какой есть лучший способ хранить объекты разных классов в одном контейнере?std::variant или std::shared_ptr>Шаблоны?штоблядь>std::map <unsigned long, parentClass> storage;>storage.insert(std::make_pair((unsigned long)storage.size(), tb));Нахуй тебе std::vector с функциями std::map?
Точнее, это std::vector с функциями std::list или что это блядь вообще такое.
>>1097988>Нахуй тебе std::vector с функциями std::map?Ну изначально планировалось, что unsigned long - будет уникальным айдишником объекта. Но потом я понял что пока уникальный айди не нужен, а если понадобится, то его лучше будет хранить внутри объекта.>std::variantТо что нужно, спасибо!Но сразу вопрос. А как его использовать если неизвестны имена будущих классов-детей?Т.е., вот сейчас это будетstd::variant<parentClass, childFirstClass, childSecondClass> classesVariant;Но если вдруг мне потребуется подгружать в программу новые классы и их объекты через плагины или какой-либо иной механизм подключения, то как расширить определение classesVariant для его восприятия объектов нового класса, чьё имя заранее неизвестно?
О, в MVS 2015 нельзя подключить <variant>.
>>1098112Так что теперь у каждого класса будет свой вектор объектов класса, а ещё будет вектор указателей на векторы с объектами классов. Проблема решена.
Реализуйте функцию getline, которая считывает поток ввода посимвольно, пока не достигнет конца потока или не встретит символ переноса строки ('\n'), и возвращает C-style строку с прочитанными символами. Обратите внимание, что так как размер ввода заранее неизвестен, то вам нужно будет перевыделять память в процессе чтения, если в потоке ввода оказалось больше символов, чем вы ожидали. Память, возвращенная из функции будет освобождена оператором delete[]. Символ переноса строки ('\n') добавлять в строку не нужно, но не забудьте, что в конце C-style строки должен быть завершающий нулевой символ. Требования к реализации: при выполнении данного задания вы можете определять любые вспомогательные функции, если они вам нужны. Определять функцию main не нужно.Почему моё решение выдаёт Wrong answer??https://pastebin.com/chdNyG3gchar getline(){ char c; // заводится переменная для хранения в ней введенного символа char str = new char[1]; // выделяется память на динамический массив длиной в 1 элемент size_t size = 1; // размер массива str for (int i = 0; std::cin >> c && c != '\n'; ++i) { // до тех пор пока не будет введен символ перевода строки str = c; //заносим введенный символ в последний элемент массива char* tmp = new char[1+ size]; //выделяем память на массив длиной масиива length(str) + 1 элемент for (int j = 0; j < size; ++j) { //копируем значения str в tmp tmp[j] = str[j]; } delete[]str; //удаляем данные по адресу str str = tmp; //перенаправляем указатель str на область памяти, где записаны старые значения + 1 свободный элемент size++; //увеличиваем размер элементов массива на 1 tmp = 0; //обнуляем указатель tmp } return str;}
>>1098160Реализовал тебе за счеку, проверяй
>>1098044Это статическая типизация без GC, здесь тру-полиморфизм без изместного наперёд дерева объектов только на указателях.>>1098160>char* tmp = new char[1+ size]; //выделяем память на массив длиной масиива length(str) + 1 элементУ меня от этого брат умер! Нахуй выделять поштучно? Ууууу блядь у тебя там квадратичная сложность ниже в коде нахуй!>Wrong answer??Это "неправильный ответ" по-русски штоле?>tmp = 0; //обнуляем указатель tmpНахуя.Олсо, внимательно прочти задание.
ВАЖНЫЙ ВОПРОСЕсть что-нибудь типа джавадока для си++ и VS2015?Ну, то-есть, я хочу, чтобы у меня для классов/функций/новых_файлов сразу создавался шаблонный коментарий.То-есть:1) Для новых файлов - это в начале коммент с лицензией, датой и именем.2) Для функций - слот для описания функции и всех параметров/аутпута.3) Для класса - просто слот для описания.Чёт в гугле ничего толкового не пишут.
>>1098412Добавлю.Пробовал TripleSlashCpp, но он вообще не кастомизируемый, генерирует только комменты для функций/классов и в формате xml, что мне не очень нравится. Лучше, чем ничего, конечно, но всё-равно довольно убогий.
>>1098412Doxygen
Вопрос на засыпку, где выделяется память для строк в библиотеке <string> по новому стандарту целиком на стеке или в куче??
ньюфаг вкатилсяИнтересует разработка под VR и разработка десктоп приложений, подскажите как с этим справляется c++, есть ли вакансии и много ли их, рассматриваю не только Россию но и возможность фрилансить или вообще завестри трактор.Слышал что плюсы не нужны и юзают только на заводах
>>1098586твой стек и есть куча, но не совсем
>>1098586Память для самого объекта выделяется в зависимости от того, как ты его создал - на стеке или в куче. Объект выделяет хранилище с помощью аллокатора либо использует SSO - хранит строку прямо в себе. В новом стандарте ничего не поменялось.
>>1098611>твой стек и есть куча,последние стандарты C++ определяют, что строки должны поддерживать оптимизацию коротких строк (small string optimization, SSO), которые располагаются на стеке целиком. Строки подлиннее всё так же живут в куче. Стек не такой большой, чтобы складывать на него данные произвольной длины.
>>1098628>последние стандарты C++ определяют, что строки должны поддерживать оптимизацию коротких строкСсылочку на параграф.
Хочу поменять местами две bucket в unordered_multimap.Ну допустим был std::unordered_multimap azaz={1,2,3,4,3,2,1}, который при выводе for (auto&& i : azaz){std::cout << i;} давал:3311224, а хочется поменять местами bucket'ы с тройками и единицами, чтобы выводилось 1133224.Такое возможно?
>>1098790Нет.
>>1098628ты с пуфон-тредом не перепутал ли, скажи еще, что они из хэш-таблицы достаются
>>1098628>>1098772Впрочем, я не так прочитал. Сначала прочитал как "строки должны реализовывать SSO", а не позволять её.
>>1098628>которые располагаются на стеке целикомПерестаньте путать место хранения объекта и стек.auto huy=new string;Где хранится *huy?
>>1085579 (OP)ПЕРЕКАТhttps://2ch.hk/pr/res/1099142.htmlhttps://2ch.hk/pr/res/1099142.htmlhttps://2ch.hk/pr/res/1099142.htmlhttps://2ch.hk/pr/res/1099142.htmlhttps://2ch.hk/pr/res/1099142.html