Программирование


Ответить в тред Ответить в тред

<<
Назад | Вниз | Каталог | Обновить тред | Автообновление
505 24 155

C Programming Language #40 /clang/ Аноним # OP 20/02/19 Срд 05:19:18 13511811
C Programming L[...].png (78Кб, 792x1023)
792x1023
Тред, посвященный прародителю всех С-подобных языков и по совместительству единственному идеальному и всесторонне годному средству программирования как на системном, так и на прикладном уровне.

Пожалуйста, пользуйтесь https://ideone.com/ или https://pastebin.com/ для вставки кода, если он длиной больше нескольких строк или содержит [​i​] или ∗.

Что читать:

- Brian Kernighan, Dennis Ritchie "The C Programming Language": http://www.cypress.com/file/56651/download
- Stephen Prata "C Primer Plus, 6th Edition" (2014): относительно свежая, знает про C89/C99/C11, описывает различия, объемная (около тысячи страниц), годная, с вопросами, упражнениями и ответами. Читать после K&R или до.
- Zed A. Shaw "Learn C the Hard Way" (2015): годное пособие для гуманитариев для гуманитариев!
- Немного примеров хорошего стиля: http://www.oualline.com/books.free/style/index.html
- ООП, например: http://www.cs.rit.edu/~ats/books/ooc.pdf
- Стандарт ISO/IEC 9899:1999 (он же C99): http://www.open-std.org/jtc1/sc22/wg14/www/docs/n1256.pdf (драфт)
- Стандарт ISO/IEC 9899:2011 (он же C11): http://www.open-std.org/jtc1/sc22/wg14/www/docs/n1570.pdf (драфт)
- man/Dash/zealdocs

Чем компилировать:

- Очевидный GCC.
- clang: оче годно, батя рекомендует.
- Intel C++ Compiler: оптимизации, тысячи их.
- Visual Studio 2017 Community Edition: внезапно этим стало можно пользоваться, особенно с тулсетом clang/C2. Поддержка C11 на уровне "есть все, что тебе понадобится в реальном проекте плюс кривая библиотека". Анализатор кода в комплекте.
- Pelles C (шиндоуз онли): поучиться, вкатиться в C11 (стандарт полностью реализован, имеются в том числе threads.h и прочие stdatomic.h), но количество багов в оптимизаторе и редкие апдейты напрочь отбивают желание собирать этим что-то сколько-нибудь серьезное.
- TCC: очень маленький компилятор с багами и поддержкой C99. С ключом -run умеет компилировать код в память и запускать его, что позволяет писать скрипты прямо на сишечке.

Что еще почитать:

http://c-faq.com/
FAQ из comp.lang.c. Древний, но все еще актуален.

Samuel P. Harbison, Guy L. Steele Jr. "C: A Reference Manual, 5th Edition" (2002)
Ебаный пересказ стандартов C89 и C99 (включая стандартную библиотеку). Для не осиливающих стандарт в оригинале. Читать в качестве подготовки к собеседованиям (есть задачник с ответами) и для ознакомления с масштабами пиздеца перед написанием своего парсера/компилера.

Peter Van Der Linden "Expert C Programming. Deep C Secrets" (1994)
"Си: грязные истории". Смехуечки, немного объяснений, чем обусловлены особенности языка, всем известные подводные камни кто там ругал косяки в JS? у нас в сишечке их гораздо больше, просто они лучше спрятаны, немного байтоебли и непонятно откуда взявшаяся глава про старинные плюсы. Читать в качестве сказки на ночь (на пару вечеров хватит).

Richard M. Reese "Understanding and Using C Pointers. Core Techniques for Memory Management" (2013) - почитать, вкатиться в указатели.

Ben Klemens "21st Century C: C Tips from the New School" (2012)

Paul Deitel, Harvey Deitel "C for Programmers with an Introduction to C11" (2013)

Stephen G. Koch@n "Programming in C (3rd Edition или 4th Edition, если найдется)" (2014)

MISRA Ltd. "Guidelines for the Use of the C Language in Critical Systems" (2013)
Набор рекомендаций по написанию надежного кода на C (промышленный стандарт). Читать - однозначно, следовать - вдумчиво и без фанатизма. Также можно посмотреть https://www.securecoding.cert.org/confluence/display/c/SEI+CERT+C+Coding+Standard

Еще более длинный список: http://www.iso-9899.info/wiki/Books#Learning_C

Онлайн-утилиты:

- https://godbolt.org/ - Compiler Explorer позволяет посмотреть выхлоп компиляторов для введенного куска кода (больше полусотни разных версий компиляторов).
- http://cdecl.org/ - С Gibberish ↔ English помогает читать сложные сишные декларации.

Прошлые треды:

- №37: https://arhivach.ng/thread/414099/
- №38: https://arhivach.ng/thread/419611/
- №39: https://arhivach.ng/thread/423396/
Аноним 20/02/19 Срд 05:31:51 13511832
Буду первым, как в школе 21.
Аноним 20/02/19 Срд 05:54:40 13511843
>>1351183
>первым
А теперь глянь на номер поста
Аноним 20/02/19 Срд 07:18:44 13511864
>>1351184
Учи мемы, чтобы не быть баттхертом.
Аноним 20/02/19 Срд 15:45:11 13513585
15-figurnaja-3-[...].jpg (74Кб, 600x600)
600x600
Пацаны, есть адекватный алгоритм по созданию пятнашек на сишечке? Вообще с чего начать, хочу сделать сам для курсача, в гугле нашел уже готовый код, но я хочу понять и сделать сам.
В принципе, что гуглить? Мб в каких-то книжках алгоритмы есть?
Аноним 20/02/19 Срд 17:04:07 13513966
>>1351358
Что конкретно вызывает вопросы?
Аноним 20/02/19 Срд 17:36:39 13514197
изображение.png (8Кб, 668x331)
668x331
>>1351396
>>1351358
В общем, ожидая твоего ответа, успел сам уже склепать.
https://pastebin.com/7uYq3NqH
Никаких сторонних либ. (А код впрочем все равно говно)
Аноним 20/02/19 Срд 17:55:05 13514318
>>1351396
Сам алгоритм создания программы, с чего начать, как действовать, то что создать массив 4x4 и заполнить его 15 случайными числами я понимаю, а на счет реализации хз.
Аноним 20/02/19 Срд 17:55:56 13514329
>>1351419
Можешь описать свои действия, алгоритм там, вся хуйня, хочу сам попробовать со своим кодом
Аноним 20/02/19 Срд 18:02:01 135143710
>>1351431
>>1351396
плюс еще вызывает вопросы одна вещь, расставлены числа в рандомном порядке и одна свободна, то есть перемещать число можно только на свободную позицию.
Аноним 20/02/19 Срд 18:16:06 135144311
изображение.png (9Кб, 668x331)
668x331
>>1351437
Ля, совсем правила забыл. Перепилил. Только тут ты указываешь, куда смещается ноль (свободная позиция), но это не критично.
https://pastebin.com/9uhB2wiF

Как делал.
Вспомнил правила (плохо вспомнил).
Создал игровое поле. Подумал, как его заполнить. Решил не заморачиваться, а тупо по порядку поставить числа и затем случайные пары поменять местами 8 раз. Реализовал.
Далее написал отладочный вывод поля. Проверил.
Решил не заморачиваться с пользовательским вводом, и сделал быстро и на отъебись. Потом прикрутил сдвиг в зависимости от команды. Упихал все это в цикл. Написал проверку на конец игры. Если конец - цикл завершается.
Аноним 20/02/19 Срд 18:25:41 135145012
>>1351443
Спасибо, бро. Попробую. Если что-то непонятно будет еще поспрашиваю , ты не против?
Аноним 20/02/19 Срд 18:58:28 135147313
>>1351431
Создаешь массив и делаешь функции для перемещения чисел в этом массиве.
Понятное дело что сначала надо разобраться с алгоритмом, т.е прикинуть куда что и как можно двигать. В каких случаях можно двигать, а в каких нельзя. Т.е сделать логику алгоритма пятнашек в максимально простом и упрощённом виде.
А дальше уже думать над его интеграцией в язык и принять соответствующие поправки в алгоритм и провести оптимизацию с учётом возможностей языка. Может быть какие-то моменты будут труднореализуемые, а какие-то наоборот реализовать будет очень просто.

При составлении любого алгоритма сначала его надо продумать на бумаге, без языка. Не надо зацикливаться на том что умеет язык, а что не умеет. Придумай законченный алгоритм и логику управления. Если ты изучал дискретные автоматы в универе, то примерно с таким же ходом рассуждений и строй алгоритмы. Чтобы они были максимально простые. А уже потом думай над реализацией. Если логика алгоритма сделана правильно, то и реализация будет несложной.
Аноним 20/02/19 Срд 19:12:54 135148114
>>1351473
>Если ты изучал дискретные автоматы
Если не изучал, с чего начать? Можно ли вкатиться в алгоритмы сразу по Седжвику или нужно начинать с автоматов?
Заканчиваю Прату читать, хочу ещё глубже.
я другой анон
Аноним 20/02/19 Срд 19:34:39 135149615
>>1351443
Имей в виду, что ты не можешь просто заполнить поле рандомными числами.
У поля есть алгебраическая чётность, и если ты поменяешь две позиции местами, то их невозможно будет собрать, т.к. чётность поменяется.
Аноним 20/02/19 Срд 19:59:22 135151716
>>1351481
Автоматы не надо. Это мне проще так просто. Если не изучал, то и не надо.
Тебе с обычной дискретной математики лучше
Аноним 20/02/19 Срд 22:33:12 135160317
Если рекурсия занимает больше места в памяти, то почему бы не отказаться от них и использовать цикл?
Аноним 20/02/19 Срд 22:45:02 135160618
>>1351603
Некоторые алгоритмы значительно проще и понятней в рекурсивной записи. Если есть увереность что ресурсов хватит что можно спокойно рекурсии навернуть и не ебаться пытаясь придумать итеративный алгоритм (не всегда просто). Можешь, к примеру, попробывать quick sort реализовать итеративно. Сложного, конечно, ничего нет, но суть проблем можно уловить.
Аноним 20/02/19 Срд 22:47:25 135160719
>>1351603
Проблема не только в памяти, интерактивные алгоритмы работают, как минимум не медленнее, а чаще всего и быстрее.
Аноним 20/02/19 Срд 22:47:59 135160820
>>1351607
Итеративные*
блядский т9
селф-фикс
Аноним 20/02/19 Срд 22:54:31 135161221
Тут что-то про рекурсию должны кодеры в функциональщине раскидать. Ведь у них нет циклов как таковых. Алсо вопрос. Любой ли рекурсивный алгоритм можно переписать итеративно? И наоборот соотвественно.
Аноним 20/02/19 Срд 22:56:11 135161522
>>1351606
Понятное дело, что итеративный будет выглядеть более громоздким. Но он же будет и более эффективным. Рекурсивный выглядит красuво, но программирование ведь идёт ради результата, а не процесса.
Аноним 20/02/19 Срд 22:58:47 135161623
Аноним 20/02/19 Срд 23:02:06 135162024
>>1351517
Спасибо.
>обычной дискретной математики
Не, ну так-то у меня техвышка есть, просто хочу исполнить мечту детства и вкатиться в си.
Аноним 20/02/19 Срд 23:03:17 135162125
happy-grin-l.png (136Кб, 1120x977)
1120x977
Аноним 20/02/19 Срд 23:03:36 135162226
>>1351615
> Но он же будет и более эффективным
Нет. Пруф: алгоритмы умножения Карацубы и Штрассена.
К тому же, с оптимизацией хвостовой рекурсии рекурсивный алгоритм эквивалентен итеративному.
Аноним 20/02/19 Срд 23:04:56 135162327
>>1351615
>ради результата, а не процесса
Ты не лишпер. И даже не линуксоед.
Аноним 20/02/19 Срд 23:05:09 135162428
>>1351621
На ведре куча клав, в том числе с коррекцией ввода.
Аноним 20/02/19 Срд 23:05:43 135162529
Как число(например 120) из массива int перенести в массив char?
И вообще как записать число 120 в строку?
Аноним 20/02/19 Срд 23:06:44 135162630
>>1351622
>с оптимизацией хвостовой рекурсии рекурсивный алгоритм эквивалентен итеративному
Осталось только объяснить зачем в 99.9% задач использовать хвостовую рекурсию, если итеративный эквивалент уже есть.
Аноним 20/02/19 Срд 23:08:33 135162831
>>1351625
ВНЕЗАПНО рекурсивно, запись начинай с последней цифры.
Аноним 20/02/19 Срд 23:10:32 135162932
>>1351628
Блядь, не то имел ввиду.
Начинай обрабатывать число с конца, и тогда:
>запись начинай с последней цифры.
Аноним 20/02/19 Срд 23:15:27 135163433
>>1351615
В большинстве случаев результат это красивый и быстрый в написании и понимании код, а не ебля с бессмусленной эффективностью. Это если профилирование покажет что код сликом медленный (ну или ты точно знаешь что пришешь критический к времени выпонения код) тогда уже расчехляешь эффективность. Проблема скорее в том чтобы понимать когда рекурсия наглядней - рекурсивные алгоритмы не всегда проще итеративных. Плюс идиоматика - если в конретном языке/проекте все привыкли ебашить циклами, то совать рекурсию стоит очень осторожно.
Аноним 20/02/19 Срд 23:59:38 135166034
>>1351625
Дать чару указатель туда же куда и инт? Если не получится, прибавь sizeof(int)-1.
Не получится ну и хер с ним.
Аноним 21/02/19 Чтв 00:05:20 135166435
>>1351634
Просто к тому что вот если писать какие-то функции для небольших программ и говорить, мол, сделаю рекурсию, ведь памяти дохуя это одно. Но когда ты используешь это же самую функцию в большом проекте где эта рекурсия часто всплывает, да ещё есть и куча других рекурсивных алгоритмов, то это в конечном итоге экспоненциально увеличивает потребление памяти.
Вон, многие жалуются на то что их баузер жрёт много памяти, может проблема растёт отсюда? Или другие программы.

Я могу конечно хуйню нести, так как вещаю со своей колокольни, но мне это видится именно так
Аноним 21/02/19 Чтв 00:07:16 135166536
>>1351625
Вообще есть int2char или что-то в этом роде.
Аноним 21/02/19 Чтв 00:42:11 135168937
>>1351626
Потому что его может и не быть. Например цепочка функций, каждая из которых вызывает следующую. Переписать итеративно может быть сложно, а тут компилятор всё сам заинлайнит, увидит хвостовую рекурсию и оптимизирует её. Или нет.
Аноним 21/02/19 Чтв 00:49:40 135169238
>>1351665
int2char в Си называется snprintf.
Аноним 21/02/19 Чтв 05:04:47 135175039
>>1351692
Наркоман?
int i = 5;
char c = i; // int2char лол
Аноним 21/02/19 Чтв 08:09:18 135176540
>>1351750
Ты, конечно, хитрожоп, но он не получит от такого ожидаемого. Поскольку 5 символ в таблице символов != '5'. Тогда уж i+'0' писал бы.
Аноним 21/02/19 Чтв 08:28:20 135177241
>>1351625
>Как число(например 120) из массива int перенести в массив char?
>И вообще как записать число 120 в строку?

Если с насыщением - то chararray = (char)(intarray>SCHAR_MAX?SCHAR_MAX: (intarray<SCHAR_MIN?SCHAR_MIN: intarray));
Аноним 21/02/19 Чтв 08:42:18 135177342
>>1351765
>ожидаемого
>char
Неужели? А если подумать?
Аноним 21/02/19 Чтв 10:16:34 135178843
>>1351772
Никогда не понимал, зачем так использовать тернарныйоэ оператор, получается же громоздкая ебота, легче на ифах написать и будет намного более понятно и красиво.
если у тебя это один тернарный оператор — Окей, но когда у тебя один вложен в другой это ужас.
Аноним 21/02/19 Чтв 12:51:43 135184744
>>1351788
> но когда у тебя один вложен в другой это ужас
На самом деле, тернарный оператор из-за его приоритета красиво чейнится, и все отлично читается. А вот так как у анона ставят скобки от незнания приоритетов, и такое действительно читать сложно.
x = (expr1) ? res1 : (expr2) ? res2 : (expr3) ? res3 : res4;
Аноним 21/02/19 Чтв 13:29:32 135187145
>>1351788
Не обращай внимания. Это называется ребенок-сосунок нашел новую игрушку, а возюкает её весь день подряд, всю обслюнявив от радости. Перебесится и пройдет или нет. но это уже терминал
Аноним 21/02/19 Чтв 13:38:17 135187546
Прочитал чутка про графы и решил сделать свой.
https://pastebin.com/tRAaADPb
Насколько всё плохо?
Аноним 21/02/19 Чтв 13:56:27 135188547
123242432543534[...].png (3Кб, 321x196)
321x196
>>1351628
>>1351660
>>1351665
>>1351772
1)Делал через itoa, в итоге получилось только с цифрами(1-9), а, например, вместо числа 10...19 выдает 1, вместо 20...25 - 2.
2)Делал через функцию, возвращающую указатель делением на 10, выдает тоже самое(пикрелейтед)
1) https://pastebin.com/6eB2U82V
2) https://pastebin.com/nD0SwttJ
В чем проблема?
анон >>1351625
Аноним 21/02/19 Чтв 14:06:41 135190148
>>1351885
Куда ты лезешь? Си это не скрипт, а низкоуровневый язык для обращения (фактически) напрямую к железу. Сначала разберись что такое простые числовые переменные и указатели, как работает память, как они в ней представлены. В строки лезь только потом, потому что строки это навороченное предыдущее, вдобавок с магией. Ты же лезешь в алгебру не понимая арифметику.
Аноним 21/02/19 Чтв 14:10:46 135190449
>>1351885
>массив указателей вместо многомерки
откуда к нам пожаловал?
Аноним 21/02/19 Чтв 14:11:40 135190550
Аноним 21/02/19 Чтв 14:19:23 135191351
>>1351905
Можно вообще написать так
int a;
char b;
b = a;
Компилятор будет ругаться, но операцию сделает. А ругается потому что в инт это 4 байти, а чар 1 байт и часть числа ты потеряешь, если в инте число больше 1 байта.
Аноним 21/02/19 Чтв 18:38:47 135210852
>>1351885
char b[4] = "";
itoa(120, b, 10);
printf("%s\n", b);

В чем проблема JS мастер или питон гуру?
Аноним 21/02/19 Чтв 19:38:57 135215853
>>1351913
А почему этот вариант не проходит? Зачем лишние телодвижения с битами делать? Вы ж всё равно не ужмёте 4 байта в 1.
Аноним 21/02/19 Чтв 19:59:27 135217354
Пытаюсь реализовать графы через структуру.
Есть две структуры типа вершина и ребро. Правильно ли будет, если в структуре вершины сделать указатель на ребро с которым он соединён? А в структуре ребра сделать указатель на вершину, к которому он идёт?
Или это пустая трата времени и надо сделать проще?
Аноним 21/02/19 Чтв 21:25:19 135220355
>>1352173
Пустая трата времени, кроме случаев когда у тебя с ребром связана куча информации и тебе необходимы манипуляции над ними по типу взять конкретное ребро в одной части графа и переместить в другую. Но мне сложно представить где это может понадобиться. Алсо при таком подходе твое ребро получается просто специфическим классом вершины - такое ребро это вершина которая может быть связана только с двумя "настоящми" вершинами (олин радитель и один потомок).
Аноним 21/02/19 Чтв 23:07:15 135228156
>>1352203
Я делаю так.
В вершине указатель показывает на адрес исходящих ребер. В ребрах - адреса куда они ведут. Т.е в принципе списочная структура получается.
Можно ребра не делать вообще, а показывать связи только между нодами. И веса там же делать, но это то же самое получается почти как по мне.
В общем не знаю. Таким способом просто хочу закрепить навыки применения разных фич языка. Но как дело доходит до реализации различных алгоритмов для модели, то тут пока ещё всё не очень.
Аноним 21/02/19 Чтв 23:39:03 135229857
>>1352281
> но это то же самое получается
Тоже самое, только без лишней сущности (ребра). Делая ребро отдельным ты ничего не выиграваешь, только лишнийуказатель заводишь.
>И веса там же делать
Вес ребра это по факту свойство ноды. Это не ребро такое охуенное что у него такой вес. Это нода такая что у нее есть ребро с таким-то весом.
Выделять ребра в отдельную сущность может быть смысл если у тебя с ребром связано много дополнительной информации, и количество ребер у каждой ноды может самое разное. Тогда ты заводишь в ноде массив и туда складываешь нужное количество ребер (ссылок на них). Что-то типа префиксного дерева.
Аноним 22/02/19 Птн 02:53:08 135236858
Capture.PNG (8Кб, 871x187)
871x187
Придумал для себя шпаргалку, лол.
Аноним 22/02/19 Птн 09:45:47 135242059
>>1352368
Да это и так легко запомнить.
Ещё вот
int m = malloc(5 sizeof m);
int n[5];
Эти строчки эквивалентны.
И вот ещё
(m+3) или m[3]
n[3] или *(n+3)
тоже эквивалентны
Аноним 22/02/19 Птн 09:49:10 135242160
Screenshot2019-[...].png (75Кб, 1080x2160)
1080x2160
>>1352420
Звёздочки потерялись.
Аноним 22/02/19 Птн 10:57:15 135244761
>>1352420
Неэквивалентны, выделять память на стеке и на куче это не одно и тоже.
Алсо:
Можно и так, но не нужно, хы.
n[3]=★(n+3)=★(3+n)=3[n]
Аноним 22/02/19 Птн 12:04:31 135248162
>>1352421
Разве не так?
int m = (int)malloc(5 * sizeof(int));
Аноним 22/02/19 Птн 12:07:43 135248463
>>1352481
Каст в си необязателен, в этом случае вообще не нужен.
В плюсах обязателен.
Аноним 22/02/19 Птн 14:54:52 135255764
>>1352420
>>1352421
Этот sizeof явно из какого-то другого языка, далекого от Си.
Аноним 22/02/19 Птн 14:58:49 135255965
>>1352484
Какой смысл в 2019 использовать си? Разве что под микроконтроллеры пишешь, но там нет выбора, а где он есть, нет смысла себя ограничивать.
Аноним 22/02/19 Птн 15:06:10 135256266
изображение.png (818Кб, 1280x720)
1280x720
Си без знания плюсов, сейчас актуален? И будет ли дальше таковым?

Выкатываюсь из бэка на питоне в низкоуровневое и пытаюсь понять куда грести
Аноним 22/02/19 Птн 15:11:22 135256567
В ассемблере не разбираюсь. if(x) func(); и x && func(); --тождественно?
Аноним 22/02/19 Птн 15:28:36 135257168
>>1352559
>под микроконтроллеры пишешь, но там нет выбора
Жава.
Аноним 22/02/19 Птн 15:29:35 135257269
Аноним 22/02/19 Птн 16:27:25 135260570
Аноним 22/02/19 Птн 16:37:45 135261071
>>1352559
Собственно, почему бы и нет?
Аноним 22/02/19 Птн 16:38:37 135261172
>>1352605
А подробнее, интересно просто.
Аноним 22/02/19 Птн 17:53:59 135266173
>>1352557
А что не так с ним? Скобки не обязательны же, просто желательны для читаемости.

>>1352565
> тождественно?
Нет. Второе - выражение, и у него есть значение. Если возьмешь tcc или gcc с -O0, то они будут считать && (в том числе конвертить результат вызова функции в int), чтобы сразу после этого его тупо выбросить. Хотя нормальные компиляторы соптимизируют, конечно. Ну и, естественно, если функция возвращает void, то второй варинт вообще не скомпилируется.
Аноним 22/02/19 Птн 18:10:17 135267574
>>1352481
Это устаревший вариант. Необязательно так делать.
Аноним 22/02/19 Птн 18:12:00 135267775
>>1352447
Но ведь на cs50 сказали что одно и то же. Да и массивы в си это указатель ведь с выделенным диапазоном памяти.
Аноним 22/02/19 Птн 18:13:32 135267876
>>1352559
Обучение.
Микроконтроллеры.
Да и вообще полезно знать.
Аноним 22/02/19 Птн 18:21:34 135268277
>>1352420
Вообще неэквивалентны. Садись, два.

>>1352677
Не сказали, говорили о другом, просто ты неправильно понял.
Аноним 22/02/19 Птн 18:29:40 135268678
>>1352682
Но ведь если я выделю таким образом память, то смогу обращаться к нему через m[0] или m[2], т.е обращаться к любому его члену. И проводить те же самые операции как если бы я объявил его в виде массива.
Так почему не эквивалентны? Где можно увидеть разницу?
Аноним 22/02/19 Птн 18:32:15 135268879
>>1352686
Пока что единственное отличие то что дебагер показывает массив как массив, а указатель только первый элемент.
Аноним 22/02/19 Птн 18:37:06 135269480
>>1352686
Ладно, понял что в первом случае делается куча, а во втором стек. Их расположение разное, но в целом работают почти одинаково.
Аноним 22/02/19 Птн 19:34:41 135272381
>>1352559
Сынок, будущее за робототехникой, так что затолкай свой скриптовой язык глубоко себе в анал и пиздуй на хуй отсюда-->
Аноним 22/02/19 Птн 19:56:38 135273482
>>1352723
Но ведь роботов программируют на питоне и джаве...
Аноним 22/02/19 Птн 20:16:10 135274383
>>1352734
Один робот на джаве уже уебался в стену.
Аноним 22/02/19 Птн 20:31:49 135275184
>>1352559
В хард рил тайме (авто, авиация, медицина и тп) запрет на динамическое выделение памяти.
Аноним 22/02/19 Птн 21:04:56 135277085
>>1352743
Ну и что, зато джава не тормозит.
Аноним 22/02/19 Птн 21:05:58 135277286
>>1352751
В авто все пишут на джаве. В авиации и критических областях используют всякие Ады, на дырявой сишке никто в здравом уме руками такое писать не будет.
Аноним 22/02/19 Птн 21:13:03 135277487
>>1352770
При 16 гб памяти подтормаживает меньше, согласен.
Аноним 22/02/19 Птн 21:14:02 135277688
Аноним 22/02/19 Птн 22:43:32 135280989
А как хранить данные, что бы данные в программе после обработки моих функций оставались в физическом состоянии навсегда?
То есть не в ОЗУ на 1 процесс, а как база данных. Только через File?
Но как тогда хранить разные типы данных?
Аноним 22/02/19 Птн 22:48:53 135281190
>>1352809
> Но как тогда хранить разные типы данных?
типданных данные;
fwrite(&данные, sizeof(данные), 1, fp);
Аноним 22/02/19 Птн 23:00:40 135281591
>>1352811
это будет как база данных?
Аноним 22/02/19 Птн 23:43:57 135282592
>>1352734
2жды иди на хуй Маня!
Аноним 22/02/19 Птн 23:45:44 135282693
Опытные товарищи, утешьте советом. У меня дипломная работа по булевым сетям (нахождения аттрактора). Стоит ли катать такое дело на любимой Сишечке, или себе дешевле вспомнить кресты?
Аноним 22/02/19 Птн 23:46:14 135282794
>>1352826
Я бы выбрал си. А ты как хочешь.
Аноним 22/02/19 Птн 23:46:47 135282895
>>1352826
нахождениеЕ аттракторОВ
22/02/19 Птн 23:49:15 135283096
Аноним 23/02/19 Суб 00:10:15 135283997
>>1352694
Ага, почти одинаково (за исключением того, что между ними нет ничего общего). Читай дальше, k&r скачай.
Аноним 23/02/19 Суб 00:13:57 135284098
>>1352774
Сколько раз объяснять, что джава и джаваскрипт - это РАЗНЫЕ ЯЗЫКИ.
Аноним 23/02/19 Суб 00:14:47 135284199
>>1352840
Тогда почему у них так много ощих буковок в названии?
Аноним 23/02/19 Суб 00:59:21 1352849100
>>1352841
Язык программирования, как и любую другую технологию, можно рассматривать минимум с двух сторон: "сверху-вниз" (лингвистика, т.е. собсно язык, синтаксис, вот это все) и "снизу-вверх" (реализация). Виртуальная машина, на которой запускается байт-код, и браузерный интпретатор, который парсит скрипт, это принципиально разные вещи, и буковки в названии тут ни к чему. Но для серьезной робототехники шо то хуйня, шо это хуйня. Виртуальная прослойка между софтом и реальной архитектурой со всякими сборщиками мусора и прочим гавном - это ни разу не про системы реального времени.
Аноним 23/02/19 Суб 01:03:15 1352852101
>>1352849
Я вообще-то того джависта хотел жирно потроллить, а ты взял и всю малину испортил. Но не суть. Если ты робототехник, то поясни за аппаратную часть роботов. Какие двиганы обычно используются? Как запитываются, какие аккумы? Какая трансмиссия для двиганов используется, если используется вообще?
Аноним 23/02/19 Суб 01:07:34 1352854102
>>1352852
далек от робототехники. Только читал Таненбаума про операционки)
Аноним 23/02/19 Суб 02:22:30 1352865103
>>1352562
Зачем тебе знание расширенного си чтобы писать на си? Да и вообще современный крест уже мало общего имеет с 89-99 стандартами сиши, вот до-диез — это да — тупо сишка расширенная
Аноним 23/02/19 Суб 04:39:41 1352880104
>>1352865
>современный крест уже мало общего имеет с 89-99 стандартами сиши
Чурбан у тебя на плечах имеет мало общего с интеллектом.
Аноним 23/02/19 Суб 08:39:41 1352909105
изображение.png (11Кб, 619x600)
619x600
Что делает данный код? Не могу понять.
Аноним 23/02/19 Суб 09:43:00 1352928106
>>1352839
Узнал что к стеку обращение идент быстрее чем к куче, плюс не факт что в куче будет ещё нужный участок памяти.
Но пока не заметил разницу когда использовал ту и другую запись. Всё ещё не понимаю в чём они так разительно отличаются, если можно и к тому и другому обращаться через m[n].
Если нужен динамический массив, то использую маллок, плюс ему можно делать реаллок в случае чего и прочее, что нельзя делать с обычным массивом.
Аноним 23/02/19 Суб 09:54:10 1352929107
>>1352852
У меня диплом бакалавра и вот в этом году будет диплом магистра по специальности мехатроника и робототехника.
Но всё ещё не знаю про сабж. Единственное что помню из курса связанное с роботами это расчет кинематики через матричные преобразования.
Думаю там используются синхронные движки с постоянным магнитом pmsm или как их там. Ну или другие, с возможностью регулирования положения. Но точно не шаговые, даже в чпу их уже не юзают.
Каждая степень свободы регулируется собственным движком, в старых роботах типа тур-10, который стоит у нас в лаборатории, используется цепной привод, а движки стоят у основания.
На сочленениях стоят силомоментные датчики или что-то вроде этого.
Про аккумуляторы не могу ничего сказать. Судя по всему, если их и используют, то с расчетом на то что он сможет выдержать нагрузку от частотного преобразователя.
Аноним 23/02/19 Суб 10:22:09 1352938108
>>1352909
>ft
Опять со школы 21 , сукке.
Аноним 23/02/19 Суб 10:22:42 1352939109
>>1352909
Очевидно, выводит комбинацию.
Комбинаторика.
Аноним 23/02/19 Суб 10:31:57 1352940110
>>1352909
до чего же всрат этот код, господа...
Аноним 23/02/19 Суб 14:34:33 1353092111
>>1352928
> обращение
Это выделение массива на стеке быстрее. А время обращения к стеку и куче одинаковое. Ну максимум первый хит в массив на куче может быть слегка дороже, но потом данные все равно в кэш попадут.

> чём они так разительно отличаются
Выделение массива на стеке - это что-то уровня sub esp,размер (одна инструкция, иногда две). Выделение массива в куче - десятки инструкций в самом лучшем случае (если у аллокатора в пуле блоков есть пустые слоты подходящего размера). Алсо, у массива на стеке и указателя на динамически выделенную область памяти разные типы, банально sizeof вернет разные размеры.

>>1352938
Вы эту школу второй тред упоминаете. Это какой-то локальный CS50 или просто урюпинская СОШ, где начали учить сишку?
Аноним 23/02/19 Суб 14:38:33 1353101112
>>1353092
>Вы эту школу второй тред упоминаете
Причем тут это, чувак задания из школы шлет. Значит он там щас учится в бассейне и просит решений
Аноним 23/02/19 Суб 14:41:26 1353110113
>>1352694
Не понял, как в кучу записывать и как в стек?
Аноним 23/02/19 Суб 17:17:31 1353294114
>>1353110
Я так понимаю, стек создаётся при компиляции программы. Т.е при первом запуске программы он выделяет фиксированный участок памяти для явно заданных переменных и программа не будет потреблять меньше этого диапазона. Но может потреблять больше, если мы будем выделять память в куче.
Аноним 23/02/19 Суб 17:25:40 1353303115
>>1352686
Для тебя - программиста laba1 с видоса ютуба, эквивалентны. Объяснять таким бесполезно, если начнешь писать настоящие программы, сам сразу поймешь разницу, а раз не видишь, значит и нет её.
Аноним 23/02/19 Суб 17:36:50 1353321116
>>1353303
Не можешь объяснить - значит сам не знаешь.
Аноним 23/02/19 Суб 17:47:41 1353326117
>>1353321
Тебя еще вчера послали читать к&р, хуль ты тут мозги ебешь? Это самые основы, еще попроси объяснить тебе, что такое функция или указатель, и в ответ на резонное "пошел нахуй" возрази "не можешь объяснить значит сам не знаешь))0)"

другой
Аноним 23/02/19 Суб 18:02:48 1353338118
Поясните плез нубу, для чего в этих строках эти %c%c%c%c?
fprintf(fp_out, "DATA%c%c%c%c", 4, 0, 0, 0);
fprintf(fp_out, "%c%c%c%c", 9, 0, 0, 0);
Аноним 23/02/19 Суб 18:08:05 1353349119
>>1353294
>если мы будем выделять память в куче.
В куче выделять это типо маллок?
Аноним 23/02/19 Суб 18:09:31 1353350120
>>1353338
Ору.
Че тоже из школы "гениев"?
Аноним 23/02/19 Суб 18:13:33 1353353121
>>1353350
Нет. Не надо переходить на личности пожалуйста.
Аноним 23/02/19 Суб 18:15:59 1353356122
>>1353349
Да. Куча это свободная на машине оперативная память. А стек физически тоже находится в оперативной памяти, но он считается зарезервированным самой программой. Ну, как я понял.
Аноним 23/02/19 Суб 18:17:59 1353358123
>>1353353
Местные "сеньоры" не могут иначе. Ввиду своей ущербности они показывают таким образом своё превосходство над другими дабы потешить чсв.
Аноним 23/02/19 Суб 18:38:27 1353372124
>>1353356
Так как именно выдедять ту или иную? Я не допер
23/02/19 Суб 18:48:18 1353379125
>>1353358
Даун, для даунов есть закреплённый тред.
Аноним 23/02/19 Суб 19:09:02 1353400126
>>1353372
Когда определяешь обычную переменную например, то она находится в стеке. А когда указатель и ему прописываешь маллок, то в куче.
Аноним 23/02/19 Суб 19:10:34 1353401127
>>1353358
Если человек не может нагуглить элементарных вещей, то ему не место в этом треде. Это тред про си, а не про обучение программированию детей с дефектами развития.
Аноним 23/02/19 Суб 19:14:54 1353406128
153806726013673[...].jpg (43Кб, 700x393)
700x393
Аноним 23/02/19 Суб 19:20:50 1353411129
Аноним 23/02/19 Суб 19:22:08 1353414130
>>1353379
>>1353401
Собственно, что и требовалось доказать. Оскорбления, посылы нахуй. Вот это вот всё.
23/02/19 Суб 19:44:12 1353425131
>>1353414
Доказал? Теперь иди на хуй.
Аноним 23/02/19 Суб 20:04:17 1353440132
Аноним 23/02/19 Суб 20:30:10 1353492133
>>1353414
Двачую бля. Какие то токсичные челики тут сидят. В cpp-треде меня никто не оскорблял никогда, а тут сразу после первого же вопроса.
23/02/19 Суб 20:40:00 1353502134
>>1353492
>В cpp-треде меня никто не оскорблял никогда
только руководствуясь принципом "не тронь говно".
Аноним 23/02/19 Суб 20:44:24 1353504135
>>1353502
Чувак, извини, но ты какой то поехавший.
23/02/19 Суб 21:20:58 1353527136
Аноним 23/02/19 Суб 22:19:18 1353578137
>>1353414
Съеби в /soc обсуждать свои трудные отношения с обществом, тут тред о программировании на си.
Аноним 23/02/19 Суб 22:30:37 1353586138
>>1351625
int num = 10;
char byte = 0;

byte = (char) num;
Аноним 23/02/19 Суб 23:12:05 1353605139
>>1353338
> для чего в этих строках эти %c%c%c%c?
Видимо, кто-то собирался параметры для этих %с изменять динамически, чтобы в файле было DATA и 8 каких-то байт (сейчас 04 00 00 00 09 00 00 00). А если константы, как сейчас, можно было прямо в строку за-escape-ить: "DATA\0x04\x00\x00\x00\0x09\0x00\0x00\x00" и писать fwrite-ом.

>>1353492
У нас обычно тоже мирно, но иногда набегают неадекватные дети.
Аноним 23/02/19 Суб 23:55:57 1353639140
Правильно реализовал стек? Для калькулятора с польской записью хочу сделать
https://pastebin.com/NS1Hb4xJ
Аноним 24/02/19 Вск 00:33:59 1353654141
>>1353639
Норм, но если бы делал empty ascending, не пришлось бы инициализировать sp. И еще в Си в пустых скобках void пишут, это тебе не кресты.
Аноним 24/02/19 Вск 00:39:30 1353659142
>>1353654
>Норм, но если бы делал empty ascending
В любом случае пришлось бы иметь указатель на вершину. К слову sp не нужен, если я в нулевом элементе буду хранить его, т.к туда не записывается ничего. Почему бы и нет собственною
Аноним 24/02/19 Вск 01:02:33 1353676143
>>1353605
Вот да, кстати, замечал, что чем меньше у человека опыта в какой-либо технологии / каком-либо ЯП, тем неадекватнее он себя ведет в соответствующих тредах. Речь, разумеется, идет о тех, кто в принципе позволяет себе подобное поведение.
мимо другой анон
Алсо, подкиньте, пожалуйста, годной литры по Cmake, ну или скажите, хватит ли мне "mastering cmake"? Книжка вроде относительно толстая, а времени на освоение не так много, за вечер до базового уровня подтянуть надо.
Аноним 24/02/19 Вск 01:34:19 1353687144
>>1353676
> Cmake
Там недавно на швабре как раз цикл статей постили, глянь их.
Аноним 24/02/19 Вск 01:35:27 1353688145
Аноним 24/02/19 Вск 01:46:33 1353690146
Phew.PNG (21Кб, 661x80)
661x80
Сделал последнее задание первой главы K&R; Пришлось немножко попердеть, но я справился (наверное). Делюсь решением:
https://pastebin.com/fzJWvZvM
Аноним 24/02/19 Вск 03:24:52 1353700147
>>1353690
Эта задачка легко решается при помощи стека, но ты написал какой-то пиздец.
Аноним 24/02/19 Вск 04:45:14 1353702148
>>1353700
>напишите программу проверки синтаксиса С
>какой-то пиздец
Какая задача, такое и решение. Пиздец пиздецу идеально подходит.
Аноним 24/02/19 Вск 09:38:56 1353724149
>>1352909
Выводит цифры до 789? Кому не похуй что он делает, если он выглядит как говно?
Унеси это говно отсюда и съеби в ньюфаг тред со своими задачками
Аноним 24/02/19 Вск 10:45:39 1353735150
В пизду кресты, буду писать все на Си. Рейт.
Аноним 24/02/19 Вск 10:54:14 1353738151
Аноним 24/02/19 Вск 10:59:59 1353740152
>>1352815
Это будет "как база данных".
Аноним 24/02/19 Вск 11:02:13 1353741153
Аноним 24/02/19 Вск 11:48:16 1353784154
Каков алгоритм печати десятичного числа из двоичного кода?
24/02/19 Вск 11:50:31 1353788155
>>1353784
printf "%d" что-то там....
Аноним 24/02/19 Вск 11:56:45 1353795156
>>1353788
Не, я имею ввиду как устроен printf...
Аноним 24/02/19 Вск 12:00:41 1353797157
>>1353795
Вроде понимаю надо выписывать чаром, остаток от деления числа с конца на 10 и тд., но что не складывается
Аноним 24/02/19 Вск 12:16:09 1353801158
>>1353797
Ебанутый? Пойди таблеток выпей.
Аноним 24/02/19 Вск 12:21:35 1353804159
>>1353801
Что не так? Хочу напечатать не используя стандартный принтф, а только putchar().
Аноним 24/02/19 Вск 12:40:49 1353811160
>>1353804
Тебе нужно узнать какой char соотвествует 0, какой 1 и т.д. и отправлять их, а не просто цифры 0,1 и т.д.
Аноним 24/02/19 Вск 12:47:53 1353814161
изображение.png (715Кб, 2560x1440)
2560x1440
Что я делаю не так?
Аноним 24/02/19 Вск 12:52:00 1353819162
>>1353811
Хм, то-ли я и в правду ебанутый, то-ли меня не правильно понимают, бряк. Вот есть int= 16; (0x10) представим что нету принтф() но есть putchar(), и как мне напечатать десятичное, используя лишь эту последовательность битов.
Аноним 24/02/19 Вск 13:10:51 1353832163
>>1353814
Там вроде нужно линковать на уровне сборки, или короче добавь в main.c include`ы getop, getch, stack
Аноним 24/02/19 Вск 13:13:11 1353834164
gdfh
Аноним 24/02/19 Вск 13:13:53 1353835165
Аноним 24/02/19 Вск 13:16:01 1353840166
>>1353814
1) Собираешь в IDE, не научившись (видимо) собирать вручную.
2) Не видишь полного лога сборки (видимо, предыдущая вкладка?).
3) Либо не линкуешься к stack.o, либо не собирается stack.c, либо функции в stack.c объявлены как static, либо у них другие имена.

>>1353819
x = 16;
while (x) {
putchar('0' + (x % 10));
x = x / 10;
}
Только это выведет задом наперед. Можешь, например, не выводить числа сразу, а класть их в массив, и потом выводить массив с конца. Или класть в стек. Алсо, при x == 0 ничего не выведет, это тоже нужно обработать.
Аноним 24/02/19 Вск 13:18:27 1353843167
>>1353835
Тебе прямо в задании намекнули, что полноценное решение может быть очень и очень сложным. Например:
char c[] = "test\
test";
или
#define RBRACE }
while (1) { RBRACE
Аноним 24/02/19 Вск 13:46:02 1353855168
>>1353819
Бляяя, куда ты лезешь? Это не сценарная хуйня. Вообще не лезь в подобные алгоритмы до того как узнаешь о типах данных, выкинь это нахуй. Вот нахуя тебе принтф если ты не ебешь чем отличается чар от инт? Принтф это путчар с перделками — форматированием аутпута.
Аноним 24/02/19 Вск 13:50:00 1353867169
>>1353814
Написано же "неопределенная ссылка на push и pop", компилятор не знает что это такое. Ищи в каком файле эти функции и включай его в свой main.c
Аноним 24/02/19 Вск 13:53:06 1353873170
stack.PNG (29Кб, 780x498)
780x498
>>1353832
Добавил, но тогда вообще странная фигня получается, цифры в консоли не вводятся, а стоит ввести букву сразу выдает ошибку, даже без нажатия ввода.
>>1353840
>Собираешь в IDE, не научившись (видимо) собирать вручную.
Ну, в книге эта тема не затрагивалась
> Не видишь полного лога сборки (видимо, предыдущая вкладка?).
Ты про Build log? Там написано тоже самое
>Либо не линкуешься к stack.o, либо не собирается stack.c, либо функции в stack.c объявлены как static, либо у них другие имена.
Так, что такое stack.o? Как statick ничего не объявлено, да и имена те же
Аноним 24/02/19 Вск 13:54:55 1353875171
>>1353855
>Принтф это путчар с перделками
Ты кретин, а он всё понимает и правильно задает вопрос, просто ленивое хуйло и не хочет сам думать/делать.
Аноним 24/02/19 Вск 14:04:14 1353889172
>>1353875
Бля ты тупой или что? Сходи поскроль хедер принтфа и нахуй тоже. Принтф выводит посимвольно ВСЕ что ты в него задашь, кроме того на что ссылается %. И своего друга с глупыми вопросами тоже забери.
Аноним 24/02/19 Вск 14:08:53 1353897173
Аноним 24/02/19 Вск 14:18:44 1353910174
>>1353873
Я не спец, но простым языком; для объединения фйлов в одну программу тебе нужно либо слинковать файлы(все кроме того где main()) при сборке в твоей IDE, либо вставляя include`ами друг в друга

>>1353889
Я и спрашивал как он печатает то что в %, int например. Этот анон >>1353840 уже помог.
Аноним 24/02/19 Вск 14:21:24 1353911175
>>1353910
...ну то-есть не нужно инклудить все файлы друг в друга, можешь например в главном файле вставить нужные.
Аноним 24/02/19 Вск 14:22:51 1353913176
>>1353897
> Что дальше делаем?
дальше делаешь make linux test
Если у тебя какой-то популярный дистрибьютив, и не нужны какие-то необычные флаги (или вообще модифицированый код) то лучше поискать готовые пакеты в репозиториях.
Аноним 24/02/19 Вск 14:29:50 1353924177
>>1353889
>кроме того на что ссылается %
Сообразил? Вот и славно. Только в следующий раз СНАЧАЛА думай, а потом хлебало разевай, а не наоборот как тут вышло.
Аноним 24/02/19 Вск 14:33:01 1353930178
>>1353924
Ты просто образцовый дегенерат.)
Аноним 24/02/19 Вск 14:33:10 1353931179
>>1353913
А если надо без всяких make, liux и mingw, чисто чтобы понять как в tcc под win32 компилировать свои будущие охуительные проекты на примере сборки lua?
Аноним 24/02/19 Вск 14:41:15 1353937180
>>1353897
>Как скомпелировать lua в tcc
>в tcc
А можно? У меня сложилось впечатление, что tcc это игрушечная хуйнюшка, которой только собственные хелловорлды можно собрать. Твой исходник луа под какой компилер выложен, мм?
Аноним 24/02/19 Вск 14:50:56 1353943181
>>1353937
Я попробовал по совету отсюда https://www.lua.org/manual/5.3/readme.html#other

tcc lua.c lapi.c lcode.c lctype.c ldebug.c ldo.c ldump.c lfunc.c lgc.c llex.c lmem.c lobject.c lopcodes.c lparser.c lstate.c lstring.c ltable.c ltm.c lundump.c lvm.c lzio.c lauxlib.c lbaselib.c lbitlib.c lcorolib.c ldblib.c liolib.c lmathlib.c loslib.c lstrlib.c ltablib.c lutf8lib.c loadlib.c linit.c

Вроде скомпилилось в один файл lua.exe без ошибок. Всё правильно сделал?
Аноним 24/02/19 Вск 14:52:23 1353944182
>>1353931
> компилировать свои будущие охуительные проекты на примере сборки
Парень, поверь, если ты не представляешь как скомпилировать свою лабу, то не стоит вскрывать эту тему. Не знаю что там конкретно у луа, но скорее всего сборка там представляет собой тысячи строк отборной скрипто дрисни (учитывая что это кроссплатформа).
Выйди на улицу, прогуляйся, подыши свежим воздухом, обдумай свою жизнь. Потом отрывайй документацию по своему компилятору и разбирайся как откомпилировать один файл. Потом два. Потом как линкануть библиотеку. Там понемногу переползай на make или что-то подобное. А там уже можешь начинать (понемногу) читать сборочные скрипты крупных проектов.
> без всяких make
Никак. Система сборки может быть встроена в ide, можно не использовать конкретно make, но вручную ты усрешся компилировать что-то крупное.
Аноним 24/02/19 Вск 14:55:25 1353948183
>>1353943
Ну запусти и посмотри. Может и да.
Аноним 24/02/19 Вск 14:57:42 1353951184
Аноним 24/02/19 Вск 15:02:01 1353954185
>>1353873
> Ну, в книге эта тема не затрагивалась
А что за книга? В целом, ты просто открываешь консоль, идешь в директорию с проектом, и говоришь gcc main.c stack.c calc.c getop.c (если gcc в path нет, указываешь полный путь).

> Так, что такое stack.o?
Программу можно собирать либо по файлу, явно компилируя файл за файлом в объектные файлы (сс stack.c -o stack.o), а потом линкером собирать их в исполняемый, либо можно скормить все файлы компилятору сразу (как я показывал выше), а он сам вызовет линкер. IDE обычно компилируют по отдельности.

Можешь выложить куда-нибудь все файлы проекта?

>>1353944
> но вручную ты усрешся компилировать что-то крупное.
Но с Lua у него внезапно получилось. Как так-то?
Аноним 24/02/19 Вск 15:02:35 1353955186
>>1353948
Да, хелловорды на луа отлично работают. Удивительно.
Аноним 24/02/19 Вск 15:02:56 1353956187
>>1353954
>сс stack.c -o stack.o
сс stack.c -o stack.o (да, мне стыдно)
Аноним 24/02/19 Вск 15:03:56 1353958188
Аноним 24/02/19 Вск 15:08:27 1353962189
>>1353958
Что то затесалось 4 файла от визуал студии
Аноним 24/02/19 Вск 15:10:21 1353965190
>>1353958
> <Unit filename="main.c">
> <Option compilerVar="CC" />
> </Unit>
И это все. Ты файлы в проект не добавил. Поищи там Project->Add files или правой кнопкой в панели проекта. Или я хуй знаю, как в этих ваших кодеблоксах сказать компиляторы, чтобы он компилировал.

> Керниган Ритчи же
Там в Getting started рассказывали про компиляцию из консоли. Не из под винды правда, но подход везде одинаков.
Аноним 24/02/19 Вск 15:11:42 1353966191
>>1353955
Ну там проблемы (при компиляции) в основном из-за зависимостей (особенно системных библиотек/вызовов). А луа походу нихуя не левого тянет поэтому и компилировать нет никаких проблем - закинул исходники и все. Плюс размер небольшой - раздельная компиляция не нужна.
Аноним 24/02/19 Вск 15:23:01 1353974192
>>1353965
Короче странное дело, создал новый проект, добавил туда файлы из прошлого и все заработало
Аноним 24/02/19 Вск 15:36:12 1353998193
>>1353974
Если старый проект остался попробуй в нем clean project сделать.
Аноним 24/02/19 Вск 15:56:52 1354035194
>>1353966
Тоже думал там полно зависимостей как обычно, вот и не соберешь, а оно вот как. Везение новичков, лол?
Аноним 24/02/19 Вск 16:08:47 1354056195
>>1353954
>Но с Lua у него внезапно получилось. Как так-то?
TCC очень простой, экстремально примитивный, там даже линкера нет. С любым нормальным компилятором вручную обосрешься пердолиться.
Аноним 24/02/19 Вск 16:21:00 1354075196
>>1354056
> там даже линкера нет
Как нет? tcc -c foo.c -o foo.o && tcc foo.o bar.c вполне работает. И вообще, это все же компилятор, никто не мешает ld дергать, если нужно что-то более сложное.

> С любым нормальным компилятором вручную обосрешься пердолиться.
Небольшие проекты, если им сделать ./configure или руками config.h сделать вменяемый, достаточно часто успешно собираются cc *.c без всяких мэйкфайлов. Если не собираются, это либо какие-нибудь извращения (например, fossil, там внешний препроцессор дергается), либо просто код сложный, зависящий от ключей компилятора и т. п.
Аноним 24/02/19 Вск 16:32:17 1354088197
>>1354075
>Как нет?
В смысле для тебя нет, просто пишешь tcc main.c и он выплевывает экзешник. Ни про какие опции, объектные файлы, линкеры ты и не узнаешь даже что они существуют.
Аноним 24/02/19 Вск 17:29:19 1354113198
>>1354088
> просто пишешь tcc main.c и он выплевывает экзешник
Просто пишешь gcc main.c и он выплевывает экзешник.
Аноним 24/02/19 Вск 19:19:52 1354211199
>>1351181 (OP)
Объясните, зачем нужна лестница из else-if
if ( ) { }
else if ( ) { }
else if ( ) { }
else if ( ) { }
else { };
если можно послать всех нахуй и сделать лестницу из одних if, которая будет делать тоже самое?
if ( ) { };
if ( ) { };
if ( ) { };


Аноним 24/02/19 Вск 19:24:41 1354221200
>>1354211
Будет, но не всегда.
if-else подразумевает выполнение только одного из блоков.
Много if могут выполниться все.
В зависимости от того, что ты за условия даёшь, конечно.
Аноним 24/02/19 Вск 21:20:22 1354331201
>>1354211
Если условия не взаимоисключающие, то нихуя не то же самое. Вот если return в теле, то ок, но все равно желательно не нарушать логическую структуру.
Аноним 24/02/19 Вск 22:06:35 1354381202
Смотрю, вы всё продолжаете мучить этот недораст
Аноним 24/02/19 Вск 22:20:08 1354395203
>>1354381
Зачем писать на расте, если есть родная Сишка с привычным синтаксисом и библиотекой?
Аноним 24/02/19 Вск 22:40:48 1354417204
>>1354381
Связный список уже написал на своем безопасном системном языке?
Аноним 24/02/19 Вск 22:50:39 1354424205
>>1354417
Во-первых, связные списки не нужны. Просто хуяришь массивы и не паришься. Во-вторых, они небезопасны.
Аноним 24/02/19 Вск 23:19:55 1354449206
Блять, частый realloc ломает кучу. Ну ебана!
Аноним 24/02/19 Вск 23:51:17 1354473207
forman.jpg (61Кб, 720x951)
720x951
>>1354417
>Связный список
А что, есть несвязные списки? Сколько тебе лет?
Аноним 25/02/19 Пнд 00:06:55 1354489208
>>1354449
Лолшто? Может ты его используешь через жопу просто?
Аноним 25/02/19 Пнд 00:07:05 1354490209
>>1354211
Допустим, есть x равное 3;

if (x > 3), то дать тебе пизды
else if (x < 5), то дать пизды твоему соседу
Никто из вас не получит пизды

if (x > 3), то дать тебе пизды
if (x < 5), то дать пизды твоему соседу
Твой сосед получит пизды

В конечном итоге лично ты не получишь пизды, поэтому можешь делать, как тебе нравится
Аноним 25/02/19 Пнд 00:08:16 1354491210
>>1354490
Чо епта, так мы с соседом пацанов с раёна подтянем за такой беспредел. else не нужны
Аноним 25/02/19 Пнд 00:08:24 1354492211
>>1353966
Ещё вот так можно скомпилировать.

tcc -rdynamic -shared -o lua.dll lapi.c lcode.c lctype.c ldebug.c ldo.c ldump.c lfunc.c lgc.c llex.c lmem.c lobject.c lopcodes.c lparser.c lstate.c lstring.c ltable.c ltm.c lundump.c lvm.c lzio.c lauxlib.c lbaselib.c lbitlib.c lcorolib.c ldblib.c liolib.c lmathlib.c loslib.c lstrlib.c ltablib.c lutf8lib.c loadlib.c linit.c

tcc lua.c lua.def

Получается жирная библиотека lua.dll и крохотный lua.exe
Аноним 25/02/19 Пнд 00:11:45 1354497212
>>1354490
В условиях 3 на 2 поменяй, я тупанул малёхо братишка. Ну и пизды получишь ты оба раза, а сосед один раз
25/02/19 Пнд 01:16:52 1354553213
>>1354473
Есть. Вон, в Java ArrayList
Аноним 25/02/19 Пнд 02:49:22 1354566214
>>1354424
> Просто хуяришь массивы и не паришься
И раздвигаешь массив при вставке. Хороший системный язык.

> они небезопасны
Так Java уже есть. И связные списки там реализуются за десять строк.

>>1354449
Собери с -fsanitize=address, и тебе скажут, где именно ты его ломаешь.
Аноним 25/02/19 Пнд 06:53:33 1354576215
>>1354489
Шиндоус 7, MinGW. Примерно на 11-12 реаллоке массива (увеличиваю на два элемента) куча идет по пизде и все падает. Видимо, неправильно использую все же.
Аноним 25/02/19 Пнд 08:40:48 1354596216
Аноним 25/02/19 Пнд 08:52:55 1354601217
>>1354576
>Видимо, неправильно использую все же
>Видимо
Компьютер не ошибается, он в точности выполняет что ты пишешь. Значит, если что-то падает - 100% ты накосячил. Вбей это сразу в свою тупую кочерыжку, иначе так и останешься необучаемым на всю жизнь.
Аноним 25/02/19 Пнд 09:06:17 1354605218
изображение.png (9Кб, 448x387)
448x387
>>1354596
Уже переписал. Вот, вспомнил и проверил - оно блять работает нормально! Но ей-богу, точно такой же код падал!
>>1354601
Да я понимаю, что я виноват. Но realloc heap corruption таки гуглится, и просто так sigtrap в отладчике внутри реаллока не срабатывает, хотя бряки я не ставил.
Аноним 25/02/19 Пнд 09:49:21 1354614219
>>1354605
arr это глобальный указатель под который ты где-то выделил память, видимо?
Аноним 25/02/19 Пнд 09:53:32 1354619220
>>1354614
Вообще код прям пиздец какой странный, на самом деле.
Аноним 25/02/19 Пнд 09:56:24 1354622221
1505275567843.png (30Кб, 577x572)
577x572
>>1354605
Фиг знает, всё работает.
Аноним 25/02/19 Пнд 10:03:54 1354627222
>>1354614
Там выше глобально объявлен он. Ну и под комментом - как именно.
>>1354619
Как сделать лучше?
>>1354622
У меня тоже. Но точно такой-же код в другой программе - нет.
Аноним 25/02/19 Пнд 13:28:31 1354739223
>>1354627
> Как сделать лучше?
Проверять результат realloc(), например. Выделять в realloc() с запасом побольше (150%, например). Если нет острой необходимости в том, чтобы весь массив описывал один только указатель, лучше явно хранить количество выделенных с запасом и количество использованных элементов. Можно еще отказаться от malloc() тоже, раз размер фиксированный, и хранить не массив указателей, а массив 256-байтовых массиов. Хотя это спорно и зависит от того, как этот arr применяется.
Аноним 25/02/19 Пнд 14:04:06 1354767224
Тут по сути идет дурацкая эмуляция списка массивом.
И передавать в функцию массив по значению - жирно.
Аноним 25/02/19 Пнд 14:34:05 1354791225
>>1354767
> передавать в функцию массив по значению
А он и не передает. Передается указатель.
25/02/19 Пнд 16:32:47 1354878226
>>1354767
>эмуляция списка массивом
Массив это одна из реализаций списка.
Аноним 25/02/19 Пнд 18:21:42 1354962227
вы пизду-то тетёхали хоть раз
Аноним 25/02/19 Пнд 19:44:49 1355054228
>>1354791
Забавно, спасибо.

>>1354878
Дебилы это одна из разновидностей человека, как и умные, но такое обобщение никому не нужно.
Аноним 25/02/19 Пнд 21:44:55 1355136229
Хай, вкатываюсь в программирование, напишите, где тут у вас найти гайды по плюсам. Тред не нашел. нуфаг, листва.
Аноним 25/02/19 Пнд 21:53:58 1355150230
Можно ли как-то прочитать прямо из консоли уже напечатанное и копировать в свой буфер. Пробую так: "fscanf(stdout, "%s", e);" , но как понимаю он читает только промежуточный буфер?
Аноним 25/02/19 Пнд 21:56:24 1355156231
>>1355150
Что сделать хочешь?
Аноним 25/02/19 Пнд 22:01:39 1355159232
>>1355150
Нельзя. stdout ведет себе как
fopen ("/dev/tty", "w"); // "/dev/tty" заменить на нужное
fscanf на другом уровне абстракции работает и не имеет дела до подкапотной реализации всяких буферов-хуюферов. Для тебя это стрим в одну сторону.
Аноним 25/02/19 Пнд 22:02:28 1355162233
>>1355156
Обработчик ошибок err(). Что б перед падение отписал что было в консоли.
Аноним 25/02/19 Пнд 22:04:05 1355165234
Аноним 25/02/19 Пнд 22:08:21 1355169235
>>1355150
Может быть такой вариант
memcpy (mybufferblyat, stdout->_base, stdout->_cnt);
Но опираться на местную реализацию FILE - не вполне разумно.
Аноним 25/02/19 Пнд 22:11:19 1355172236
>>1355162
А почему в сигнал-handler просто не вызвать fflush(stdout)?
Аноним 25/02/19 Пнд 22:11:58 1355173237
>>1355169
Не, что то он кракозябры пишит.
Аноним 25/02/19 Пнд 22:13:46 1355177238
>>1355173
ну, может не _base, а _ptr
Аноним 25/02/19 Пнд 22:14:35 1355178239
>>1355172
fflush я пробовал, а до "сигнал-handler" видать пока не дорос. Это что вообще?
Аноним 25/02/19 Пнд 22:16:39 1355181240
>>1355162
а зачем, собсно, промежуточный буфер?
fwrite (ukazatel, sizeof (bukva), skolkobukov, stdout);
Аноним 25/02/19 Пнд 22:18:23 1355182241
>>1355178
Ну, обработчик ошибок - это ведь функция, которая вызывается, когда прилетает SIGTERM (ctrl+C), SIGSEGV (segment naebnulsa) или что-то в этом роде. Или это не то?
Аноним 25/02/19 Пнд 22:21:31 1355184242
>>1355182
Я наверно ляпнул что-то не то. У меня просто обёрнутый принтом exit() который я вставляю в забагованом месте и отлаживаюсь принтом в эррор.тхт файл.
Аноним 25/02/19 Пнд 22:22:00 1355185243
>>1355136
Предлагаю самый лучший баг по ленивому сипп для далбаебов типа тебя — съеби нахуй
Аноним 25/02/19 Пнд 22:26:06 1355189244
>>1355184
Отладочный лог обычно через stderr выводится. Там без задержек все. Чтоб в файл текло, надо запускать ./sverhproga 2>эррор.тхт
Аноним 25/02/19 Пнд 22:45:53 1355206245
Есть последовательность байтов, вытащенная в хекс-редакторе. Например.
27 00 00 13 26 20 3A 3F
Я знаю, что там запакованы данные. Как распаковать? Какие алгоритмы использовать?
Аноним 25/02/19 Пнд 22:50:34 1355212246
>>1355206
Гугли magic numbers алгоритмов.
Аноним 25/02/19 Пнд 23:01:34 1355223247
1551124855609.PNG (11Кб, 472x224)
472x224
1551124855620.PNG (11Кб, 472x224)
472x224
>>1355212
У меня 3F 80 повторяется в некоторых последовательностях записей.
На пикче две последовательности. В файле, который я ковыряю, меняется только расположение элемента по координатной оси. Когда растет X, длина последовательности записей увеличивается, то есть первая пикча - это элемент сильнее сдвинут по оси Х.
Аноним 25/02/19 Пнд 23:02:10 1355224248
1551124891809.PNG (27Кб, 354x604)
354x604
>>1355223
Фак, проебался, вот более длинный.
Аноним 26/02/19 Втр 00:26:56 1355326249
>>1355223
И что ты от нас хочешь?
Аноним 26/02/19 Втр 03:05:30 1355392250
>>1355206
Ищешь код который записывает/считывает эти данные, реверсишь его и выясняешь алгоритм.
Аноним 26/02/19 Втр 09:32:15 1355464251
>>1355326
Это и есть мэджик намба?
Аноним 26/02/19 Втр 09:37:43 1355469252
>>1355326
Чтоб мы расшифровали ему архив с цп забесплатно.
Аноним 26/02/19 Втр 10:20:47 1355496253
>>1355223
> У меня 3F 80 повторяется в некоторых последовательностях записей.
Ну вот это, например, флоаты, little endian. 0x3f800000 = 1.0f. Возьми себе редактор типа 010, который умеет показывать выделенные байты в различных представлениях.
Аноним 26/02/19 Втр 11:24:48 1355532254
Зашёл в тред и очутился на форумах девяностых. Вы чё, совсем ебобо? Кто-то реально пишет щас на этом говне?
Аноним 26/02/19 Втр 11:36:45 1355538255
>>1355532
на говне твои родители расписались
Аноним 26/02/19 Втр 12:01:55 1355547256
>>1355532
Каком форуме 90-ых, пиздюшня? Ты же 97 года рождения, откуда тебе знать.
Аноним 26/02/19 Втр 12:22:59 1355561257
>>1355547
в 90х в россии на bbs сидели, избранные имели доступ к зеркалам nntp
рассвет интернет-форумов в россии - это начало нулевых вообще то
люди сидели в своих домовых локалках, на шарах и ирке, и имели пару гигов интернета на выход в большой мир
но откуда тебе это знать
Аноним 26/02/19 Втр 12:25:26 1355563258
>>1355496
а еще внутреннее представление чисел можно узнать через union в самом коде
Аноним 26/02/19 Втр 13:00:48 1355585259
1l1-G0NDMp8.jpg (59Кб, 467x339)
467x339
>>1355561
>пару гигов интернета
Аноним 26/02/19 Втр 13:04:34 1355588260
Аноним 26/02/19 Втр 13:05:22 1355589261
Аноним 26/02/19 Втр 13:05:32 1355591262
>>1355561
Да согласен, ещё были ламповые чаты и аська
Аноним 26/02/19 Втр 13:44:49 1355627263
>>1355469
С чего ты взял, что это архивы с цп? Каждый думает в меру своей испорченности.
Аноним 26/02/19 Втр 13:46:19 1355630264
>>1355496
Мой редактор умеет показывать в разных представлениях. Только все равно непонятно, как данные пакуются
Аноним 26/02/19 Втр 13:46:54 1355631265
>>1355591
Начнем с того, что рунета просто не было, или читаешь зарубежные сайты на английском или нахуй идешь. Но такой проблемы не стояло, потому что у рюско-быдла не было компьютеров, а интернета и подавно.
Аноним 26/02/19 Втр 13:52:50 1355635266
>>1355630
В смысле, почему оно именно этими байтами представлено, или ты хочешь, чтобы мы отреверсили для тебя формат по скриншотам?
Аноним 26/02/19 Втр 13:56:11 1355638267
>>1355635
Нет, мне непонятен сам принцип упаковки. Как из какой то длинной последовательности байтов получается более короткая? Причем короткая будет разной длины в зависимости от входных данных.
Аноним 26/02/19 Втр 14:01:05 1355640268
>>1355638
Да, и еще непонятно, почему после упаковки одно и то же число начинает повторяться
Аноним 26/02/19 Втр 14:07:31 1355646269
>>1355638
Ты бы рассказал, что за файл, что за данные. Какие нахуй последовательности? Это кейфреймы анимации что ли? Почему ты решил, что там что-то упаковывается, если флоаты торчат голой жопой? Сдампи в человекочитаемый вид для начала:
fseek(fp, офсет, SEEK_SET);
struct { uint16_t a; uint16_t b; float c; } smth[24];
fread(smth, sizeof(smth), 1, fp);
for (j = 0; j < sizeof(smth) / sizeof(smth[0]); j++) {
printf("%d: %.4x %.4x %g\n", j, smth[j].a, smth[j].b, smth[j].c);
}
И уже ищи закономерности. Никакого магического решения не существует, нужно думать. Алсо, другие части файла тоже могут иметь значение. Можешь взять kaitai struct или темплейты в том же 010 editor и документировать известные поля, например.
Аноним 26/02/19 Втр 14:07:56 1355647270
>>1355640
А ты уверен, что это вообще упакованный файл?
Аноним 26/02/19 Втр 14:13:29 1355650271
>>1355631
У меня был инет с 97 года, чего ты пиздишь то?
Аноним 26/02/19 Втр 14:22:21 1355657272
>>1355650
Нахуй ты зелёному отвечаешь, у него гигабайтные сетки на ирке стояли и аплоады по 26кбпс в 95-ом в его воображении
Аноним 26/02/19 Втр 22:53:56 1355974273
>>1355646
Короче, мне уже кое что известно об устройстве этого файла. Данные есть в интернете. Но пресловутая структура практически не описана. Сказано лишь, что она представляет из себя последовательность записей по 8 байт. Похоже, она отвечает за текстуры поверхности, именно за привязку кусочков текстур к вершинам.
Я получаю структуры, закрашивая разные вершины (или клетки) поверхности ландшафта в игровом редакторе. Одну клетку закрашиваю и потом смотрю, что добавилось в hex-редакторе.
Почему появилась мысль о том, что данные запакованы?
Во первых, часть данных в этом файле уже была запакована. Других данных, не этих. Распаковывал, используя готовую утилиту, там уже все до меня было сделано.
Во вторых, очень странное поведение. Когда я крашу ближе к началу координат, структура получается очень короткая, всего 8 байт. Когда крашу квадратик ближе к середине или другому краю, то записей становится дохуя, как на пикче выше. Это необязательно значит, что данные запакованы, но такие мысли возникают.
И вот я теперь думаю, что либо эти записи запакованы, и данные о координатах вершин запрятаны, либо в этих записях не записаны координаты вершин напрямую, и текстурки к вершинам привязываются как то по другому.

Upd: пока писал, обнаружил, что последний байт 3F как то связан с интенсивностью цвета текстуры. Потому что когда перезаписал на 3E, то в редакторе она поблекла. То есть видимо данные все таки не запакованы.
Аноним 26/02/19 Втр 23:06:51 1355989274
Коротко:
glib-ский tdestroy из <search.h> не освобождает память. ЧЗХ??

Длинно:
Здарова, аноны-сишники. Я к вам не с пустыми руками.
Тонна гавнокода...
https://pastebin.com/WTCxAaJE
...приятного аппетита (кто не голоден - 71я строка)
Итак, проблема. Решил наскоро смастерить реализацию ROBDD. Тест на соответствие возвращаемых значений исходной таблице истинности проходится успешно. Глянул в диспетчере, сколько оперативки кушает это чудо, и охуел. Мегабайтаж явно не соответствует числу узлов диаграммы, проверено сверхмозгом, принтэфился из-под капота. Тем же суперметодом было установлено, что после вызова tdestroy (derevoblya), где dereveblya - собсно, дерево, в которое добавлен, на минуточку, не один миллион уникальных элементов, так вот, после вызова tdestroy памяти освобождается ровно... нихуя, а, как я полагаю, один узел - это минимум три qword-указателя плюс еще что-то. Что делать то, епт?
P.S. любопытных прошу не ругать за костыль с bdd_cmp. Я знаю, что для concurrent-safe работы надо как-то с каждым вызовом полный адрес ей доставить, но не стал ебать себе голову.
Аноним 26/02/19 Втр 23:11:48 1355991275
>>1355989
> tdelete() frees the memory required for the node in the tree. The user is responsible for freeing the memory for the corresponding data.
Аноним 26/02/19 Втр 23:17:08 1355994276
>>1355991
хм.. у меня другая инфа
> tdelete() deletes an item from the tree. Its arguments are the same as for tsearch().
стало быть, якась хуйня, а вот:
> tdestroy() removes the whole tree pointed to by root, freeing all resources allocated by the tsearch() function. For the data in each tree node the function free_node is called. The pointer to the data is passed as the argument to the function. If no such work is necessary, free_node must point to a function doing nothing.
выглядит как то, что надо
Аноним 26/02/19 Втр 23:19:33 1355996277
>>1355991
>>1355994
упс, про frees the memory required for the node уже вычитал, но это неинтересно. Я и не хочу удалять corresponding data, я лишь хочу сам скелет дерева выбросить.
Аноним 26/02/19 Втр 23:31:04 1356003278
>>1355996
> Я и не хочу удалять corresponding data, я лишь хочу сам скелет дерева выбросить.
Ну так он у тебя удаляется у тебя не освобождается (и скорее всего течет) corresponding data (malloc на 61 строке). Если твой алгоритм позволяет попробуй вместо того malloc подставлять просто ссылку на какой-то один буфер (для всего дерева). И посмотри на ситуацию с памятью.
Аноним 26/02/19 Втр 23:42:24 1356008279
>>1356003
61 строка находится не во вложенной рекурсивно крутящейся функции, а выполняется лишь раз за весь вызов, а потом только reallo-чится. Там не утечка, там именно tdestroy сломалась, которая по идее должна распускать за ненадобностью дерево, используемое лишь в процессе выполнения алгоритма построения диаграммы, но на деле ни мегабайта не возвращется. Проверено getchar-ом до и после в обнимку с system monitor (линуксовый диспетчер задач)
Аноним 27/02/19 Срд 00:10:56 1356029280
>>1356008
Ну тогда хуй знает. Есть вариант вилкой чистить. Начинаешь с самого просто примера с деревом. Убеждаешся что с памятью все ок. Потом начинаешь постепенно превращать его в свой код, как можно меньшими шажками, пока не начнется хуйня. Если стркутура позволяет то лучше конечно бинарным поиском - добавляешь примерно половину кода, если все ок, добавляешь половину оставшегося, если не ок - убираешь половину вставленого. Если действительно с tdelete() проблема то это баг дохуя.
твоя мамаша 27/02/19 Срд 00:12:36 1356031281
писать на С в 2к19...
чувак найди себе бабу, трахни, забудь про С, устройся на завод.
Аноним 27/02/19 Срд 00:18:16 1356038282
снова вылазят дохуя умные и смещные. Пиздец.
Алсо дауны детектятся по словам "2К19".
Аноним 27/02/19 Срд 00:36:42 1356042283
>>1356038
ко ко ко пидор
что по больному, да?
небось тебе уже 40+ а ти баб не ебал ещо?
с батей уже трахался?
как он в попец?
мамка твоя ничо так
Аноним 27/02/19 Срд 00:40:29 1356044284
>>1356042
понимаю, делать нехуй, но.. чувак, ты реально скучный вариант выбрал, технари не церковники, на такую толстоту не ведутся. Ну, вот >>1356038 один повелся, да, но такая скудная еда даже полминуты постинга твоего высера не стоит
Аноним 27/02/19 Срд 00:40:56 1356045285
>>1356042
>с батей уже трахался
уж лучше с батей поебаться, чем устраивать ЯП-срач.
Аноним 27/02/19 Срд 00:44:29 1356047286
>>1356029
Таки да, самый простой пример благополучно выявил поломку glib-овского чудо-дерева. Так и знал, что самому придется дерево писать. Люблю Си...
Аноним 27/02/19 Срд 01:06:13 1356057287
>>1356047
ну так какая мова такая и реализация фич :)
Аноним 27/02/19 Срд 01:07:43 1356058288
>>1356045
а где тут срач за ЯП ?
просто соси писос
Аноним 27/02/19 Срд 01:20:59 1356066289
>2к18 + 1
>думать что Си есть замена
Аноним 27/02/19 Срд 07:09:44 1356103290
>>1355974
> Это необязательно значит, что данные запакованы, но такие мысли возникают.
Возникают мысли, что оно взяло максимальные x/y закрашенные, побило прямоугольник {0, 0, max_x, max_y} на квадратики или треугольники и хранит для них пиксельные координаты или что-то подобное (вон я выше код кидал, переменные a и b), ну и интенсивность.

> обнаружил, что последний байт 3F как то связан с интенсивностью цвета текстуры
Охуеть, ты изменил флоат 1.0 на 0.25, и что-то уменьшилось. Внезапно, правда?
Аноним 27/02/19 Срд 13:46:11 1356206291
Привет Двач.
Есть ли тут люди работавшие с отечественным мк 1886ве4у от миландра?
Аноним 27/02/19 Срд 13:55:46 1356214292
>>1356029
>>1356057
Ага, зацените, как на багзилле на отъебись ответили. Однако, посылать нахуй таких ответчиков - то еще удовольствие. Не зря мать уроки по инглишу оплачивала.
Аноним 27/02/19 Срд 13:56:36 1356215293
>>1356029
>>1356057
Ага, зацените, как на багзилле на отъебись ответили. Однако, посылать нахуй таких ответчиков - то еще удовольствие. Не зря мать уроки по инглишу оплачивала.
https://sourceware.org/bugzilla/show_bug.cgi?id=24271
Аноним 27/02/19 Срд 14:04:22 1356221294
>>1356103
То есть последние 4 байта отвечают за интенсивность. Выглядит вполне правдоподобно.
Я вчера ещё выяснил, что первые 2 байта, а может и 4 даже, отвечают за расположение закрашиваемого квадратика. То есть вроде бы получилось расшифровать. Теперь осталось только выяснить, зачем он создаёт много этих 8-байтных текстур, если красить далеко от начала координат.
Аноним 27/02/19 Срд 14:09:43 1356225295
>>1356221
> 8-байтных текстур
Структур, быстрофикс
Аноним 27/02/19 Срд 14:23:45 1356229296
>>1356215
Погоди, твоя проблема лишь в том, что менеджер кучи не отдает ОС память, а придерживает ее для себя, и тебе это не нравится?
Аноним 27/02/19 Срд 15:38:19 1356252297
>>1356229
>менеджер кучи не отдает ОС память, а придерживает ее для себя
Прям завоняло 15-рублевыми оправдателями андроида и дрисни 10:
- Почему у меня вся память занята, хотя ничего не запущено?
- СИСТЕМЕ ВИДНЕЕ, ОНА ДЛЯ ТВОЕЙ ЖЕ ПОЛЬЗЫ РЕЗЕРВИРУЕТ, НАХУЯ ТЫ ПОКУПАЛ ПАМЯТЬ, ЧТОБЫ ОНА ПУСТОВАЛА? РАЗ ЗАНЯТА, ЗНАЧИТ ТАК НУЖНО, НЕ ТЕБЕ ХОЛОПУ СЮДА ЛЕЗТЬ!
Аноним 27/02/19 Срд 16:00:16 1356264298
>>1356229
Полгига "для моего же блага"? Неее, не имеет права, шел бы он нахуй с такими премудростями. free, кстати, в таком говне не замечен. Отдает мегабайты, как миленький, все до единого, по любой мелочи. Это tdestroy в manpages раскудахтался на обещания все ресурсы из под дерева распустить, а на деле нихуя не высвобождается.
Аноним 27/02/19 Срд 16:03:41 1356267299
>>1356252
> Почему у меня вся память занята
Вытеснена в своп, лежит, есть не просит.

> СИСТЕМЕ ВИДНЕЕ
Это не система. Линкуйся с другим аллокатором, можешь хоть на каждый освобожденный байт делать сисколлы. И похуй, что они теперь еще дороже стали из-за багфиксов для x86.
Аноним 27/02/19 Срд 16:16:09 1356271300
>>1356264
> free, кстати, в таком говне не замечен
Так в tdestroy и нет ничего, кроме вызова твоей функции для освобождения данных и обычного free() для каждого узла. Такие дела.

Алсо, у тебя там вообще скорее всего проблема с фрагментацией: ты выделяешь ноду, потом выделяешь данные для нее, повторяешь много раз, и выделение скорее всего идет из одного и того же пула. А когда ты освободишь дерево, получается последовательность блоков free-used-free-used-free-used, где used - это данные, которые ты не освободил. И вот пока ты вот с этими used ничего не сделаешь, никакая магия тебе память в систему не отдаст, даже если ты очень захочешь. Можешь проверить это, выделяя данные пожирнее, например, по 128 байт на узел, чтобы гарантированно использовался другой пул. Если картина изменится, можешь пофиксить это, например, выделяя данные заранее, а потом уже вторым проходом складывая в дерево.
Аноним 27/02/19 Срд 16:20:42 1356272301
>>1356271
Вот этот вроде не совсем дебил.
Даже странно.
Аноним 27/02/19 Срд 16:22:38 1356273302
>>1356271
Там узлы дерева выходят втрижды жирнее самих данных, а данные-то пакуются в один массив, который целиком reallo-чится по +килобайту по каждом переполнении.
Аноним 27/02/19 Срд 16:24:06 1356274303
>>1356273
Я код перестал читать на вложенной функции, так что тебе виднее.
Аноним 27/02/19 Срд 17:01:43 1356282304
>>1356274
ну сорян, у меня SICP-головного-мозга не остыл еще)
Аноним 27/02/19 Срд 17:08:45 1356284305
>>1356282
>головного-мозга
Проиграл с этого оптимиста №47.
Аноним 27/02/19 Срд 18:52:11 1356330306
Есть какая-то единая книжка в которой описан си от самых низов до работы с памятью и таким
Такая чтоб страниц на 700-900
Аноним 27/02/19 Срд 19:11:37 1356339307
Аноним 27/02/19 Срд 19:14:50 1356341308
Байтоёбы -- мерзкие педерасты, анимешники и прыщебляди
27/02/19 Срд 19:26:03 1356349309
>>1356341
Двачую. Я именно такой.
Аноним 27/02/19 Срд 19:29:42 1356350310
>>1356341
Это оскорбления или как? Подлиза, чего тебе?
Аноним 28/02/19 Чтв 01:22:26 1356518311
а есть гарантия, что секвенс поинты будут строго как написано в кода выполняться? то есть, если я буду писать в память и вызывать функцию, которая читает её - это ещё понятно. а что если у меня другой поток читает? например считывает статус выполнения какой-то операции.
Аноним 28/02/19 Чтв 01:39:23 1356523312
>>1356518
Точки следования говорят, когда закончится вычисление выражения. Они никак не гарантируют тебе видимость сайд-эффектов извне: ни то, что результат попадет из регистра в память, ни то, что одно выражение выполнится раньше другого, если у них нет зависимости по данным. И уж тем более оно никак не гарантирует, что соседний поток это все увидит. И даже если ты расставишь везде volatile, чтобы компилятор не ленился писать в память, есть еще такая страшная штука, как memory ordering, и что там у тебя будет происходить с данными, запишутся ли они сразу в память, или запись пойдет в кэш и будет отложена, и увидит ли это соседний процессор и т. д. - про все это Си для обычных переменных не дает тебе никаких гарантий, все целиком и полностью зависит от платформы. Поэтому не выделывайся, бери C11 и используй атомики, для них компилятор будет проделывать все необходимые пляски с бубном.
Аноним 28/02/19 Чтв 01:52:20 1356526313
>>1356523
ну в общем я так и думал, что нужно писать асм и оборачивать в функции. на моей платформе нет атомиков.
Аноним 28/02/19 Чтв 09:08:22 1356560314
>>1356526
А что за платформа такая?
Аноним 28/02/19 Чтв 15:55:17 1356669315
>>1356560
Почему компилятор нормально воспринимает функцию, int f(double const ⋆x), но ругается на int f(double const ⋆⋆x)?
Как передать компилятору ⋆⋆x и объяснить, что в функции не должны изменяться ни указатели на ⋆x[...], ни элементы x[...][...]?
Аноним 28/02/19 Чтв 16:19:00 1356678316
>>1356669
> ругается на int f(double const ⋆⋆x)
Как ругается? Несовпадение типов, потому что ты передаешь массив указателей на неконстантные даблы? Касти, такое автоматически не приводится.

> объяснить, что в функции не должны изменяться ни указатели на ⋆x[...], ни элементы x[...]
Тебе нужен массив константных указателей (нельзя изменять укащатели) на константные даблы (нельзя изменять данные). Вот и записываешь: const double ⋆const array[], но у тебя указатель вместо массива, правишь и получаешь const double ⋆const ⋆x.
Аноним 28/02/19 Чтв 16:20:01 1356679317
>>1356678
note: expected ‘const unsigned int ⋆⋆’ but argument is of type ‘unsigned int ⋆⋆’
Аноним 28/02/19 Чтв 16:24:13 1356680318
>>1356678
Аналогичное предупреждение:
note: expected ‘const unsigned int const’ but argument is of type ‘unsigned int
Но суть примерно понял, сейчас поугадываю, как передать. Спасибо.
Аноним 28/02/19 Чтв 16:27:41 1356682319
>>1356680
Без каста никак, не пытайся. Автоматическое втыкание квалификаторов поддерживает максимум один уровень косвенности, у тебя два.
Аноним 28/02/19 Чтв 16:50:39 1356689320
Аноним 28/02/19 Чтв 17:42:14 1356705321
Аноним 28/02/19 Чтв 21:28:00 1356907322
пиздос, передоз си в крови. Сейчас секунд 10 искренне пытался вспомнить, где я проебал указатель на вилку, лежащую передо мной на столе.
алсо, чем анализировать код, чтобы всякие тонкости не проебывать? мозг имеет свойство сбоить после всего-то двух-трех дней без сна, поэтому не всегда вариантpvs-studio знаю и пользовал, интересны альтернативы
Аноним 01/03/19 Птн 07:27:09 1357048323
Анонче у вас тоже так, в общем дня не можете провести без C? Как будто подрочить, обязательно нужно какую то хуйню написать и ебать себе мозг решением проблемы и когда решаешь то кончаешь?
Аноним 01/03/19 Птн 17:47:02 1357277324
>>1357048
Да, эта болезнь называется байтоебство
Аноним 01/03/19 Птн 18:00:51 1357282325
#include <stdio.h>

int main(void)
{
int i, j, list[10];

for (i = 1; i < 10; i++)
{
list = 2 * i + 3;
for (j = 1; j <= i; j++)
printf("%d\n", list[j]);
}

return 0;
}


Почему из-за ескейпа \n ломается луп и не обновляет значение j ?
Аноним 01/03/19 Птн 18:17:41 1357290326
>>1357282
Ахахах лол, именно из-за эскейпа.
Аноним 01/03/19 Птн 18:20:16 1357292327
>>1357290
Всмысле printf возьмет в память ескейп?
Аноним 01/03/19 Птн 19:53:24 1357347328
>>1357292
В смысле ищи свою проблему где-то еще. Я хуй знаю, зачем ты это делаешь, но этот код делает именно то, что в нем написано.
Аноним 01/03/19 Птн 20:02:51 1357353329
>>1357347
Что он делает?
Он выводит массивы со случайными значениями, хотя это не так, там определенные значения должны быть.
У меня когда в принте %d\n выводит мусор, а когда отделяю %d от \n то сразу все становится на свои места и j обновляет значение и луп работает как надо.
Аноним 01/03/19 Птн 20:28:16 1357366330
>>1357353
> со случайными значениями
Нет, оно выводит вот эти твои последовательности нечетных чисел, начиная с пяти. Ну это если макаба на самом деле сожрала [​i​] в выражении list[​i​] = 2 * i + 3.
> У меня когда в принте %d\n выводит мусор
У тебя компилятор сломался, скачай другой.
Аноним 01/03/19 Птн 20:30:53 1357369331
>>1357353
>>1357366
О, я догадался. Ты делаешь что-то типа printf("%d ", ...); printf("\n"), и так как ты не можешь в фигурные скобки, второй принтф попадает во внешний цикл, а не во внутренний, и у тебя получаются красивые строчки чисел, а не один непонятный столбец. Так?
Аноним 01/03/19 Птн 20:39:41 1357377332
>>1357369
Нет, все в столбец. Там даже когда как ты сказал все равно будет столбец, ибо \n срабатывает каждый луп, поэтому строчка и так и так будет.
Проблема в том, что компилятор по моему сломан, ибо почему то когда спецификатор %d с \n сочетаешь в одной функций printf, то вывод ломается, либо разные адреса печатает, либо вообще не инкрементирует.
Аноним 01/03/19 Птн 20:40:24 1357378333
>>1357377
Компилятор кстати gcc.
Аноним 01/03/19 Птн 20:42:35 1357380334
>>1357378
Блядь, закинь код на пастебин и скинь сюда.
Аноним 01/03/19 Птн 21:18:06 1357401335
>>1357377
>каждый луп
зачем тебе оно надо? Шел бы оффициантом
Аноним 01/03/19 Птн 21:46:43 1357421336
изображение.png (13Кб, 785x356)
785x356
>>1357282
УМВР. И да - на gcc гнать смысла нет, ищи ошибку у себя.
Аноним 02/03/19 Суб 06:53:44 1357567337
Если присвоить указателю адрес некой переменной, можно ли потом прибавить к нему какое либо число, чтобы он стал указывать на другую переменную?
Аноним 02/03/19 Суб 08:11:57 1357591338
>>1357567
В Си нету магии. Адрес это просто целое число, к которому можно прибавить (или отнять) другое целое число.
Аноним 02/03/19 Суб 08:34:53 1357593339
Аноним 02/03/19 Суб 08:37:59 1357594340
Аноним 02/03/19 Суб 08:44:04 1357596341
>>1357421
Нет, дело в компиляторе было. Я тупой еблан, кодил на ночь, прошу прощения за мозгоебство, в следующий раз буду писать на свежую голову.
Сам себя запутал, я думал что вывод
5
5
7
Это ошибка, и думал правильно будет
5
57
В виде пирамиды.

В общем тупой долбоеб.
Аноним 02/03/19 Суб 08:44:44 1357597342
>>1357596
Дело не в компиляторе было

самофикс
Аноним 02/03/19 Суб 09:13:34 1357599343
>>1357596
>кодил на ночь
>кодил
Всё равно что насыпать сахару в чай и размешать, а потом говорить "я готовил".
Аноним 02/03/19 Суб 09:31:30 1357601344
>>1357591
Я не спорю, я спрашиваю можно ли таким прибавлением случайно попасть в адрес другой переменной
Аноним 02/03/19 Суб 09:37:20 1357602345
>>1357601
> можно ли таким прибавлением случайно попасть
Можно. https://ideone.com/ijeBN3 Но делать так не стоит. Обращения за пределы объектов в памяти - undefined behavior.
Аноним 02/03/19 Суб 09:46:29 1357605346
>>1351183
ещё барахтаешься в бассейне?
Аноним 02/03/19 Суб 09:51:45 1357606347
>>1357601
Разумеется можно, но толку нет, ты закосячишь программу непредсказуемым образом (коррупция памяти), ведь нет гарантий расположения переменных относительно друг друга.
Аноним 02/03/19 Суб 10:10:52 1357608348
>>1357605
Я среди 284 лучших, которые прошли.
Аноним 02/03/19 Суб 10:18:54 1357613349
>>1357608
>среди 284 лучших
маловато как-то "лучших"
Аноним 02/03/19 Суб 10:41:44 1357627350
Аноним 02/03/19 Суб 12:26:43 1357669351
>>1357627
Пока вам эта школа не даст реальных профитов, кроме как циферки, завидовать нечему.
Аноним 02/03/19 Суб 17:06:28 1357793352
>>1357608
тоже хочу пройти, дай советов
вчера был экзамен, успехов мало
Аноним 02/03/19 Суб 17:08:42 1357795353
Аноним 02/03/19 Суб 18:27:03 1357838354
>>1357599
Скорее как вскипятить чайник и заварить доширак.
Аноним 02/03/19 Суб 20:25:24 1357893355
>>1351181 (OP)
По ссылке [http://www.iso-9899.info/wiki/Books#Learning_C] у ОПа

>Stuff that should be avoided:
>Understanding and Using C Pointers by Richard M. Reese: Horribly written, conflates language specification and implementation, and describes concepts confusingly and/or wrongly in many cases.
Аноним 02/03/19 Суб 21:17:24 1357927356
>>1357793
Если будет тяжело, то читери как сука.
На гитхабе есть готовые решения, задания на бассейн не меняются годами.
Гуглить github piscine 42.
Аноним 02/03/19 Суб 21:28:52 1357934357
Как в CRC32 предварительно вычисляются таблицы? Не те, которые полные и занимают 4гб памяти, а те, например, что на 256 значений.
Аноним 02/03/19 Суб 21:50:47 1357947358
>>1357893
Мы в курсе. И про хардвей тоже. Но плохие книги тоже нужно читать.

>>1357934
Ну погугли painless guide to crc32. В целом, суть в том, что CRС32 - это длинное деление (в столбик, как в школе), только вместо обычного вычитания там xor, и еще тебя не интересует частное, только остаток. И ты можешь либо ксорить побитово, либо можешь заметить, что то, с чем поксорится "текущий" остаток после n итераций, полностью определяется следующим n-битовым словом. Ну и ты берешь вот это слово, и для каждого его возможного значения гоняешь побитовую версию crc32, получаешь табличку.
Аноним 02/03/19 Суб 22:05:59 1357955359
>>1357947
Ух ты, спасибо за хорошую наводку.
Аноним 02/03/19 Суб 22:10:42 1357958360
>>1357947
>плохие книги тоже нужно читать
если ты уже знаешь что и куда, да

алсо, где достать MISRA C:2012? на либгене только 2004
Аноним 03/03/19 Вск 00:07:56 1358020361
Аноним 03/03/19 Вск 10:14:51 1358141362
Почему если убрать размер строки у t, то программа вылетает?
#include <stdio.h>
int main()
{
char s[100]= "test string";
char t[100] = "stroka";
strcat(s,t);
printf("%s",s);
return 0;
}

void strcat(char s, char t){
while(s++ !='\0');
s--;
while(
s++=*t++);
}
Аноним 03/03/19 Вск 10:37:39 1358151363
>>1358020
Посмотрел видео.
Как правильно записывать поинетры?
int pointerAge = &age;
int
pAge = &age;

Или какой другой вариант?
Аноним 03/03/19 Вск 10:40:52 1358152364
Аноним 03/03/19 Вск 11:30:11 1358185365
>>1358151
Например, в glib в объявлениях функций имена параметров указателей кончаются на p. Вообще, сишный стиль краткий, если хотя бы посмотреть на имена тех же функций стандартной библиотеки strcmp, memcmp и т.д., так что pointer явно длинновато, максимум ptr.
Аноним 03/03/19 Вск 11:31:15 1358186366
>>1358152
Он видимо у s убирал.
Аноним 03/03/19 Вск 11:33:58 1358187367
>>1358185
> сишный стиль краткий, если хотя бы посмотреть на имена тех же функций стандартной библиотеки
Не надо на них смотреть. Все это делалось в те времена, когда количество значимых символов в именах было дико ограничено, чтобы экономить память и время компиляции, поэтому ребята крутились как могли и писали вот эти нечитаемые strpbrk.
Аноним 03/03/19 Вск 11:43:48 1358191368
Можно ли в С создать указатель на функцию и передать этому указателю функцию с определенными аргументами, а потом вызвать эту функцию через указатель не указываю аргументов?
Аноним 03/03/19 Вск 11:55:48 1358198369
>>1358191
в этом случае пишут еще одну функцию обертку, в которой игнорируются входные параметры, а вместо их подставляются сохраненные значения внутри этой функции
на с++ обычно пишут функтор, в котором сохранение состояния выражается более явно
Аноним 03/03/19 Вск 11:57:25 1358199370
>>1358191
Нет. Максимум ты можешь добиться такого с помощью кодогенерации в рантайме (libffi или jit какой-нибудь), но насколько кроссплатформенно это будет - зависит от того, как ты это будешь делать. С другой стороны, ты явно хочешь чего-то странного. Ты можешь, например, сделать так, чтобы твоя функция вместо нескольких аргументов функция принимала один указатель на структуру или на массив с аргументами. Тогда ты сможешь сделать что-нибудь типа struct { void (∗func)(void ∗args); void ∗args; void ∗result; } myfunc = { ... }, и потом сделать какой-нибудь callfunc(&myfunc);
Аноним 03/03/19 Вск 12:07:00 1358212371
Аноним 03/03/19 Вск 12:11:05 1358213372
Аноним 03/03/19 Вск 13:28:07 1358291373
>>1358191
Нужна библиотека GNU libffcall с помощью alloc_callback можно вроде как такое сделать, я правда не пробывал никогда
http://www.gnu.org/software/libffcall/callback.html
Еще есть екстеншен под clang который добавляет "блоки", но это нужно устанавливать llvm, clang и потом само libblocksruntime-dev
https://en.wikipedia.org/wiki/Blocks_(C_language_extension)
Аноним 03/03/19 Вск 13:43:57 1358299374
Я не понимаю что такое llvm и как он работает. Как он связан с асмом и машинным кодом? Что это вообще?
Аноним 03/03/19 Вск 15:25:12 1358372375
>>1358299
Вместо того чтобы компилить сразу в машинные коды, код сначала превращается в какой-то промежуточный вид, а потом из него компилиться в машинный код для конкретной системы. Если у тебя есть 10 языков и 5 систем, если ты хочешь использовать их все на всех системах - тебе прийдется написать 50 компиляторов. А с таким подходом тебе нужно 10 компиляторов с языков высокого уровня в промежуточный вид, и пять компиляторов с промежуточного в машинные коды конкретной системы.
Аноним 03/03/19 Вск 15:40:43 1358376376
>>1358372
> код сначала превращается в какой-то промежуточный вид
На самом деле так делает любой серьезный компилятор, просто у LLVM байткод стандартизирован, документирован и опубликован. И еще его можно в таком виде таскать, тогда как обычно у компиляторов промежуточное представление живёт в лучшем случае до линковки.
Аноним 03/03/19 Вск 19:23:21 1358563377
Всем привет я из школы 21 буду учить си и буду крутой програмиссткой давайте дружить)
03/03/19 Вск 19:53:45 1358581378
>>1358563
Удобно плавниками-то печатать?
Аноним 03/03/19 Вск 21:33:50 1358644379
>>1351181 (OP)
Спрошу тута.
Посоветуйте деревенщине годное что-нибудь по системному программированию под *nix. А то под венду вагон туторов по ддлкам, мультитредингу и всему такому, а то под никсами я только fork() знаю.
Аноним 03/03/19 Вск 21:40:04 1358648380
>>1351181 (OP)
анон, есть сорсы какой-то хитрой большой сишной либы, там куча кого-то говна, каких-то монструозных мэйкфайлов и прочего (в чем по слову говно можно было понять я не шарю) - можно как-то без боли (хаха) для нуба это всё скомпилировать и пройтись по интересующим меня кускам в дебагере? иде там какие-то годные для этого люди используют или как вообще?
Аноним 03/03/19 Вск 21:40:19 1358650381
>>1358644
Попробуй "Искусство программирования под Unix".
Книг так-то достаточно, мог бы сам загуглить и начать читать.
Алсо туторы для дебилов.
Аноним 03/03/19 Вск 21:41:36 1358652382
>>1358648
В нормальных либах есть файл с инфой по установке, дебажить можешь подсосавшись GDB, например.
Аноним 03/03/19 Вск 21:50:38 1358656383
>>1358652
ну вот к сожалению нету, на сайте либы пишут что проще всего устанавливать - скачать пакеты вашего дистра.
сука, ну неужели по-человечески никак это не делается? не первый раз такая ситуация, не понимаю блеа как вообще дебажить большие чужие либы, как это нахер всё собирается...
Аноним 03/03/19 Вск 22:45:46 1358705384
>>1358650
Ну туторы по какому-нибудь WinAPI дело хорошее. Понял основы и закапываешься в MSDN. А потом плачешь от кривости устройства своей программы
Мимо
Аноним 03/03/19 Вск 22:55:28 1358713385
>>1358656
Ну почитай что там в install пишут, вообще монструозные мейкфайлы нужны чтобы ты мог просто написать make install и все ок если повезет. У тебя проблема в том что ты дебажить хочешь - тоесть тебе нужны тыблицы символов - скорее всего прийдется править мейкфайлы, если они не предусмотрели удобного флага для компиляции. Есть возможность где-то нагуглить уже готовые таблицы под твою библиотеку (если она распространенная) тогда можно попробывать скачать готовый пакет + таблицы. Естественно там куча проблем (вродже того что должны совпадать версии компилятора).
04/03/19 Пнд 00:06:27 1358742386
>>1358713
Ты так говоришь
> править мейкфайлы
как будто положить -g и -O0 в CFLAGS - это занятие на целый вечер.
Аноним 04/03/19 Пнд 07:04:03 1358802387
>>1358563
Привет, асечку-писечку?
Аноним 04/03/19 Пнд 10:16:46 1358852388
>>1358020
Никаких, С знают с рождения.
Аноним 04/03/19 Пнд 11:05:57 1358883389
>>1358852
Ты один из этих китайцев с генными модификациями?
Аноним 05/03/19 Втр 00:35:07 1359334390
1.На чем писать на винде
2.посоветуйте книжку для новичка,но чтобы не совсем как с маленьким
заранее спасибо
Помогите зеленому Чайник 05/03/19 Втр 13:32:45 1359522391
Парни, есть задание. Надо написать программу для вычисления значения функции f(x) в точке x с помощью ряда Тейлора в окружности точки x0 = 0 . Для функции f(x)= ln (x^2)-x+1 при x=1.5
Петух 05/03/19 Втр 14:27:08 1359546392
>>1359522
Привет, ты че охуел? Тебе эту задачу дали чтобы ты ее сам решил. Формулы все есть, осталось только написать пару строк кода.
Аноним 05/03/19 Втр 14:58:53 1359563393
Анон, есть годная книга, цикл-статей, что угодно по написанию компиляторов/интерпретаторов на Си?
Modern compiler implementation in С c тигром пойдёт?
Аноним 05/03/19 Втр 17:24:30 1359626394
>>1359563
Есть, в Др. Добс был цикл статей, мини/тини си конпилер.
Аноним 05/03/19 Втр 18:53:25 1359701395
Аноним 05/03/19 Втр 19:23:39 1359716396
>>1359522
Сделаю в течение часа за 500
tg luaisnotdead
Аноним 05/03/19 Втр 21:25:26 1359812397
Здарова, низкоуровневые аноны. У меня дипломная работа с булевыми сетями. Уже был тут с вопросом, стоит ли для такой математически сложной задачи перекатиться на кресты, или нет причин дергаться и можно спокойно на любимой Сишечке осилить. А теперь у меня возникла мысль... не удобнее ли будет на FORTRAN всю эту симуляцию и алгоритмы пилить? Треда по Форту нет, по сему зашел сюда.
Аноним 05/03/19 Втр 21:26:46 1359814398
>>1359812
собсно, вопрос к тем, кто с имел дело с FORTRAN и может сказать, для чего он удобнее, а для чего нет.
Аноним 05/03/19 Втр 22:00:36 1359828399
>>1359812
>Уже был тут с вопросом, стоит ли для такой математически сложной задачи перекатиться на кресты
Подозреваю, что ты пилишь такой говнокод, что похуй
>не удобнее ли будет на FORTRAN всю эту симуляцию и алгоритмы пилить
Нет.

Форт и фортран разные языки.

Удобнее взять python и numba.
Аноним 05/03/19 Втр 22:53:46 1359863400
>>1359812
>не удобнее ли будет на FORTRAN всю эту симуляцию и алгоритмы пилить? Треда по Форту нет, по сему зашел сюда
Анон, Форт и Фортран это разные языки, есличо. Очень-очень разные.
Аноним 05/03/19 Втр 22:59:04 1359866401
>>1359812
Я бы на твоем месте не выебывался и писал на том на чем умеешь.
Аноним 05/03/19 Втр 23:24:37 1359878402
>>1359828
>>1359863
> Форт и Фортран разные языки
Не знал про Форт, поэтому когда увидел где-то это название, подумал, что речь про Фортран (ласковое сокращение). Я таки имею ввиду не Форт.
Аноним 05/03/19 Втр 23:30:51 1359879403
>>1359866
Скорее всего, самый рациональный вариант.
Просто думал, что раз Си был придуман для байтоебства (разработка ОС), а FORTRAN для матана (научные вычисления), то последний может оказаться удобнее. До сих пор меня клинило исключительно на Си, так что перекат в любом случае будет болезненным, а олдскул мне как-то больше по душе. Хотя, может и вправду "этот ваш" Python такой легкоусвояемый-мощновозможностный-проектопозахватуземлипригодный...
Аноним 06/03/19 Срд 00:04:17 1359894404
>>1359879
Вся математика нынче пилится на питоне, там либ ёбнешься сколько, то что ты на си напишешь строчек за 200, на питоне займет 10.
Если ты оэлдэ-извращенец юзай фортран, но я бы взял питон, он реально простой, тем более если ты не изучаешь язык, а пилишь на нем конкретный проект.
Аноним 06/03/19 Срд 02:00:35 1359924405
>>1359879
>Скорее всего, самый рациональный вариант.
Самый рациональный вариант использовать вуз для освоения технологий, которые пригодятся в дальнейшем. И "Я бы на твоем месте не выебывался и писал на том на чем умеешь." - это хорошо для бизнеса, а не для диплома.
Поэтому бери python+numba. Освоишь, заодно и код на сишке будешь писать менее говнокодистый.

Фортран первый высокоуровневный язык, на нем много научных вычислений просто из-за того, что их дохуя написали за полвека его существования. Но сам язык хуевый.
Аноним 06/03/19 Срд 09:22:47 1359978406
>>1359924
>И "Я бы на твоем месте не выебывался и писал на том на чем умеешь." - это хорошо для бизнеса, а не для диплома.
Как говорил брус ли - надо боятся не того кто написал 100 строк на 100 языках, а того кто написал 1000000 строк на 1 языке.
Аноним 06/03/19 Срд 09:32:16 1359982407
>>1359978
Я на 100 языках тебя уделаю, пока ты будешь 1000000 делать на одном.
Аноним 06/03/19 Срд 09:45:20 1359986408
НУБО_ВОПРОС

int array[4][8];
...
func(array);

Что в данном случае передётся в функцию? Ну всымсле НЁХ/поинтер(если поинтер то на что?)?
Аноним 06/03/19 Срд 09:46:43 1359988409
Аноним 06/03/19 Срд 09:50:03 1359989410
>>1359978
>1000000 строк на 1 языке.
И потом он будет преподовать в ненавистном ВУЗике ненавситным студентам и продолжать фапать на фортран. Действительно, страшно.
Аноним 06/03/19 Срд 09:56:09 1359990411
Аноним 06/03/19 Срд 09:57:06 1359991412
>>1359989
На фортран фапают олды, они как раз на нем считали свой матан, примерно до появления си. Фортнайт фортран они осилили, а си уже нет. Им щас как раз 70-80 лет и они преподают.
Аноним 06/03/19 Срд 10:03:46 1359994413
>>1359991
Си для матана не подходит. Язык, в котором даже не проверяется выход за пределы массива, это маразм.
Аноним 06/03/19 Срд 10:11:21 1359998414
>>1359994
Ну да, зайди в местный нии матана и механики и расскажи им как на си не пишут.
Аноним 06/03/19 Срд 10:29:52 1360001415
>>1359998
Наверное поэтому "местные НИИ" такое дно над которым только насмехаются, хуже чем жарить бургеры в макдаке.
Аноним 06/03/19 Срд 10:37:36 1360003416
>>1360001
Ну, ты хотя бы попытался поискать причину. Это уже похвально.
Аноним 06/03/19 Срд 10:53:47 1360005417
>>1360003
Но ведь он прав. Уважающий себя человек не будет работать за еду, причем очень хуевую
Аноним 06/03/19 Срд 10:56:57 1360008418
>>1360005
А дело в этом исключительно в языке программирования?
Аноним 06/03/19 Срд 11:08:27 1360014419
>>1359994
> Язык, в котором даже не проверяется выход за пределы массива, это маразм.
Что мешает написать структуру либо использовать написанное до тебя?
Аноним 06/03/19 Срд 12:33:11 1360055420
>>1360001
Ну тебе видней с дивана, а пока крылатые ракеты в сирии летают и танчики стреляют на твоей кукареку всем пофиг.
Аноним 06/03/19 Срд 12:38:05 1360057421
>>1360055
>крылатые ракеты в сирии
А потом сами же и ноете, что бабахи вас терроризируют. Вроде программисты тут, а с логикой на "вы".
Аноним 06/03/19 Срд 12:39:40 1360058422
>>1360008
И в языке тоже. Сброд, не способный даже выбрать язык для своей работы, это идиоты, а идиоты не могут ничего хорошего произвести, вот и находятся на дне как и заслужили.
Если что, настоящие ученые используют питон, как самый удобный для любых экспериментов. А в продакшен они ничего не делают, так что производительность им не важна совершенно.

>>1360014
Вопрос был в языке подходящем для матана, а не в языке в котором можно навилосипедить что угодно. Пердолик головного мозга, который вместо работы лепит велосипеды, даже не приступая к собственно работе, это еблан, просирающий время впустую, вдобавок шизло, подменяющее настоящую цель раболты на свой манямирок велосипедов.
Аноним 06/03/19 Срд 12:53:11 1360063423
>>1360058
>настоящие ученые используют питон
Спасибо.Давно так не смеялся.
Аноним 06/03/19 Срд 12:59:29 1360067424
>>1360058
Непонятно ты тупой или так тралишь.
Одно дело ученые в говне моченые, другое дело двачер который собрался лезть в другой язык для написания дипломной работы.
Аноним 06/03/19 Срд 13:08:38 1360072425
>>1360067
А дипломная работа это что? Продукт на рынок или макет показать что алгоритм работает? Мне кажется, второе, именно этим занимаются ученые.
Аноним 06/03/19 Срд 13:36:59 1360089426
>>1360072
Так ты не тралишь. Разница в том что ты собираешься одну работу сделать или заниматься этим, те не разовая работа. Проведу доступную тебе аналогию либо ты работаешь перфоратором каждый день тк ты строитель, либо ты учишься работать перфоратором для того чтобы сделать 1 дырку.
Аноним 06/03/19 Срд 13:40:04 1360093427
pyton9.jpg (100Кб, 811x693)
811x693
>>1359828
>Удобнее взять python и numba.
Дяяя, удобнее, хороший язык.
Аноним 06/03/19 Срд 14:13:51 1360108428
>>1360089
Дипломы сдают в ВУЗе, это учебное заведение ученых, при них там ученые клубы, в которые студент может прямо перейти далее работать, либо не захочет и сваливает, получив корочку, которую требуют на работе. Но на работе корочка это формальность, а на самом дел таме требуют совсем другие знания, которые ты учишь самостоятельно.
Аноним 06/03/19 Срд 14:15:34 1360109429
>>1360108
Че ты несешь вообще, даун? Какой работодатель, какой диплом? Речь была про то чтобы лезть в другой язык ради дипломной работы. Земля тебе пухом, долбоеб.
Аноним 06/03/19 Срд 14:19:26 1360111430
>>1360093
>пробел является синтаксической единицей
>для тупой обезьяны это слишком сложная концепция ведь пробелы невидимы
>ПЛАХОЙ ИЗЫК, РЯ!
Аноним 06/03/19 Срд 14:23:06 1360113431
>>1360109
>язык ради дипломной работы
>ты строитель, либо ты учишься работать перфоратором
Где связь, имбецил?
Диплом = ВУЗ = ученые.
Строитель = работа = работа, дебил, ферштейн?
Аноним 06/03/19 Срд 14:27:41 1360116432
>>1360113
>Диплом = ВУЗ = ученые
Хуй=говно=моча
Аноним 06/03/19 Срд 14:29:37 1360118433
>>1360116
>>1360108
Перечитывай до просветления, если можешь читать вообще.
Аноним 06/03/19 Срд 15:35:35 1360156434
Ep17RE.jpg (54Кб, 640x480)
640x480
Сап Сисачь, у меня такой вопрос -

есть приложение, у этого приложения есть ресурсы (картинки звуки текст в своих директориях) как заставить в коде искать их тупо в той же папке где и это приложение? То есть что бы не статичные пути при компиляции какие то вбивать, а что бы вот как у бинарников фаирфокса с сайта - их можно распокавать в любое удобное место (/opt/firefox предположим) симлинкнуть бинарий в /usr/local/bin и оно работает апдейтится. На Си вообще так можно сделать?

get_pwd просто рабочую директорию выводит а не ту в которой придложения как я понял так что не предлагать
Аноним 06/03/19 Срд 15:41:13 1360158435
>>1360111
А разве в современных Иде для питона нет возможности поставить отображение спейсов символами? В виде ещё с древнейших версий это можно сделать, поэтому хз почему это в си треде у кого-то багор должно вызывать
Аноним 06/03/19 Срд 16:20:27 1360177436
Аноним 06/03/19 Срд 17:52:25 1360219437
>>1359986
Численно - адрес первого элемента массива в памяти (т.е., (uintptr_t) &array[0][0]), тип - int (∗)[8], т.е., указатель на массив из 8 интов.

>>1359990
Нет, ты не прав, автоматически к указателю преобразуется только один (первый) уровень массива: массив из 4 массивов из 8 интов -> указатель на массив из 8 интов.

>>1360156
> как заставить в коде искать их тупо в той же папке где и это приложение
Ну получай путь до себя (readlink("/proc/self/exe")), иди до первого слеша с конца строки, втыкай вместо него '\0'. Естественно, если там хардлинки вместо симлинков, то так не прокатит. Но не делай хардлинки, вот и все. Алсо, лучше вытащи это в отдельную функцию и сделай кроссплатформенно: на винде GetModuleFileName(NULL) есть для того же.
Аноним 06/03/19 Срд 18:39:55 1360267438
>>1360063
Аналогично. Сейчас бы он попробовал на питончике покодить, скажем, расчет погоды это просто пример на кластере с использованием GPU. Удачи ему в этом.
Аноним 06/03/19 Срд 18:43:56 1360273439
>>1360219
> втыкай вместо него '\0'
Пиздец так то подход, даже не понял вначале нахуй оно нужно пока в твоем посте подсказку не увидел оказывается в си так строку рубят, впрочем что еще ждать от С99
Путь взял из argv[0] /proc решение не кросплатформенное и даже в никсах отличается, для винды свой отдельный уродливый #ifdef, хардлинков в программе нигде не валяется вроде, а если всмысле кому-то понадобится сделать хардлинк на бинарник то это уже похуй.
Благодарю.
Аноним 06/03/19 Срд 19:02:47 1360280440
>>1360219
А это, еще такой вопрос почему переменная со строкой не скрещается?

fn_to_call(path"/img.png");

path инициализирована через char path[256]; догадываюсь что она типа массив и так просто его записывать в строку нельзя, но я видел в некоторых примерах что так записывабт иногда. Или это только когда константой в хидере прописано и компилятором автоматически подставляется, а так вообще нельзя?
Аноним 06/03/19 Срд 20:15:30 1360323441
>>1360273
> Путь взял из argv[0]
Ты же сам писал про симлинки. В argv будет симлинк, а не настоящий файл. Алсо, в argv[0] может быть что угодно, включая неполный путь или вообще какой-нибудь мусор: https://ideone.com/NWijmR

>>1360280
> почему переменная со строкой не скрещается
В Си нет строк. Есть массивы char, заканчивающиеся \0, которые по соглашению используются вместо строк. В них же разворачиваются и строковые литералы. А чтобы объединить два массива придумали всяческие strcat(), а также циклы или memcpy на худой конец. Тебе strcat() вполне подойдет, например.

> видел в некоторых примерах что так записывабт иногда
Автоматически (на этапе компиляции) склеиваются только литералы. Делают, например, так:
#define PREFIX "Hello, "
puts(PREFIX "world!") но это потому, что оно развернется в puts("Hello, " "world!"); и литералы склеятся.
Аноним 06/03/19 Срд 20:28:51 1360332442
>>1360323
Понятно. Спасибо.
Буду тогда ifdef -ами под разные ос разруливать.
Аноним 06/03/19 Срд 20:35:11 1360334443
PlviPC9KnH8.jpg (71Кб, 740x740)
740x740
Где можно скачать? Торрент не находит.
Аноним 06/03/19 Срд 21:06:45 1360350444
>>1360334
4ое издание в джву нашел за 3 минуты гуглом.
Аноним 06/03/19 Срд 21:38:00 1360372445
>>1360350
Скинь на ргхост, няша.
Аноним 06/03/19 Срд 21:38:24 1360373446
>>1360350
Сильное отличие от седьмого?
Аноним 06/03/19 Срд 21:50:58 1360378447
>>1360372
он зароскомнадзорен
>>1360373
Серьезно? Ты даже поиск освоить не можешь, может не надо тебе программирование?
Аноним 06/03/19 Срд 23:07:09 1360455448
>>1360332
Вот зачем ты спросил? Как мне теперь с этим жить? Почему линукс такой линукс? https://ideone.com/AhIPz6
Аноним 07/03/19 Чтв 01:55:43 1360494449
>>1360378
Ну тебе сложно скинуть чтоле?
Аноним 07/03/19 Чтв 08:09:43 1360535450
>>1360455
Надеюсь ты не специально для меня все это писал?
Для линукса можно еще через /proc/pid/exe getpid()
https://stackoverflow.com/questions/143174/how-do-i-get-the-directory-that-a-program-is-running-from#198099

Или вот библиотеку кто то написал (но в ней через self)
https://github.com/gpakosz/whereami/blob/master/src/whereami.c

Поскольку у в коде и так уже этих прагм (или как это называется) натыкано я по своему их напишу.
Аноним 07/03/19 Чтв 12:33:30 1360608451
>>1360535
> Надеюсь ты не специально для меня все это писал?
Нет, я экспериментировал просто.

> Для линукса можно еще через /proc/pid/exe
/proc/self - это симлинк для /proc/<pid>, где <pid> - твой pid, так что это одно и то же.
Аноним 08/03/19 Птн 19:13:05 1361118452
Попала на основное обучение в школу 21 теперь я буду круче вас всех домоседов тупых
Аноним 08/03/19 Птн 19:30:36 1361131453
>>1361118
молодец, респект
удачи тебе
Аноним 09/03/19 Суб 02:13:41 1361255454
>>1361118
Сначала научись чему-нибудь полезному и работу найди, потом кукарекай.
Понабежали животные со своей школой, пиздец.
хоть и толстота
Аноним 09/03/19 Суб 07:36:34 1361286455
>>1361118
> на основное обучение в школу 21
А тип то какой на выходе?
Аноним 09/03/19 Суб 13:05:49 1361368456
>>1361118
С учетом того, что бассейн ещё идет, ты там Грефу отсосала чтоле?
Аноним 10/03/19 Вск 17:54:16 1362058457
>>1351181 (OP)
Есть ли смысл учить Си, если могу вкотиться в С++?
Аноним 10/03/19 Вск 18:39:10 1362087458
>>1362058
Если ты ОС пишешь, первичную систему инициализации, драйвер или просто хочешь форкнуть какой то легаси проект на Си то однозначно, а если какое то десктопное приложение с нуля писать то зачем мучится писать его на си, честно говоря я деже не понимаю зачем мучится писать его полностью на С++
Аноним 10/03/19 Вск 18:43:54 1362089459
>>1362087
Т.е. Си больше подходит для низкоуровневого программирования, чем кресты?
Ну и поддержка легси.
10/03/19 Вск 18:45:01 1362090460
>>1362089
Си подходит, если ты хочешь понимать все, что происходит в программе. Т.к., в отличие от C++ язык простой, и не приходится заниматься шаманством.
Аноним 10/03/19 Вск 18:46:50 1362091461
>>1362090
Типа, вручную врубать гарбедж коллектор и указывать ему, что делать?
Аноним 10/03/19 Вск 19:37:59 1362113462
>>1362089
> Т.е. Си больше подходит для низкоуровневого программирования, чем кресты?
На мой субъективный взгляд они оба не подходят уже ни для чего, но просто нету пока созревшей альтернативы.
В Си меньше всяких возможностей, там нет ооп там нет нормальной работы со строками, нет никакой безопасности в плане работы с памятью, только математика и какие то базовые конструкции. В следствии чего программы получаются маленькими легковесными и быстро компилируемыми хоть на утюг прпи наличии компилятора. Плюсы по сравнению с Си содержат кучу всего, но это только по сравнению с Си, по сравнению с другими более модными языками в них куча архаизмов Си а современных фичь постоянно нехватает. Но для плюсов есть оптимизирующие компиляторы и расширения всякие для написания высоконагруженной и сверхпроизводительной хуеты а для модных молодежных только вот какой то один фронтенд к ллвм генерирующий мягко говоря неспешный и не очень оптимизированный код, а то и вовсе какой то самопальный компилятор.

В общем Си на сегодня занимает нишу эмбэйдщины, плюсы хайлоад приложений и научной всякой вычислительной хуиты.
Во всем остальном ВМ языки проявляют себя лучше. Пистон, Сишарп, Джаваскрипт.
10/03/19 Вск 19:52:42 1362121463
>>1362113
> там нет ооп
Отсутствие ключевого слова class - это преимущество. Писать объектно-ориентированный код можно на любом языке.

> нет нормальной работы со строками
А тебе какие строки? UTF-32 или UCS-16? Или, может быть, UTF-8, но с тормозами и исключениями, если строка невалидная? А если у меня микроконтроллер, и я в рот ебал ваш юникод, мне 6 бит на символ за глаза? Поэтому отсутствие "строк" - это преимущество. Огромный недостаток - то, что по традиции байты не отличают от символов и вдалбливают это в каждой первой книге, но это проблема большинства старых языков. Вот, например, в Python3 одумались.

> никакой безопасности в плане работы с памятью
Это системный язык. Не существует никакой безопасной работы с памятью, если ты сам определяешь границы. Тот же раст отлично это показывает - ты либо отсасываешь компилятору и не можешь сделать без костылей даже базовые вещи, либо... у тебя небезопасная работа с памятью.
Аноним 10/03/19 Вск 20:04:32 1362128464
>>1362121
>>1362113
Лол, т.е. я правильно понимаю, что С++ (это его ты пистоном назвал?) - это фреймворк для Си, с ограничениями, но фичами?
Аноним 10/03/19 Вск 20:09:45 1362135465
Аноним 10/03/19 Вск 20:12:32 1362137466
>>1362135
А. Ну да. Там же сишарп и джава (но не скрипт же!)

В общем, если нужно что-то маленькое, низкоуровневое, то это в Си. Если что-то больше, то С++, потому-что не придется ебаться с памятью.

Спасибо за информацию! Пожалуй, попробую Кресты.
Аноним 10/03/19 Вск 20:12:58 1362139467
>>1362128
Ахуеть, представь себе, спп реализован на си, и при желании ты можешь реализовать любой метод спп любого стандарта реализовать на си99. ты фронтендер да?
Аноним 10/03/19 Вск 20:14:10 1362140468
>>1362139
Оу, прости, что в треде для начинающих вкатываться, я демонстрирую себя, как нуб, который только-только начинает вкатываться.
А тебя не смущает, что я на русском говорю? Вдруг у тебя другие ожидания.
Аноним 10/03/19 Вск 20:16:23 1362141469
>>1362140
Это не тред для начинающих. Это мертвый ситред, заваленный шлангоебами и вс дегенератами, и если ты хочешь тут остаться — привыкай.
Аноним 10/03/19 Вск 20:19:19 1362143470
>>1362141
>Это мертвый ситред
Ват? Нумерной, не утонувший, дошедший до бамп-лимита и мертвый?

>шлангоебами и вс дегенератами
Этого ты так любишь?

>и если ты хочешь тут остаться
Я хотел совет и получил его. Теперь я знаю, что если хочу попробовать, то намного разумнее будет начинать с крестов.
Аноним 10/03/19 Вск 20:21:46 1362145471
>>1362128
>это фреймворк для Си, с ограничениями, но фичами?
Нет. Это 2 разных языка со своими фичами и ограничениями.
Аноним 10/03/19 Вск 20:26:32 1362153472
>>1362121
> Отсутствие ключевого слова class - это преимущество. Писать объектно-ориентированный код можно на любом языке.
Ключевое в объектно ориентированном подходе не наличие или отсутствие слова class, а наследование.

> А тебе какие строки? UTF-32 или UCS-16? Или, может быть, UTF-8, но с тормозами и исключениями
Да хоть какие, я же говорю про средства выражения и инструменты - регекспы мультистроки вставки, вот это вот все.

> Это системный язык. Не существует никакой безопасной работы с памятью, если ты сам определяешь границы.
В эльбрусе существует и в некоторых разрабатываемых на западе архитектурах по видимому будет то же.
Так что готовься сосать у компилятора и учится решать задачи в рамках логики/конструкций высокоуровневого языка.
Аноним 10/03/19 Вск 20:31:30 1362155473
>>1362137
>не придется ебаться с памятью
Придётся. Есть умные указатели, но ты всё-равно должен представлять себе, кто владеет чем и в какой момент всё удалять.
Аноним 10/03/19 Вск 20:35:18 1362159474
>>1362143
Блять. Пощади, дебилоид. Если ты только-только начал вкатываться, то задавай нормальные вопросы, а не свою хуету уровня b с вопросами уровня куда вкатываца. Спрашивай по сабжу, ответят нормально.
10/03/19 Вск 20:41:33 1362163475
>>1362153
> Ключевое в объектно ориентированном подходе
ООП - это такой термин, у которого дохуя возможных трактовок, и каждый выбирает самое удобное для него толкование. Ты вот, например, даже не указал, что именно собрался наследовать. Реализацию ты можешь отлично наследовать на сишке.

> я же говорю про средства выражения и инструменты
Берешь либу и используешь.

> В эльбрусе существует
Нормальную документацию завезли уже?

> по видимому будет то же
Инструкция bound в x86 старше, чем ты сам. Вот только оно настолько никому нахуй не нужно, что кроме как в тормознутом вижуалбейсике в двухтысячных этого никто нигде не видел. Да и там отключалось.

> учится решать задачи в рамках логики/конструкций высокоуровневого языка
tsya.ru
Что касается логики и конструкций, вот я пишу прошивку или даже меморименеджер для ОС, вся память моя, что контролировать собираешься? Похуй. Пишу обычный сервер под линукс, у меня пул объектов, я их заранее выделил, они все мои, как будешь контролировать доступ от тредика, связанного с одним объектом к другому объекту из этого же пула? Интел вон не осиливает между адресными пространствами доступ разделить, постоянно что-то протекает, о чем уж тут говорить вообще.
Аноним 10/03/19 Вск 22:00:35 1362220476
>>1362163
> Ты вот, например, даже не указал, что именно собрался наследовать
Как чего наследовать https://ru.wikipedia.org/wiki/Наследование_(программирование)
> Берешь либу и используешь.
Да нету такой либы чтобы дать то чего изначально нет.
> Нормальную документацию завезли уже?
Ну ты же охуел, подробное описание архитектуры валяется давно http://www.mcst.ru/files/511cea/886487/1a8f40/000000/book_elbrus.pdf#page=150
Описания команд и вообще всей системы программирования только нет
> Что касается логики и конструкций, вот я пишу прошивку или даже меморименеджер для ОС, вся память моя, что контролировать собираешься? Похуй.
Это же часный случай, я вот то же например не хочу картинку качать на комп куда то что бы ее запостить а хочу сразу с буры по url постить сидеть. Давайте убирем все ограничения жабаскриптам что-ли пускай шлют запросы куда и как хотят, или не стоит все таки?
Я не говорил вроде нигде что там где оно нахуй не надо надо ее туда втулить, мне просто непонятно что ненормального можно увидеть в нормальном разруливании задачь средствами языка.
Тем более с эльбрусом как я уже сказал будешь как фуфел-ВМщик в область видимости втыкатьи учиться программировать по строгим правилам.
10/03/19 Вск 22:10:48 1362228477
>>1362220
Хуйня твой эльбрус.
Аноним 10/03/19 Вск 22:29:39 1362244478
>>1362220
> Да нету такой либы чтобы дать то чего изначально нет.
Это в JS так, "вот браузер нипаддерживает, значит нельзя". А в Си если чего-то нет, ты просто берешь и пишешь. И чаще всего это уже кто-то написал за тебя.

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

> www.mcst.ru
> Контроль границ данных и кода обеспечивается за счет того, что в качестве указателей на данные в программах на языках C и С++ применяются дескрипторы переменных и дескрипторы объектов соответственно
Очень хорошее, глубокое техническое описание. Они изобрели fat pointers? Оно давно везде есть, но только область применения узкая, потому что тормоза, и потому что границы объектов часто размыты. Например, как в случае с пулом объектов выше.

> а хочу сразу с буры по url постить
В винде, начиная вроде бы с 98, в диалог открытия файлов можно вставлять урл.

> мне просто непонятно что ненормального можно увидеть в нормальном разруливании задачь средствами языка
В высокоуровневом языке защита ног от программиста - это плюс. А в низкоуровневом ты, а не язык, определяешь, что именно из всего окружающего мира - твои ноги, поэтому если язык лезет со своим охуенно важным мнением - это плохой язык.

>>1362228
В целом нет. В том виде, в котором оно сейчас - да.
Аноним 10/03/19 Вск 22:39:44 1362250479
>>1362244
VLIW процессоры это тупиковая ветвь развития в процессоростроении, так что он говно в любом случае.
Аноним 10/03/19 Вск 23:13:11 1362259480
Сап, аноны. Подскажите, пожалуйста, по следующему вопросу:
Есть ли стандарты языка в печатном виде C99/C11 и в нормальном переплете?

Дело в том, что читать с экрана глаза устают и с печатного варианта приятнее. Можно, конечно, распечатать на работе, но тогда это превращается в кипу бумажек, в которой еще листы постоянно теряются и путаются. Поэтому, я был бы даже готов купить стандарты в виде книги, если цена приемлемая.
Аноним 10/03/19 Вск 23:21:24 1362262481
Аноним 10/03/19 Вск 23:26:38 1362266482
>>1362259
> Есть ли стандарты языка в печатном виде C99/C11 и в нормальном переплете?
Есть. Официальные, у iso.org. 13к, и он твой. Ну или есть многочисленные сервисы print on demand, получится в 3-4 раза дешевле, но при этом все еще с нормальным качеством.
Аноним 10/03/19 Вск 23:29:32 1362268483
>>1362262
>>1362266

Ок. Спасибо. 13к многовато для меня будет. Да и в 3-4 раза дешевле - тоже. Видимо, буду возиться со скоросшивателем)
Аноним 10/03/19 Вск 23:47:53 1362278484
>>1362268
Последний драфт c17 качай и печатай. Если найдешь офф. релиз c17 стандарта, кинь сюда
Аноним 11/03/19 Пнд 01:14:30 1362327485
>>1362259
Просто интересно, зачем тебе "читать" стандарт? Я понимаю использовать как справочник (раздел тут, раздел там), но чтобы отдельно сидеть и читать? Там же legalese очень серьёзный.
Аноним 11/03/19 Пнд 01:28:22 1362331486
>>1362327
А я его как справочник и собираюсь использовать. Видимо, плохо сформулировал в своем вопросе. Подсмотреть что-то, если непонятно, что бы под рукой было. Лучше в стандарте смотреть, чем на StackOverFlow искать. Что-то "читать" ради того, что бы просто "читать" - я не собираюсь, т.к. это глупо.
Аноним 11/03/19 Пнд 02:14:50 1362337487
>>1362331
> Лучше в стандарте смотреть, чем на StackOverFlow искать
Не факт. В стандарте ответы могут быть раскиданы по разным главам, а на SO тебе все это уже нашли и свели в один короткий ответ, да еще и с комментариями.
Аноним 11/03/19 Пнд 16:35:17 1362484488
Подскажите, где я обосрался? Выводит огромное значение, хотя вроде все логично
https://pastebin.com/raw/ivBedi3m
11/03/19 Пнд 16:56:58 1362499489
>>1362484
> Подскажите, где я обосрался?
Обосрался ты в первую очередь в отсутствии проверки значения, которое вернула scanf(). Если бы проверил - узнал бы, что scanf() делает ноль присваиваний. А делает она так потому, что указание точности в scanf() не имеет смысла и поэтому не поддерживается. Оставь просто %lf, и все заработает.
Аноним 11/03/19 Пнд 17:01:34 1362503490
>>1362499
Спасибо большое. Я чет на дауничах перепутал, когда это можно юзать, а когда нет
Аноним 11/03/19 Пнд 17:03:23 1362504491
11/03/19 Пнд 17:58:06 1362522492
>>1362504
Тебе же написали, что %Lf для long double. А у тебя что?
Аноним 11/03/19 Пнд 21:10:14 1362614493
>>1362484
Бля, ну куда ты лезешь? Это не объектная хуита, тут нельзя вызывать методы на каждый пук. Если ты допилишь этим же образом функционал до базовых функций обычного калькулятора, у тебя будет программа будет два числа складывать за 50кб памяти. Или в джаву или сишарп, тебе самому же легче будет
Аноним 11/03/19 Пнд 21:16:03 1362623494
>>1362614
У него все ок. Код читаемый, вызов cube() компилятор заинлайнит. Можешь сходить на годболт и проверить.
Аноним 11/03/19 Пнд 21:26:14 1362631495
>>1362614
>ему жалко 4-6 байт на пролог и эпилог функции
Плюс, всё равно инлайн будет.
Аноним 11/03/19 Пнд 21:29:10 1362636496
Поясните, нахуя сейчас учить С, если есть rust?
11/03/19 Пнд 21:32:09 1362640497
>>1362636
Связный список написал уже?
Аноним 11/03/19 Пнд 21:51:31 1362666498
>>1362640
А ты MemorySanitizer заюзал на gcc? То-то же
Аноним 11/03/19 Пнд 21:53:13 1362669499
>>1362631
>>1362623

Нельзя так писать на си. Это язык не для этого. Нельзя считая выражение из 10 действий вызывать десять раз разные функции и постоянно в них перекидывать промежуточный результат. Нельзя использовать сканф в реальной работе. То что он делает — это просто реализация контента задачников по джаве на си. Бесполезно, бессмысленно, беспощадно. Таким образом ничему не научиться в си, и судя по всему ему и нужен не си. Ему будет лучше и легче пойти сразу делать это на джаве.
Аноним 11/03/19 Пнд 22:02:24 1362683500
>>1362669
> Нельзя
Ты запретил?
11/03/19 Пнд 22:10:50 1362693501
>>1362666
> А ты MemorySanitizer заюзал на gcc?
Конечно. Но в моем коде редко всплывают подобные проблемы.

>>1362669
> Нельзя использовать сканф в реальной работе.
Единственная здравая мысль. Но он вряд ли пишет что-то реальное, так что никаких проблем по-прежнему нет.
Аноним 11/03/19 Пнд 22:18:28 1362705502
>>1362693
>Конечно. Но в моем коде редко всплывают подобные проблемы.
И давно в gcc завезли чеки на чтение неинициализированной памяти?
Аноним 11/03/19 Пнд 22:19:04 1362707503
>>1362669
>Нельзя считая выражение из 10 действий вызывать десять раз разные функции и постоянно в них перекидывать промежуточный результат
Я понимаю, если у тебя оптимизированная функция с SIMD и интнринсиками, когда ты реально считаешь циклы и расчитываешь скедьюлинг на порты проца, или ты пишешь под эмбеддед с хреновым компилятором, который половину языка не поддерживает, тогда да.
>Нельзя использовать сканф в реальной работе
Если в реальной работе ты в прицнипе принимаешь инпут от юзера в проге на Си (или даже плюсах) - это уже провал. А для примеров вполне сгодится. Те же K&R начинали с такого рода примеров.
11/03/19 Пнд 22:46:29 1362725504
>>1362705
> чеки на чтение неинициализированной памяти
Обычно решается заполнением кучи всевозможными 0xbaadf00d. И еще шланг умеет давно, и valgrind вроде тоже. Гораздо более частый доступ к неинициализированной локальной переменной ловится еще на этапе компиляции уже лет тридцать.
Аноним 12/03/19 Втр 00:42:57 1362796505
>>1362725
0xDEADBEEF
дико проиграли когда индусы спросили, почему у нас в драйвере используется это значение
ПЕРЕКАТ Аноним # OP 12/03/19 Втр 00:51:28 1362800506
Настройки X
Ответить в тред X
15000 [S]
Макс объем: 40Mб, макс кол-во файлов: 4
Кликни/брось файл/ctrl-v
Стикеры X
Топ тредов
Избранное