169 похожих чатов

Кстати, а я вот тут подумал. Допустим, у нас имеется

цикл который выполняет огромное количество итераций, но мы хотим, чтобы какие-то действия исполнилось только один раз. В Яву мы для этого использовали бы битовый флаг, но с точки зрения ассемблера возможно сделать джамп в начале цикла, а потом в конце этого участка перезаписать этот джамп nop-ом. Имеет ли смысл делать подобное или вообще любое программное вмешательство в исполняемый код программы вредно?

23 ответов

44 просмотра

в яву бы это однократное действие выполнялось бы до цикла или после него

The Bird of Hermes- Автор вопроса
Mixail Frolov
в яву бы это однократное действие выполнялось бы д...

Предположим, что это сделать невозможно принципиально

Имеет. Я так в некоторых проектах делал.

The Bird of Hermes
Предположим, что это сделать невозможно принципиал...

Принципиально невозможно помещать сделать так.

The Bird of Hermes- Автор вопроса
Mixail Frolov
в яву бы это однократное действие выполнялось бы д...

Цикл обработки сообщений от оконного приложения WinAPI так работает

Незачем. Предсказатель ветвлений обучится так или иначе.

The Bird of Hermes- Автор вопроса
s54820
Незачем. Предсказатель ветвлений обучится так или ...

Ну нопы ведь все равно в тактах дешевле, чем условные прыжки

The Bird of Hermes
Ну нопы ведь все равно в тактах дешевле, чем услов...

будет сбиваться кэш кода, а это уже многое теряет в скорости

The Bird of Hermes- Автор вопроса
The Bird of Hermes
Ну нопы ведь все равно в тактах дешевле, чем услов...

У тебя следующая итерация начнет ещё до джампа выполняться. Если это на самом деле цикл, который что-то считает. А если это оконный цикл, походы в ядро и весь остальной апи сожрут и предсказателя, и весь эффект от твоих патчей. И кэш тоже.

The Bird of Hermes
Ну нопы ведь все равно в тактах дешевле, чем услов...

Это имеет смысл всегда, делай так, если хочешь.

The Bird of Hermes- Автор вопроса
КТ315
Это имеет смысл всегда, делай так, если хочешь.

Ну я просто хочу понять, будет ли это в принципе полезно, вредно или ни на что не повлияет

The Bird of Hermes
Ну я просто хочу понять, будет ли это в принципе п...

SMC позволяет невероятно уменьшить вес, это выглядит круто и просто доставляет удовольствие. По скорости невозможно определить, можешь провести тесты, но скорость вряд ли упадёт. Так что делай.

А ещё в вм, которые x86 на арм запускают, например, может быть очень серьезный дроп: оно пометит страницу, как содержащую самомодифицируемый код, и привет.

The Bird of Hermes- Автор вопроса
s54820
А ещё в вм, которые x86 на арм запускают, например...

А че будет от такого? Антивирус может взвыть?

The Bird of Hermes
А че будет от такого? Антивирус может взвыть?

У тебя и так 12 обнаружений, из которых довольно уважаемые антивирусы пометили программу как "100% malicious", тебе серьёзно интересно мнение антивирусов?

The Bird of Hermes- Автор вопроса
КТ315
У тебя и так 12 обнаружений, из которых довольно у...

Ладно, тогда главное чтобы защитник винды не ругался🤣

The Bird of Hermes
А че будет от такого? Антивирус может взвыть?

Нет, я про вм типа qemu. Динамическая бинарная трансляция. Оно переведет код в целевую архитектуру и покэширует. А если решит, что ты любишь smc, то не покэширует, и будет постоянно переписывать. Не так плохо, как я описываю, но иногда будет.

The Bird of Hermes
Ладно, тогда главное чтобы защитник винды не ругал...

По своему опыту скажу, что он ругается: 1. Если программа консольная, но не использует вывод\чтение консоли 2. Если программа GUIшная, но не рисует GUI 2.1. Если программа GUI, но не имеет ресурсов Там у Defender встроена нейросеть, и она ооочень сложная, даже отсутствие иконки или метаинформации может повлиять, но только в сумме с другими факторами.

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта