Спасибо. Про размерность массива я уже думал, можно же просто контроллировать корректность передаваемых параметров. Хотя, можно и добавить контроль внутри функции. Для надежности. Хочу более-менее унивирсальную библиотеку для аппаратного I2C сделать для dspic30. Что то более общее и удобное, чем встроенная в компилятор. В данном случае функция для передачи данных,массив будет только читаться, так что внутри функции не изменится. А в функции для чтения из устройства возможность изменить массив из функции очень даже пригодится. Тема указателей, в общем, то понятна, но пока на практике как то обходился без них. А здесь и не обойтись ...
Ну когда массив передается в кач-ве аргумента функции, он всегда передается как указатель на первый или указанный элемент. Когда передается указатель на данные динамического размера, принято обычно следующим аргументом передавать их длину, если их нельзя терминировать чем-то, как строку \0, к примеру.
использую Onewire библиотеку положительная температура правильно, просто замечательно отображается, а отрицательная- абракадабра
Спойлер// ---------- обращаемся к функции float readDS18B20(){
oneWire.reset(); // сброс шины oneWire.write(0xCC); //обращение ко всем датчикам (если всего один DS18B20) //oneWire.select(sensorAddress); // выбор конкретного адреса - если несколько DS18B20 oneWire.write(0x44); // начать преобразование (без паразитного питания)
oneWire.reset(); // сброс шины oneWire.write(0xCC); //обращение ко всем датчикам (если всего один DS18B20) //oneWire.select(sensorAddress); // выбор конкретного адреса - если несколько DS18B20 oneWire.write(0xBE); // Read Scratchpad (чтение регистров) temp = (oneWire.read() | oneWire.read() << 8 ) / 16.0; //прочитаны 2 байта
}
// ---------- ВЫВОД ТЕМПЕРАТУРЫ НА ДИСПЛЕЕ void showTemp(){ // if(secFr==0) temp=readDS18B20(); // читаем датчик DS18B20. Для DS18S20 не подходит! if(temp<0) showDigit(11, 0, dig5x8rn); // Если температура отрицательная печатаем в начале "-" else showDigit(10, 0, dig5x8rn); // Иначе печатаем "+" int t1=(int)temp/10; // число десятков int t0=(int)temp%10; // число едениц int tf=(temp-int(temp))*10.0; // число десятых if(t1) showDigit(t1, 4, dig4x8); // если десяки = "0" то не печатаем showDigit(t0, 9, dig4x8); // печатаем еденицы showDigit(tf, 16, dig4x8); // печатаем десятые setCol(14, 0xC0); // выводим запятую между целыми и десятыми градусов showDigit(7, 22, dweek_ru); // Выводим значек градусов и "С" } //
помогите как сделать преобразование отрицательного числа
Да, если температура отрицательная, нужно не только минус распечатать, но и сделать её затем для дальнейших расчетов положительной, инвертировав значение.
Пытаюсь сделать копирование массивов с использованием ПДП. Пока есть вариант для копирования побайтно. Но, хочется, при определенных условиях копировать 16-битными словами или 32-битными. Полагал, что если адреса массивов и число копируемых данных делится на 4, то можно использовать 32-битный обмен. Но вот как это узнать?
Этот код не компилируется: "../dma.c", line 41: error #31: expression must have integral type "../dma.c", line 41: error #31: expression must have integral type "../dma.c", line 46: error #31: expression must have integral type "../dma.c", line 46: error #31: expression must have integral type
Как эту проверку сделать правильно?
_________________ А люди посмотрят и скажут: "Собаки летят. Вот и осень."
не знаю в какой теме спросить немного не про С/С++, помогите .
есть сервер FTP с папкой source в которой каждый день создается файл с названием мм-дд-гг.csv (например сегодня 261120.csv завтра создаст 271120.csv и файлов в этой папки уже много) есть компьютер на нем windows хр и папка Destination
нужно написать батник, чтобы виндувс сам копировал из source в час ночи вчерашний фай с расширением csv и вставлял в папку Destination
как поставить запуск этого bat-ника в определенные дни и часы через планировщик Windows, знаю.
написал батник на своем компе... копирует все дни, а нужно только вчерашний.
Допустим 1 января в час ночи он получит текущую дату 210101, а нужна дата предыдущего дня где отличаются год, день и месяц... Лично я бы, наверное, набросал небольшую прогу на С#:
Код:
var date = DateTime.Now; date = date.AddDays(-1); string srcFileName = $"{date.Year - 2000}{date.Month:D2}{date.Day:D2}.csv"; File.Copy(srcFileName, dstFileName);
powershell -command "((Get-date).AddDays(-1)).ToString('ddMMyyyy') | set-content '%TEMP%\tempDate'" && set /p dt=<%TEMP%\tempDate && del %TEMP%\tempDate" copy c:\source\%dt%.csv c:\destination\%dt%.csv
1ая строка получит дату вчера и сохранит её во временный файл. Потом из него считает в переменную окружения %dt% и удалит временный файл. Во 2ой соб-но копируется с указанием переменной. Пример работы, где перед copy дописано echo, чтобы увидеть что будет копироваться:
Код:
C:\Users\nstorm>powershell -command "((Get-date).AddDays(-1)).ToString('ddMMyyyy') | set-content 'C:\Users\nstor\AppData\Local\Temp\tempDate'" && set /p dt= 0<C:\Users\nstor\AppData\Local\Temp\tempDate && del C:\Users\nstor\AppData\Local\Temp\tempDate"
Добавлено after 2 minutes 53 seconds: EDIT4: еще один костыль - bash для windows: https://steve.fi/software/bash/ Через него любой вариант shell-скрипта для bash а-ля Linux. Просто написать, если надо помогу.
Последний раз редактировалось NStorm Чт ноя 26, 2020 20:09:41, всего редактировалось 2 раз(а).
Serzh2000, формат вы раньше чуть другой писали ) хотя я год в 4 цифры написал. Ну поменяйте тогда ToString('ddMMyyyy') на ToString('MMddyy'). А расширение .csv там же при копировании добавляется.
Gudd-Head, без подсказки совсем, предположу что undefined behavior, и будет компиляторо-зависимое. (но это не так, правильный ответ нашел за 3 минуты гугления). Вообще не понимаю вопросы, требующие ответа "без подсказки". Особенно такую экзотику. Кто будет в голове держать то, что в реальности может быть полезно знать раз в пятилетку и загуглить при необходимости не проблема?
На Хабре попалось. Скажете без подсказки, чему равно: 1. 1^NaN 2. 0^NaN 3. NaN^0 ?
Статья на хабре была несколько дней назад и там был пример для python со степенью. Это тема про C/C++, в этих языках есть NAN, а не Nan, а '^' обозначает вовсе не степень. Бинарные же операторы не работают для чисел с плавающей точкой, т.е. все эти примеры просто не скомпилируются...
ps. Оказывается только в ревизии стандарта IEEE 754 от 2008 года закрепили, что pow(1, NaN) и pow(NaN, 0) должны возвращать 1, раньше результатом мог быть и NaN, т.е. ANSI C совместимый компилятор из конца 90-х может возвращать что угодно
Можно ли подобные строки записывать как то проще, без обрамления каждого символа в одинарные кавычки? Т.е. как инициализировать строку с спецсимволами в ней?
Вы не можете начинать темы Вы не можете отвечать на сообщения Вы не можете редактировать свои сообщения Вы не можете удалять свои сообщения Вы не можете добавлять вложения