linux c warning 'XXX' declared 'static' but never defined解决方法

C语言中的static一直都是比较头疼的问题,但是高质量的C 程序往往都将static用的非常精妙。

今天在程序使用static的时候遇到一个问题,定义一个局部可见的程序的时候使用了static,在头文件声明后产生了“warning 'XXX' declared 'static' but never defined”的警告。

XX.c文件中:

static int test(void)
{
   .........
}

 XX.h文件中:

static int test(void);

问题原因:声明为static的函数不能被其他文件所使用,如果其他文件include XX.h。那么就会报上面的错误。

解决的办法很简单,将头文件中的声明转移到.c文件中就可以了。

XX.c文件中:

static int test(void);

   ..........

static int test(void)
{
   .........
}

 

  • 7
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
.erase(it); found = true; break; } } if (found) { cout << "删除成功!"这个警告是由于定义了一个变量ptr,但是在后面的代码中没有使用到ptr,编译 << endl; } else { cout << "没有找到该歌曲!" << endl; } } // 按器认为这个变量是多余的,因此给出了这个警告信息。 如果确实不需要使用歌名排序 void sortBySongName() { sort(songs.begin(), songs.end(), [](SongInfo a, SongInfo b)这个变量,可以将它从代码中删除,这样就可以避免这个警告了。例如,可以将 { return a.name < b.name; }); cout << "按歌名排序完成!" << endl; } private上面的代码修改为: ```c char receivedData[] = {0x01, 0x03, 0x00: // 输出一首歌曲的信息 void printSongInfo(SongInfo song) { cout << "名称:" <<, 0x00, 0x00, 0x03, 0x05, 0xCB}; char str[] = song.name << endl; cout << "歌手:" << song.singer << endl; cout << "作曲者:" << song "0x00 0x00 0x00"; if (strstr((char *) receivedData, str) != NULL) { .composer << endl; cout << "类别:" << song.category << endl; cout << "年份:" << song.year << printf("receivedData contains str.\n"); } else { printf("receivedData does not contain str.\n"); } ``` 在这 endl; cout << "喜爱程度:" << song.favorite << endl; cout << "曲风:" << song.style << endl个例子中,我们直接将receivedData强制类型转换成char类型的指针,并将其作为strstr函数; cout << endl; } }; int main() { MusicManagementSystem system; // 创建音乐信息管理系统对象的第一个参数传入,而不需要定义一个额外的变量ptr。这样就可以避免上述警告了。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值