Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: ф-я инлайн
Форум разработчиков электроники ELECTRONIX.ru > Сайт и форум > В помощь начинающему > Программирование
Метценгерштейн
Keil, ARM

создаю ф-ю
Код
inline void lowPowerHeat (void)
{    
    fSinglePower = 1;
    fDowblePower  =0;
}

где присваиваю двум глобальным переменным значения.
Дальше по коду вызываю эту ф-ю. Но выдает ошибку
.\_build\v1_0_alpha.axf: Error: L6218E: Undefined symbol lowPowerHeat (referred from logic_work.o).

стоит только или:
1 -убрать inline или
2- дописать static или
3- закомментировать любую переменную внутри ф-ии или
4- внутри тела файла один из двух (любой) вызов ф-ии закомментить, то

ошибка пропадает.
А почему так?
Lotor
Подозреваю, что Вам стоит убрать инлайновую функцию в h-файл.
Метценгерштейн
а почему? Она в .c находится. Разве так нельзя?
Harvester
Насколько я понимаю, inline-функция просто по-определению должна быть static.
CrimsonPig
Цитата(Harvester @ Jun 22 2015, 14:42) *
Насколько я понимаю, inline-функция просто по-определению должна быть static.


Вы таки понимаете неправильно. inline и static понятия ортогональные.
P.S. Компилятор должен видеть всю inline функцию целиком. Поэтому если она используется в нескольких модулях, то обычно целиком включается в заголовочный файл. Если она используется только в одном модуле, то можно ее текст включить только в исходник этого модуля. В последнем случае static не помешает но и не поможет сильно.
И вообще это все в любом букваре описано.
Метценгерштейн
понятно, что статик- это область видимости только. Никак на решение проблемы не должно влиять.
Но в чем причина такого поведения?
AHTOXA
Да вроде даже интуитивно понятно - чтобы подставить вызов функции, надо знать только имя и список параметров. А чтобы подставить саму функцию - надо знать всю функцию целиком.
В первом случае достаточно объявления, во втором - необходимо определение.
Метценгерштейн
Цитата(AHTOXA @ Jun 22 2015, 21:45) *
Да вроде даже интуитивно понятно - чтобы подставить вызов функции, надо знать только имя и список параметров. А чтобы подставить саму функцию - надо знать всю функцию целиком.
В первом случае достаточно объявления, во втором - необходимо определение.

и как это мне поможет? Не совсем просто понятно.
Что у меня не так с определением ф-ии?
jcxz
Цитата(Метценгерштейн @ Jun 23 2015, 01:57) *
Что у меня не так с определением ф-ии?

Не так у Вас то, что Вы тут ищете телепатов, коих тут нету. Если бы действительно хотели совета, описали-бы подробно:
в каком файле определена функция? в каких вызывается? какой язык? каковы опции оптимизации (в частности всё что касается inlining)? как определены переменные, которые записываете внутри функции? ...
AHTOXA
Цитата(Метценгерштейн @ Jun 23 2015, 00:57) *
и как это мне поможет? Не совсем просто понятно.
Что у меня не так с определением ф-ии?

Дело в том, что в си используется раздельная компиляция. То есть, каждый *.c файл компилируется отдельно от других.
Теперь смотрите: вы поместили объявление инлайн-функции в файл inline.h:
Код
inline int myInlineFunction();

, а определение инлайн-функции в файл inline.cpp:
Код
inline int myInlineFunction(){
  return 42;
}

Теперь вы хотите использовать эту функцию в файле main.c. Вы пишете:
Код
#include "inline.h"
void main()
{
  i = myInlineFunction();
}

Компилятор компилирует файл main.c. Напомню, компиляция раздельная, то есть, компилятор видит только текущую единицу компиляции. Он видит main.c, он видит включаемый файл inline.h, но не видит файла inline.c. Он хочет подставить встраиваемую функцию, но не видит её тела, а видит только её объявление, расположенное в файле inline.h. Вот и получается ошибка.
Поэтому для встраиваемых функций приходится помещать определение функции в *.h файл. Файл inline.h:
Код
inline int myInlineFunction(){
  return 42;
}

Теперь компиляция main.c пройдёт нормально. Но если мы захотим использовать эту функцию в ещё одном файле, скажем, foo.c, то на этапе линковки возникнет ошибка, потому что модули main и foo будут содержать функцию myInlineFunction(). Для решения этой проблемы надо сделать myInlineFunction() статической:
Код
static inline int myInlineFunction(){
  return 42;
}

Вот теперь всё будет нормально.
halfdoom
Цитата(Метценгерштейн @ Jun 22 2015, 14:26) *
ошибка пропадает.
А почему так?

Если файл logic_work.с содержит определение вышеназванной функции (не путать с объявлением), то это явный баг в компиляторе.
jcxz
Цитата(halfdoom @ Jun 23 2015, 10:51) *
Если файл logic_work.с содержит определение вышеназванной функции (не путать с объявлением), то это явный баг в компиляторе.

Не думаю. Скорей всего ТС что-то недоговаривает. Я уже написал об этом.
Метценгерштейн
Всем привет. Попробуем еще раз сначала. Допускаю, что не все подробно изложил.
То, что ф-я должна быть в .h- это я уже понял. Спасибо за подробное объяснение.
Но тут вот как происходит:
сама ф-я - ее тело- описано в файле, в котором я и вызываю ее. Никаких .h пока нет.
Есть один файл, где и сама ф-я и ее вызов ниже. Т.е. прототип не нужен.
Код
void lowPowerHeat (void)
{    
    fSinglePower = 1;
    fDowblePower = 0;
}

так нет ошибки

Код
inline void lowPowerHeat (void)
{    
    fSinglePower = 1;
    fDowblePower = 0;
}

так сразу ошибки
ViKo
Может, компилятор выбросил ненужную переменную?
CrimsonPig
Цитата(ViKo @ Jun 23 2015, 07:45) *
Может, компилятор выбросил ненужную переменную?


Компилятор выкинул ненужную функцию sm.gif Что, собственно и правильно.

TC, делайте-ка полный поиск по имени вашей функции во всех файлах вашего проекта. Может вы где-то забыли ссылку на нее.
Если не поможет - выкиньте компилятор.
Метценгерштейн
еще раз, я в одном файле .c создал эту inline ф-ю и в этом же файле ее вызываю.

просто глюки какие-то.
ar__systems
Цитата(Метценгерштейн @ Jun 23 2015, 02:57) *
еще раз, я в одном файле .c создал эту inline ф-ю и в этом же файле ее вызываю.

просто глюки какие-то.


Давайте весь файл в студию. Точнее все файлы. ЛОЛ, кол-во глюков с которыми вам приходится иметь дело просто радует

Подозреваю что функция где-то в заголовка объявлена как extern
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.