gcc添加外部头文件增加系统默认调用路径 10C

Mac os x安装了openblas外部库文件,但其安装路径不是gcc库文件的默认调用路径,希望在不改变该头文件的调用方式#include的情况下能够访问。在~/bash_profile里增加了新的路径,查看路径里有增加的路径,但是编译时仍找不到对应头文件lapacke.h。安装openblas时提示:
怎么通过终端添加ldflags,cppflags

3个回答

你的include是引号还是尖括号包含的头文件,添加了路径应该用引号

ajiao2013
水纸谷幽 我是在添加在系统路径里了,<>应该是可以访问到的吧?引号不是绝对路径吗?这里并不想修改原文件里的调用形式#include<lapacke.h>
一年多之前 回复

你gcc编译的时候,指定-I,-L等对应的路径吗,你题目中的提示就是要你编译器编译的时候设定的

ajiao2013
水纸谷幽 但是我这里需要加载的是一个python的包,c程序只是其中嵌入的一个子模块,并不需要直接调用
一年多之前 回复

如果openblas没有安装在系统路径中,建议在系统路径下创建个软连接,链接到安装目录下的so库

u011514451
hpu刘 回复ajiao2013: ln -s /usr/local/opt/openblas/lib/libopenblas.so.0 /usr/lib64/libopenblas.so.0
一年多之前 回复
ajiao2013
水纸谷幽 回复ajiao2013: 我试过了,不起作用,还是显示'lapacke.h' file not found 有什么办法可以验证该操作正确完成了呢?
一年多之前 回复
ajiao2013
水纸谷幽 回复ajiao2013: 是在终端输入:ls -s /usr/local/opt/openblas/include /usr/local/include
一年多之前 回复
ajiao2013
水纸谷幽 怎么创建软连接?
一年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
linux下给gcc添加头文件和库文件添加默认搜索路径
本人学linxu和编程没多久,很多问题不懂,请各路大神多多指教,感激不尽!!!! 今天在linux下用gcc编译器做了一个动态库(库文件名为libhot.so),库文件在 目录为“/usr/selflib/lib/libhot.so”,这个库的头文件和main1.c在一个目录里(本例子中就是当前目录下),然后就试了试这个库文件,写了一个main1.c文件来调用这个动态库文件中的函数,编译命令如下: gcc main1.c -L /usr/selflib/lib/libhot.so -o main1.o 编译通过了,没问题。但是我觉得这样太麻烦了,每次编译时还要指定动态库文件路径和名字,我知道可以通过编写makefile文件来解决这个问题,但是我还是觉得太麻烦,后来就想找一种方法来增加gcc编译器的头文件和库文件默认搜索路径,做到 gcc main1.c -o main.o 一条简单的命令就能搞定(不用设置环境变量,不用再次指定搜索路径,也不必通过编写makefie来解决),就行使用它的内部库一样那么轻松简单。后来试过了(修改ld.so.conf配置文件,然后以管理员身份运行ldconfig命令)这个方法,失败了,也知道了原因。那应该如何修改才能达到我的目的呢? 求大神们指教!!
Linux下gcc无法找到头文件
我的源码目录:main.c lib //lib是一个目录 我把头文件放在lib目录里面,gcc main.c -o test无法找到我放在lib目录里的头文件 在网上搜了一下,说要在 .bashrc 后面加一句:export C_INCLUDE_PATH= 以下是我.bashrc的配置: # .bashrc # User specific aliases and functions** ali asrm='rm -i' alias cp='cp -i' alias mv='mv -i' #Source global definitions if [ -f /etc/bashrc ]; then . /etc/bashrc fi export C_INCLUDE_PATH=/root/projects/ConsoleApplication1/lib //这条是新加的 然后再用gcc,依然找不到头文件: #运行 gcc main.c -o test /tmp/cco8z3FL.o:在函数‘main’中: main.c:(.text+0x2a):对‘errExit’未定义的引用 collect2: 错误:ld 返回 1 问题,头文件和源文件在不同的目录,如何编译呢?
安装LLVM过程中提示gcc版本低,但是系统中默认的gcc版本就是7.3.0,如何解决?谢谢!!!
![图片说明](https://img-ask.csdn.net/upload/201912/06/1575600474_141765.png)
gcc 的编译问题 求大佬解答
使用gcc 编译.c文件时出现: fatal error: rootshell.h: 没有那个文件或目录 430 | #include "rootshell.h" | ^~~~~~~~~~~~~ compilation terminated. 求大神解答 该怎么办 ![图片说明](https://img-ask.csdn.net/upload/202001/03/1578028924_720407.png)
编译安装gcc后,新的gcc仍调用原有gcc的动态库,怎么解决?
您好,我在linux系统(自带有gcc)的机器上下载了gcc源码,编译并安装成功,安装路径区别于系统自带安装的gcc路径,新的gcc可以正常编译我写的测试程序,但是,我用ldd hello.out发现hello.out调用的还是原来的.so共享库,没使用新安装的gcc库,我配置了LD_LIBRARY_PATH变量为新gcc路径,但使用ldd hello.out发现还是调用原有gcc so库文件,怎样使新安装的gcc调用自己安装目录下的so库文件呢?
关于centos卸载gcc的问题?
linux 3.10 centos 7系统,默认安装的gcc版本为4.8.5。因为跑程序要用到4.9以上的gcc版本,所以安装了gcc-8.3.0。 安装完成后,使用cat /proc/version命令只能看到gcc4.8.5,使用gcc -v命令只能看到gcc8.3.0。 运行程序时,又提示gcc版本不能高于gcc7.0,所以想卸载gcc8.3.0。但是利用rpm -q gcc 只能找到gcc-4.8.5,求问该怎么办?
用Ubuntu16.04编译iDT算法(c++)时报错:/usr/lib/gcc/x86_64-linux-gnu/5/../../../x86_64-linux-gnu/crt1.o: In function `_start':(.text+0x20): undefined reference to `main'
最近在学习iDT算法,刚刚接触Ubuntu也刚刚接触c++,很多东西不是很懂,请教各位: 我在编译iDT算法的时候,需要依赖opencv和ffmpeg两个库,我安装成功并且确保这两个库能用之后,去编译iDT算法,'make'之后报错: ![图片说明](https://img-ask.csdn.net/upload/202001/10/1578648835_846854.png) 查过资料,有的人说是缺少main函数,但是我确保.cpp文件里是有main函数的。 也有帖子说是crt1.o文件的问题,也有帖子说是动态库的问题,现在很迷茫,不知道问题出在哪里,希望各位能够帮助我,万分感谢。 同时为了方便各位帮我找到问题,我上一下我的makefile文件以及Opencv和ffmpeg的安装信息。 Makefile文件 ``` # set the binaries that have to be built TARGETS := DenseTrack Video # set the build configuration set BUILD := release #BUILD := debug # set bin and build dirs BUILDDIR := .build_$(BUILD) BINDIR := $(BUILD) # libraries LDLIBS = $(addprefix -l, $(LIBS) $(LIBS_$(notdir $*))) LIBS := \ opencv_core opencv_highgui opencv_video opencv_imgproc \ avformat avdevice avutil avcodec swscale # set some flags and compiler/linker specific commands CXXFLAGS = -pipe -D __STDC_CONSTANT_MACROS -D STD=std -Wall $(CXXFLAGS_$(BUILD)) -I. -I/opt/include CXXFLAGS_debug := -ggdb CXXFLAGS_release := -O3 -DNDEBUG -ggdb LDFLAGS = -L/opt/lib -pipe -Wall $(LDFLAGS_$(BUILD)) LDFLAGS_debug := -ggdb LDFLAGS_release := -O3 -ggdb include make/generic.mk ``` 下面是opencv和ffmpeg的安装信息: ffmpeg: ![图片说明](https://img-ask.csdn.net/upload/202001/10/1578649174_591798.png) opencv: ![图片说明](https://img-ask.csdn.net/upload/202001/10/1578649330_643110.png) 恳请各位帮忙!!(小弟没有金币,没办法给悬赏,还请各位见谅!)
VScode在设置C语言环境时gcc报错
我的gcc -v和gdb-v都可以在terminal里成功执行, **我的launch.json是这样的: { "version": "0.2.0", "configurations": [ { "name": "(gdb) Launch", // 配置名称,将会在启动配置的下拉菜单中显示 "type": "cppdbg", // 配置类型,这里只能为cppdbg "request": "launch", // 请求配置类型,可以为launch(启动)或attach(附加) "program": "${workspaceFolder}/${fileBasenameNoExtension}.exe",// 将要进行调试的程序的路径 "args": [], // 程序调试时传递给程序的命令行参数,一般设为空即可 "stopAtEntry": false, // 设为true时程序将暂停在程序入口处,一般设置为false "cwd": "${workspaceFolder}", // 调试程序时的工作目录,一般为${workspaceFolder}即代码所在目录 "environment": [], "externalConsole": true, // 调试时是否显示控制台窗口,一般设置为true显示控制台 "MIMode": "gdb", "miDebuggerPath": "D:\\C#\\GCC\\bin\\gdb.exe", // miDebugger的路径,注意这里要与MinGw的路径对应 "preLaunchTask": "gcc", // 调试会话开始前执行的任务,一般为编译程序,c++为g++, c为gcc "setupCommands": [ { "description": "Enable pretty-printing for gdb", "text": "-enable-pretty-printing", "ignoreFailures": true } ] } ] } **我的task.json是这样的: { "version": "2.0.0", "command": "g++", "args": ["-g","${file}","-o","${fileBasenameNoExtension}.exe"], // 编译命令参数 "problemMatcher": { "owner": "cpp", "fileLocation": ["relative", "${workspaceFolder}"], "pattern": { "regexp": "^(.*):(\\d+):(\\d+):\\s+(warning|error):\\s+(.*)$", "file": 1, "line": 2, "column": 3, "severity": 4, "message": 5 } } } 然后我F5调试的时候报错为: 下图找不到gcc??? 请问一下广大网友如何解决
eclipse+gcc编译源代码如何可以生成bin,elf文件
如果仅仅想借助eclipse平台开发一个C/C++ 的IDE,借助CDT还有GCC就可以做到。只是这样对源码编译之后生成的文件是exe文件。如果想生成elf以及bin文件应该怎么做呢?
eclipse+gcc开发ARM时,不能调用.s汇编文件中的函数
eclipse+gcc开发ARM时,不能调用.s汇编文件中的函数 ![图片说明](https://img-ask.csdn.net/upload/201907/03/1562121831_582680.jpg) ![图片说明](https://img-ask.csdn.net/upload/201907/03/1562121888_611237.jpg) 如图所示,无法调用汇编中的该函数。求大神指点。 (开发环境win10)
GCC编译问题 一直找不到头文件
头文件和源文件放在不同的文件夹下,目录结构如下: . ├── include │ ├── test.h ├── src │ ├── test.c test.c 中写: #include "test.h" 怎么写gcc命令 实现编译
redhat下gcc路径的问题
哪位高手能说一下 redhat下有没有默认安装gcc,如果安了路径是什么?
webrtc编译Android版本编译参数is_clang=false时,编译报错,is_clang=true时,编译成功。
[2274/3376] LINK ./rgba_to_i420_converter FAILED: rgba_to_i420_converter exe.unstripped/rgba_to_i420_converter python "../../build/toolchain/gcc_link_wrapper.py" --output="./rgba_to_i420_converter" --strip="../../buildtools/third_party/eu-strip/bin/eu-strip" --unstripped-file="./exe.unstripped/rgba_to_i420_converter" -- ../../third_party/llvm-build/Release+Asserts/bin/clang++ -Wl,--fatal-warnings -fPIC -Wl,-z,noexecstack -Wl,-z,relro -Wl,-z,now -Wl,-z,defs -Wl,--as-needed -fuse-ld=gold -Wl,--icf=all -Wl,--exclude-libs=libgcc.a -Wl,--exclude-libs=libvpx_assembly_arm.a --target=aarch64-linux-android -Wl,-mllvm,-enable-machine-outliner=never -Wl,--warn-shared-textrel -Wl,-O2 -Wl,--gc-sections -nodefaultlibs --sysroot=../../third_party/android_ndk/platforms/android-21/arch-arm64 -nostdlib -Wl,--warn-shared-textrel -pie -Bdynamic -Wl,-z,nocopyreloc -Wl,--dynamic-linker,/system/bin/linker64 -L../../third_party/android_ndk/sources/cxx-stl/llvm-libc++/libs/arm64-v8a -o "./exe.unstripped/rgba_to_i420_converter" -Wl,--start-group @"./rgba_to_i420_converter.rsp" -Wl,--end-group ../../third_party/android_ndk/platforms/android-21/arch-arm64/usr/lib/crtbegin_dynamic.o -lc -lgcc_s -lm -lrt -landroid_support ../../third_party/android_ndk/toolchains/aarch64-linux-android-4.9/prebuilt/linux-x86_64/lib/gcc/aarch64-linux-android/4.9.x/libgcc.a -ldl -llog -lGLESv2 ../../third_party/android_ndk/platforms/android-21/arch-arm64/usr/lib/crtend_android.o /usr/bin/ld.gold: fatal error: obj/rtc_tools/rgba_to_i420_converter/converter.o: unsupported ELF machine number 183 clang: error: linker command failed with exit code 1 (use -v to see invocation)
友善之臂mini2440 运行uart裸板程序失败
用的板子是友善之臂mini2440,自己学习韦东山的一期视频,在写uart裸板程序时发现怎么都无法实现功能 s3c2440.h ``` /* GPIO寄存器 */ #define GPBCON (*(volatile unsigned int*)0x56000010) #define GPGCON (*(volatile unsigned int*)0x56000060) #define GPHCON (*(volatile unsigned int*)0x56000070) #define GPBDAT (*(volatile unsigned int*)0x56000014) #define GPGDAT (*(volatile unsigned int*)0x56000064) #define GPHUP (*(volatile unsigned int*)0x56000078) /* UART寄存器 */ #define UCON0 (*(volatile unsigned int*)0x50000004) #define UBRDIV0 (*(volatile unsigned int*)0x50000004) #define ULCON0 (*(volatile unsigned int*)0x50000028) #define UTRSTAT0 (*(volatile unsigned int*)0x50000010) #define UTXH0 (*(volatile unsigned char*)0x50000020) #define URXH0 (*(volatile unsigned char*)0x50000024) #define UFCON0 (*(volatile unsigned int*)0x50000008) #define UMCON0 (*(volatile unsigned int*)0x5000000C) #define UCON1 (*(volatile unsigned int*)0x50004004) #define UBRDIV1 (*(volatile unsigned int*)0x50004028) #define ULCON1 (*(volatile unsigned int*)0x50004000) #define UTRSTAT1 (*(volatile unsigned int*)0x50004010) #define UTXH1 (*(volatile unsigned char*)0x50004020) #define URXH1 (*(volatile unsigned char*)0x50004024) #define UFCON1 (*(volatile unsigned int*)0x50004008) #define UMCON1 (*(volatile unsigned int*)0x5000400C) ``` uart.h ``` #ifndef _UART_H #define _UART_H void uart0_init(); int putchar(int c); int getchar(void); int puts(const char *s); #endif ``` uart.c ``` #include "s3c2440.h" /* 设置引脚用于串口 */ void uart0_init() { GPHCON &= ~((3<<8)|(3<<10)); //清空GPH2,GPH3 GPHCON |= ((2<<8)|(2<<10)); //GPH4,GPH5用于TXD1,RXD1 GPHUP &= ~((1<<4)|(1<<5)); //使能内部上拉 UFCON0 = 0x00; //不使用FIFO UMCON0 = 0x00; //不使用流控 ULCON0 = 0x00000003; //设置数据格式8n1:8位数据位,无校验位,1停止位 UCON0 = 0x00000005; //PCLK,中断/查询模式 UBRDIV0 = 26; //设置波特率 115200 } int putchar(int c) { while(!(UTRSTAT0) & (1<<2)) UTXH0 = (unsigned char)c; } int getchar(void) { while(!(UTRSTAT0) & (1<<0)) return URXH0; } int puts(const char *s) { while(*s) { putchar(*s); s++; } } ``` main.c ``` #include "s3c2440.h" #include "uart.h" int main(void) { unsigned char c; uart0_init(); puts("hello,world!\n"); while(1) { c = getchar(); putchar(c); } return 0; } ``` start.S ``` .text .global _start _start: /*设置内存:sp 栈*/ ldr sp,=4096 /*nand启动*/ /* 关闭看门狗 */ ldr r0, =0x53000000 ldr r1, =0 str r1, [r0] /* 设置CPU工作于异步模式 */ mrc p15,0,r0,c1,c0,0 orr r0,r0,#0xc0000000 //R1_nF:OR:R1_iA mcr p15,0,r0,c1,c0,0 /* 设置MPLL,FCLK */ /* CLKDIVN(0x4c000014) = 0x5 */ ldr r0, =0x4c000014 ldr r1, =0x5 /* HCLK = FCLK/4 = 100 MHz , PCLK = HCLK/2 = 50MHz */ str r1, [r0] /* 设置MPLLCON(0x4c000004) = (92<<12)|(1<<4)|(1<<0) FCLK = 400 MHz*/ ldr r0, =0x4c000004 ldr r1, =(92<<12)|(1<<4)|(1<<0) str r1,[r0] /*调用main*/ bl main halt: b halt ``` Makefile ``` all: arm-linux-gcc -c -o uart.o uart.c arm-linux-gcc -c -o main.o main.c arm-linux-gcc -c -o start.o start.S arm-linux-ld -Ttext 0 start.o uart.o main.o -o uart.elf arm-linux-objcopy -O binary -S uart.elf uart.bin arm-linux-objdump -D uart.elf > uart.dis clean: rm *.bin *.o *.elf *.dis ``` 程序写完后扔到虚拟机里编译生成.bin文件,之后用友善之臂自己编写的下载工具进行烧写 ![图片说明](https://img-ask.csdn.net/upload/202001/07/1578379644_335442.png) 之后选择nand启动,连接串口,并没有看到返回字符串hello,world! 特来请教
Linux系统中的音乐播放器
用的是centos7,GCC编译后就没反应了怎么回事?![图片说明](https://img-ask.csdn.net/upload/201912/25/1577263309_616211.png) ``` #include <stdio.h> #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> #include <unistd.h> #include <string.h> #include <unistd.h> #include <stdlib.h> #include <dirent.h> #include <signal.h> #include <sys/wait.h> #include <time.h> #include <sys/ptrace.h> char * song[100];//指向歌名的指针数组 char song_buf[100];//存放将要播放的歌的歌名 char cmd_buf[100];//存放命令 int name[100];//存放播放过的歌曲名字,最多保存100首 int all = 0;//歌曲总数 int i;// int com=0;//当前歌 int flag=1;//默认列表播放 0为随机播放 1为列表播放 2为随机播放 int n; int a; void findmusic(void);//查找mp3文件 void getname(void);//获取mp3文件名字 void play_singlecircle_music1(int);//单曲循环 void play_listcircle_music1(int);//列表循环 void play_random_music(int);//随机播放 void last_music(int a);//上一首歌 void next_music(int a);//下一首歌 void text(void);//测试是否正在播放歌曲 void savename(void);//保存歌曲 void Name(void);//播放歌曲超过100时丢掉保存的第一首歌 int m=48;//0的ASCII值为48 void savename(void) { if(n<100){name[n++]=com;//将当前歌存放在数组里 } else Name();//当超过100首歌时,丢弃掉数组里存放的第一首歌 } void fun(int a)//父子进程成功通讯测试函数 { printf("父子进程通讯成功!\n"); } /*用ps -ef | grep -w madplay | grep -v grep | wc -l终端命令来测试是否madplay正在运行,如果运行,执行结果为1,否则为0*/ void text(void) { FILE *fp; FILE *fp2; char buf[15] ={"it's finish!"};//在这里随便定义了一个buf,反正最后只是用来承接终端命令返回值,并且只有第0位用的到 memset(buf,'\0',10); fp = popen("ps -ef | grep -w madplay |grep -v grep |wc -l ","r");//使用FIFO管道执行外部程序,获得的返回值用fread读 fread(buf,1,1,fp); pclose(fp); m=(int)buf[0];//这里获得的0和1为ASCII值 } int main(void) { int ch; int flag=0; getname();//获取当前目录下的mp3文件 pid_t pid=fork(); if(pid<0) { perror("fork"); return -1; } else if(pid==0) { signal(20,fun);//测试 signal(4,play_singlecircle_music1);//使用信号4当作单曲循环信号,觉得可以用,但是会不会影响性能并不清楚,下同 signal(5,play_listcircle_music1); signal(6,play_random_music); signal(7,last_music); signal(8,next_music); while(1);//不让子进程直接执行完毕,等待父进程的信号 } else{ printf("共找到以上本地MP3文件:\n"); sleep(2); kill(pid,20);//测试父子进程通讯 y: printf("*********************************\n");//菜单 printf(" 按1暂停播放 \n"); printf(" 按2继续播放 \n"); printf(" 按3单曲循环 \n"); printf(" 按4列表循环 \n"); printf(" 按5随机播放 \n"); printf(" 按6上一首歌 \n"); printf(" 按7下一首歌 \n"); printf(" 按0退出系统 \n"); printf("*********************************\n"); while(1) { z: printf("请输入你需要进行的操作\n"); scanf("%d",&ch); if(ch<0&&ch>7) {printf("输入有误!\n");goto z;} switch (ch) { case 1:printf("暂停\n"); sprintf(cmd_buf,"killall -SIGSTOP madplay");system(cmd_buf);break;//暂停,给madplay发送暂停信号 case 2:printf("播放\n"); sprintf(cmd_buf,"killall -SIGCONT madplay");system(cmd_buf);break;//播放 case 3:printf("单曲循环\n"); kill(pid,4);break;//单曲循环,给子进程发送信号,进入相应的服务函数 case 4:printf("列表循环\n"); kill(pid,5);break;//列表循环 case 5:printf("随机播放\n"); kill(pid,6);break;//随机播放 case 6: kill(pid,7);break;//上一首 case 7: kill(pid,8);break;//下一首 case 0: kill(pid,9);//关闭全部进程 sprintf(song_buf,"killall -9 madplay"); system(song_buf); raise(9); break; default :break; } goto y; }} wait(NULL); return 0; } void next_music(int a) { sprintf(song_buf,"killall -9 madplay"); system(song_buf); switch(flag) { case 0: savename(); text(); if(m!=48)//如果当前正在播放歌曲,则杀死madplay进程 {sprintf(song_buf,"killall -9 madplay"); system(song_buf);} printf("n = %d\n",n); sprintf(song_buf,"madplay -o wav:- /root/System_project/mp3/ %s 2> /dev/null | aplay 2>/dev/null &",song[com]); system(song_buf); raise(4); break; case 1: savename(); printf("n = %d\n",n); if(com==(all-1)) com=-1; com++; text(); if(m!=48) {sprintf(song_buf,"killall -9 madplay"); system(song_buf);} sprintf(song_buf,"madplay -o wav:- /root/System_project/mp3/ %s 2> /dev/null | aplay 2>/dev/null &",song[com]); system(song_buf); raise(5); break; case 2: savename(); printf("n = %d\n",n); srand((int)time(NULL)); int r=rand()%(all); com=r; text(); if(m!=48) {sprintf(song_buf,"killall -9 madplay"); system(song_buf);} sprintf(song_buf,"madplay -o wav:- /root/System_project/mp3/ %s 2> /dev/null | aplay 2>/dev/null &",song[com]); system(song_buf); raise(6); break; } sleep(1); } void last_music(int a) { sprintf(song_buf,"killall -9 madplay"); system(song_buf); if(n<0) { printf("当前已是第一首\n"); n=0; } com=name[n-1]; n--; //printf("n = %d\n",n); //printf("com = %d\n",com); sprintf(song_buf,"madplay -o wav:- /root/System_project/mp3/ %s 2> /dev/null | aplay 2>/dev/null &",song[com]); system(song_buf); sleep(1); if(flag==0) raise(4); else if(flag==1) raise(5); else if(flag==2) raise(6); } void play_random_music(int a) { int r; flag=2; while(1) { text: text(); if(m!=48)//还是madplay进程的问题,每延时3s查询一次是不是正在播放歌曲,总觉得很鸡肋,却又没找到其他的解决办法 {sleep(3); goto text;} repeat: srand((int)time(NULL)); r=rand()%(all); if (r>all-1) { goto repeat;//产生随机数如果大于i,重新获取,一般是不会的 } savename(); //printf("n = %d\n",n); com=r; sprintf(song_buf,"madplay -o wav:- /root/System_project/mp3/ %s 2> /dev/null | aplay 2>/dev/null &",song[com]); system(song_buf); } } void play_listcircle_music1(int a) { flag=1; while(1) { text: text(); if(m!=48) {sleep(3); goto text;} savename(); //printf("n = %d\n",n); com++; if(com>all-1) {com=0;} sprintf(song_buf,"madplay -o wav:- /root/System_project/mp3/ %s 2> /dev/null | aplay 2>/dev/null &",song[com]); system(song_buf); } } void play_singlecircle_music1(int a) { flag=0; while(1) { text: text(); if(m!=48) {sleep(3); goto text;} savename(); //printf("n = %d\n",n); sprintf(song_buf,"madplay -o wav:- /root/System_project/mp3/ %s 2> /dev/null | aplay 2>/dev/null &",song[com]); system(song_buf); } } void Name(void) { int j; for(j=0;j<99;j++) { name[j]=name[j+1]; } n--; } /* 这里使用脚本查询getname函数,脚本文件内容如下 find *.mp3 */ void findmusic(void) { system("./find.sh"); } void getname(void) { int len; int j; static char *buf; DIR *dir; all=0; struct dirent *ptr; dir = opendir(".");//在当前目录下查找MP3歌曲,如果还有其他路径,就把这里改为其他路径 while((ptr = readdir(dir))!=NULL) { len=strlen(ptr->d_name); len=len-4; if((strcmp(ptr->d_name+len,".mp3"))==0)//后四位进行比较,是否为“.mp3” { buf=(char*)malloc(100);//不开辟空间会导致数组里存放的歌曲全为最后一首歌 memset(buf,0,sizeof(buf)); strcat(buf,ptr->d_name); song[all++]=buf; } } for(j=0;j<all;j++) { printf("%s\n",song[j]); } } ```
写Makefile时头文件中包含路径分割符怎么办
小白求问,这两天一直在尝试Makefile的书写时卡在路径分隔符了,因为做的项目中有出现类似于#include<demo/wait.h>的文件,所以下面我就自己用一个简单的工程来进行试验,请各位大神不吝赐教。 我的系统环境:Ubuntu14.04 文件夹:practice9:main.c add.c Makefile practice2 : math1.h defi.h main.c文件 ``` #include<stdio.h> #include"workspace/practice2/math1.h" int main() { int result = 0; result = add(4,A); printf("result:%d\n",result); return 0; } ``` add.c文件 ``` #include"math1.h" int add(int x,int y) { return x+y; } ``` math1.h文件 ``` #include"defi.h" int add(int x,int y); ``` defi.h文件 ``` #define A 1 ``` Makefile文件 ``` vpath %.h /home/free/workspace/practice2 edit: main.o add.o gcc -o edit main.o add.o main.o: main.c math1.h gcc -c $< -I /home/free/workspace/practice2 add.o: add.c gcc -c $< -I /home/free/workspace/practice2 clean: rm edit main.o add.o ``` 运行在~/workspace/practice9目录make命令时找不到math1.h文件,如果把math1.h文件中的“workspace/practice2/math1.h”换成“math1”就可以运行,请教各位大神这种有路径分割符的头文件怎样弄啊,谢谢各位了~
c++程序未挂,几分钟无响应,之后又好了?
1、里面的每秒定时器显示,距离上次执行超时10分钟了,按理超时2秒都不正常的。 超时期间没有任何日志,程序好多地方都有打印日志的 2、同一时间,相关的另一个进程也未收到任何信息,按理是可以收到的 3、用的是 Ubuntu 14.04.6 LTS (GNU/Linux 4.4.0-93-generic x86_64),gcc version 4.8.4 4、出问题的时候、cpu和内存、文件句柄数都正常,网络、端口、防火墙也可以 5、问题期间尝试建立sock连接无反应 6、刚出问题那会,就算请求进来的信息也突然中断,直到程序自己好了才回复,就好像CPU突然被占用了一样 ![图片说明](https://img-ask.csdn.net/upload/201912/30/1577695786_985376.png)
c++ 这个报错是什么原因?如何解决?
以下代码在编译时报错: ``` #include<iostream> using namespace std; string type_get, str_empty, str_num1, str_num2; string to_do = "+-*/"; int empty, i, operator_num, num1, num2; int flag = 1;//flag=1:运行,flag=0:退出 int plus(int num1,int num2) { int result; result = num1 + num2; return result; } int minus(int num1,int num2) { int result; result = num1 - num2; return result; } int multiply(int num1,int num2) { int result; result = num1 * num2; return result; } int divide(int num1,int num2) { int result; result = num1 / num2; return result; } int main() { while(flag) { cin >> type_get; if (type_get == "exit") { flag = 0; } else { operator_num = type_get.find_first_of(to_do); char array_type_get[type_get.length()]; for (i = 0; i < type_get.length(); i++) { array_type_get[i] = type_get[i]; } for (i = 0; i < operator_num; i++) { str_num1[i] = array_type_get[i]; } for (i = operator_num + 1; i < sizeof(array_type_get); i++) { str_num2[i] = array_type_get[i]; } num1 = atoi(str_num1.c_str()); num2 = atoi(str_num2.c_str()); switch (array_type_get[operator_num]) { case "+" : plus(num1,num2); break; case "-" : minus(num1,num2); break; case "*" : multiply(num1,num2); break; case "/" : divide(num1,num2); break; default : cout << "请输入一个运算符!" << endl; break; } } } return 0; } ``` 报错信息如下: ``` calculator.cpp: In function 'int main()': calculator.cpp:73:10: error: invalid conversion from 'const char*' to 'int' [-fpermissive] case "+" : ^~~ calculator.cpp:73:10: error: conversion from pointer type 'const char (*)[2]' to arithmetic type 'int' in a constant expression calculator.cpp:74:6: error: reference to 'plus' is ambiguous plus(num1,num2); ^~~~ In file included from c:\mingw\lib\gcc\mingw32\8.2.0\include\c++\string:48, from c:\mingw\lib\gcc\mingw32\8.2.0\include\c++\bits\locale_classes.h:40, from c:\mingw\lib\gcc\mingw32\8.2.0\include\c++\bits\ios_base.h:41, from c:\mingw\lib\gcc\mingw32\8.2.0\include\c++\ios:42, from c:\mingw\lib\gcc\mingw32\8.2.0\include\c++\ostream:38, from c:\mingw\lib\gcc\mingw32\8.2.0\include\c++\iostream:39, from calculator.cpp:1: c:\mingw\lib\gcc\mingw32\8.2.0\include\c++\bits\stl_function.h:147:12: note: candidates are: 'template<class _Tp> struct std::plus' struct plus; ^~~~ calculator.cpp:8:5: note: 'int plus(int, int)' int plus(int num1,int num2) ^~~~ calculator.cpp:77:10: error: invalid conversion from 'const char*' to 'int' [-fpermissive] case "-" : ^~~ calculator.cpp:77:10: error: conversion from pointer type 'const char (*)[2]' to arithmetic type 'int' in a constant expression calculator.cpp:78:6: error: reference to 'minus' is ambiguous minus(num1,num2); ^~~~~ In file included from c:\mingw\lib\gcc\mingw32\8.2.0\include\c++\string:48, from c:\mingw\lib\gcc\mingw32\8.2.0\include\c++\bits\locale_classes.h:40, from c:\mingw\lib\gcc\mingw32\8.2.0\include\c++\bits\ios_base.h:41, from c:\mingw\lib\gcc\mingw32\8.2.0\include\c++\ios:42, from c:\mingw\lib\gcc\mingw32\8.2.0\include\c++\ostream:38, from c:\mingw\lib\gcc\mingw32\8.2.0\include\c++\iostream:39, from calculator.cpp:1: c:\mingw\lib\gcc\mingw32\8.2.0\include\c++\bits\stl_function.h:150:12: note: candidates are: 'template<class _Tp> struct std::minus' struct minus; ^~~~~ calculator.cpp:15:5: note: 'int minus(int, int)' int minus(int num1,int num2) ^~~~~ calculator.cpp:81:10: error: invalid conversion from 'const char*' to 'int' [-fpermissive] case "*" : ^~~ calculator.cpp:81:10: error: conversion from pointer type 'const char (*)[2]' to arithmetic type 'int' in a constant expression calculator.cpp:85:10: error: invalid conversion from 'const char*' to 'int' [-fpermissive] case "/" : ^~~ calculator.cpp:85:10: error: conversion from pointer type 'const char (*)[2]' to arithmetic type 'int' in a constant expression ``` **_在这上面卡了好几天了,求各位大神解答!_**
关于gcc __attribute_(( section))使用时对齐问题
__attribute_((section))在使用时,LD链接时的地址对齐原则是什么,现在x64下,有如下宏定义,在多次使用MENU_INIT注册后,每项的对齐地址有没有什么规律? ``` typedef void (*func1)(void); typedef void (*func2)(void); typedef void (*fun3)(void); typedef struct{ int father_id; int self_type; int self_id; func1 f1; func2 f2; func3 f3; }ITEM_OP_S; #define _init __attribute__((used, section(".myitem"))) #define ITEM_INIT(fatherid, selftype, selfid,f1,f2,f3) \ ITEM_OP_S _item_##item_op _init = {(fatherid), (selftype),(selfid),(f1),(f2),(f3) } ``` ``` ```
相见恨晚的超实用网站
搞学习 知乎:www.zhihu.com 简答题:http://www.jiandati.com/ 网易公开课:https://open.163.com/ted/ 网易云课堂:https://study.163.com/ 中国大学MOOC:www.icourse163.org 网易云课堂:study.163.com 哔哩哔哩弹幕网:www.bilibili.com 我要自学网:www.51zxw
爬虫福利二 之 妹子图网MM批量下载
爬虫福利一:27报网MM批量下载    点击 看了本文,相信大家对爬虫一定会产生强烈的兴趣,激励自己去学习爬虫,在这里提前祝:大家学有所成! 目标网站:妹子图网 环境:Python3.x 相关第三方模块:requests、beautifulsoup4 Re:各位在测试时只需要将代码里的变量 path 指定为你当前系统要保存的路径,使用 python xxx.py 或IDE运行即可。
字节跳动视频编解码面经
引言 本文主要是记录一下面试字节跳动的经历。 三四月份投了字节跳动的实习(图形图像岗位),然后hr打电话过来问了一下会不会opengl,c++,shador,当时只会一点c++,其他两个都不会,也就直接被拒了。 七月初内推了字节跳动的提前批,因为内推没有具体的岗位,hr又打电话问要不要考虑一下图形图像岗,我说实习投过这个岗位不合适,不会opengl和shador,然后hr就说秋招更看重基础。我当时
开源一个功能完整的SpringBoot项目框架
福利来了,给大家带来一个福利。 最近想了解一下有关Spring Boot的开源项目,看了很多开源的框架,大多是一些demo或者是一个未成形的项目,基本功能都不完整,尤其是用户权限和菜单方面几乎没有完整的。 想到我之前做的框架,里面通用模块有:用户模块,权限模块,菜单模块,功能模块也齐全了,每一个功能都是完整的。 打算把这个框架分享出来,供大家使用和学习。 为什么用框架? 框架可以学习整体
源码阅读(19):Java中主要的Map结构——HashMap容器(下1)
(接上文《源码阅读(18):Java中主要的Map结构——HashMap容器(中)》) 3.4.4、HashMap添加K-V键值对(红黑树方式) 上文我们介绍了在HashMap中table数组的某个索引位上,基于单向链表添加新的K-V键值对对象(HashMap.Node&lt;K, V&gt;类的实例),但是我们同时知道在某些的场景下,HashMap中table数据的某个索引位上,数据是按照红黑树
c++制作的植物大战僵尸,开源,一代二代结合游戏
    此游戏全部由本人自己制作完成。游戏大部分的素材来源于原版游戏素材,少部分搜集于网络,以及自己制作。 此游戏为同人游戏而且仅供学习交流使用,任何人未经授权,不得对本游戏进行更改、盗用等,否则后果自负。 目前有六种僵尸和六种植物,植物和僵尸的动画都是本人做的。qq:2117610943 开源代码下载 提取码:3vzm 点击下载--&gt; 11月28日 新增四种植物 统一植物画风,全部修
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
Python——画一棵漂亮的樱花树(不同种樱花+玫瑰+圣诞树喔)
最近翻到一篇知乎,上面有不少用Python(大多是turtle库)绘制的树图,感觉很漂亮,我整理了一下,挑了一些我觉得不错的代码分享给大家(这些我都测试过,确实可以生成喔~) one 樱花树 动态生成樱花 效果图(这个是动态的): 实现代码 import turtle as T import random import time # 画樱花的躯干(60,t) def Tree(branch
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 顺便拉下票,我在参加csdn博客之星竞选,欢迎投票支持,每个QQ或者微信每天都可以投5票,扫二维码即可,http://m234140.nofollow.ax.
Python 基础(一):入门必备知识
目录1 标识符2 关键字3 引号4 编码5 输入输出6 缩进7 多行8 注释9 数据类型10 运算符10.1 常用运算符10.2 运算符优先级 1 标识符 标识符是编程时使用的名字,用于给变量、函数、语句块等命名,Python 中标识符由字母、数字、下划线组成,不能以数字开头,区分大小写。 以下划线开头的标识符有特殊含义,单下划线开头的标识符,如:_xxx ,表示不能直接访问的类属性,需通过类提供
深度学习图像算法在内容安全领域的应用
互联网给人们生活带来便利的同时也隐含了大量不良信息,防范互联网平台有害内容传播引起了多方面的高度关注。本次演讲从技术层面分享网易易盾在内容安全领域的算法实践经验,包括深度学习图
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 欢迎 改进 留言。 演示地点跳到演示地点 html代码如下`&lt;!DOCTYPE html&gt; &lt;html&gt; &lt;head&gt; &lt;title&gt;music&lt;/title&gt; &lt;meta charset="utf-8"&gt
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。 1. for - else 什么?不是 if 和 else 才
数据库优化 - SQL优化
前面一篇文章从实例的角度进行数据库优化,通过配置一些参数让数据库性能达到最优。但是一些“不好”的SQL也会导致数据库查询变慢,影响业务流程。本文从SQL角度进行数据库优化,提升SQL运行效率。 判断问题SQL 判断SQL是否有问题时可以通过两个表象进行判断: 系统级别表象 CPU消耗严重 IO等待严重 页面响应时间过长
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 c/c++ 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7
通俗易懂地给女朋友讲:线程池的内部原理
餐厅的约会 餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”我楞了一下,心里想女朋友今天是怎么了,怎么突然问出这么专业的问题,但做为一个专业人士在女朋友面前也不能露怯啊,想了一下便说:“我先给你讲讲我前同事老王的故事吧!” 大龄程序员老王 老王是一个已经北漂十多年的程序员,岁数大了,加班加不动了,升迁也无望,于是拿着手里
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹
面试官:你连RESTful都不知道我怎么敢要你?
面试官:了解RESTful吗? 我:听说过。 面试官:那什么是RESTful? 我:就是用起来很规范,挺好的 面试官:是RESTful挺好的,还是自我感觉挺好的 我:都挺好的。 面试官:… 把门关上。 我:… 要干嘛?先关上再说。 面试官:我说出去把门关上。 我:what ?,夺门而去 文章目录01 前言02 RESTful的来源03 RESTful6大原则1. C-S架构2. 无状态3.统一的接
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
致 Python 初学者
欢迎来到“Python进阶”专栏!来到这里的每一位同学,应该大致上学习了很多 Python 的基础知识,正在努力成长的过程中。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 python 这门编程语言,从2009年开始单一使用 python 应对所有的开发工作,直至今天。回顾自己的学习过程,也曾经遇到过无数的困难,也曾经迷茫过、困惑过。开办这个专栏,正是为了帮助像我当年一样困惑的 Python 初学者走出困境、快速成长。希望我的经验能真正帮到你
Python 编程实用技巧
Python是一门很灵活的语言,也有很多实用的方法,有时候实现一个功能可以用多种方法实现,我这里总结了一些常用的方法,并会持续更新。
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
"狗屁不通文章生成器"登顶GitHub热榜,分分钟写出万字形式主义大作
GitHub 被誉为全球最大的同性交友网站,……,陪伴我们已经走过 10+ 年时间,它托管了大量的软件代码,同时也承载了程序员无尽的欢乐。 万字申请,废话报告,魔幻形式主义大作怎么写?兄dei,狗屁不通文章生成器了解一下。这个富有灵魂的项目名吸引了众人的目光。项目仅仅诞生一周,便冲上了GitHub趋势榜榜首(Js中文网 -前端进阶资源教程)、是榜首哦
推荐几款比较实用的工具,网站
1.盘百度PanDownload 这个云盘工具是免费的,可以进行资源搜索,提速(偶尔会抽风????) 不要去某站买付费的???? PanDownload下载地址 2.BeJSON 这是一款拥有各种在线工具的网站,推荐它的主要原因是网站简洁,功能齐全,广告相比其他广告好太多了 bejson网站 3.二维码美化 这个网站的二维码美化很好看,网站界面也很...
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
相关热词 如何提升c#开发能力 矩阵乘法c# c#调用谷歌浏览器 c# 去空格去转义符 c#用户登录窗体代码 c# 流 c# linux 可视化 c# mvc 返回图片 c# 像素空间 c# 日期 最后一天
立即提问

相似问题

1
aarch64-linux-gnu-gcc QT交叉编译移植
1
Ubuntu用gcc打开c文件,显示找不到文件
1
PHP利用shell_exec执行c文件时出现gcc: error trying to exec 'cc1': execvp: No such file or directory
1
Ubuntu 下codeblocks编译C++,更改头文件后编译不成功问题
1
海思系列的芯片能使用arm-linux-gcc编译的ffmpeg吗。
2
Linux下gcc编译C代码出现段错误,提示没有strcmp.S文件,原因何在?
0
怎么在wins系统上交叉编译生成linux(不是嵌入式平台,想找一个gcc交叉编译器)文件?
2
配置Linux编译环境时出现arm-linux-gnueabihf-gcc: fatal error: no input files问题
0
gcc中target是i486但创建的文件夹是i686开头的
3
请大家帮帮萌新 为什么C语言运行中文会乱码?
0
安装arm-linux-gcc时报错:cannot execute binary file: Exec format error
0
GDB远程调试warning: Could not load shared library symbols for /lib/libc.so.6.
1
eclipse+gcc开发ARM时,不能调用.s汇编文件中的函数
0
在ubuntu下安装完flex bison,flex不能编译.l的文件,bison和gcc正常
1
jetson TX2的开发板安装Pangolin时执行到最后一步make时报错,请问是什么原因?
1
使用dev c++无法调试?
2
c#调用go语言生成的dll传string不成功,急!
0
Linux下为什么在编译时指定了动态库路径但为什么还要先将动态库复制到/lib/下面
1
Linux下反汇编C语言程序,其中有个匿名的且非常简短的函数,通过分析发现这个函数好像没有任何意义?
1
关于Makefile 通用规则的疑问