当前位置: 首页 > wzjs >正文

如何给网站做防御怎么一键打开两个wordpress

如何给网站做防御,怎么一键打开两个wordpress,手机建站官网,wordpress每篇文章怎么加关键词1. 递归调用子目录 Makefile 通过 $(MAKE) -C 进入子目录并执行其 Makefile,这是最常见的分层构建方法。 示例:基本递归调用 目录结构: project/ ├── Makefile # 顶层 Makefile ├── lib/ │ ├── Makefile # 子目录…

1. 递归调用子目录 Makefile

通过 $(MAKE) -C 进入子目录并执行其 Makefile,这是最常见的分层构建方法。

示例:基本递归调用

目录结构:

project/
├── Makefile         # 顶层 Makefile
├── lib/
│   ├── Makefile     # 子目录 Makefile
│   └── src/
├── app/
│   ├── Makefile
│   └── src/
└── test/├── Makefile└── src/

顶层 Makefile 内容:

SUBDIRS = lib app test.PHONY: all clean $(SUBDIRS)all: $(SUBDIRS)$(SUBDIRS):$(MAKE) -C $@clean:for dir in $(SUBDIRS); do \$(MAKE) -C $$dir clean; \done

说明:

  • SUBDIRS 定义了所有子目录。

  • all 目标依赖 $(SUBDIRS),按顺序调用每个子目录的 make

  • clean 目标递归调用所有子目录的 clean 目标。


2. 处理子目录依赖关系

确保子目录按依赖顺序构建(例如 app 依赖 lib)。

示例:显式声明依赖
# 顶层 Makefile
SUBDIRS = lib app test# 定义依赖关系
app: lib
test: app.PHONY: all $(SUBDIRS)all: $(SUBDIRS)$(SUBDIRS):$(MAKE) -C $@

说明:

  • app: lib 表示构建 app 前必须先完成 lib 的构建。

  • 此时运行 make all 会按顺序执行:lib → app → test


3. 变量传递到子 Makefile

通过 export 或命令行将变量传递给子目录的 Makefile。

方法 1:全局导出变量
# 顶层 Makefile
export CFLAGS = -O2 -Wall
SUBDIRS = lib app testall: $(SUBDIRS)@echo "所有子目录构建完成"$(SUBDIRS):$(MAKE) -C $@

子目录 Makefile(例如 lib/Makefile):

# 直接使用上层导出的 CFLAGS
lib.o: src/lib.cgcc $(CFLAGS) -c src/lib.c -o lib.o
方法 2:命令行显式传递变量
# 顶层 Makefile
SUBDIRS = lib app testall: $(SUBDIRS)@echo "所有子目录构建完成"$(SUBDIRS):$(MAKE) -C $@ CFLAGS="$(CFLAGS)"

说明:

  • 子目录 Makefile 中,直接使用 $(CFLAGS)


4. 并行构建优化

利用 make -jN 启用并行构建,需确保依赖关系正确。

示例:允许无依赖子目录并行构建
SUBDIRS = lib utils app test# 定义依赖关系
app: lib utils
test: app.PHONY: all $(SUBDIRS)all: $(SUBDIRS)@echo "构建完成"$(SUBDIRS):$(MAKE) -C $@

运行命令:

make -j4  # 并行构建 lib、utils → 完成后构建 app → 最后构建 test

5. 错误处理

确保子目录构建失败时,上层 Makefile 立即终止。

示例:严格错误检查
# 顶层 Makefile
SUBDIRS = lib app test.PHONY: all $(SUBDIRS)all: $(SUBDIRS)@echo "构建成功"$(SUBDIRS):$(MAKE) -C $@ || exit 1clean:for dir in $(SUBDIRS); do \$(MAKE) -C $$dir clean || exit 1; \done

说明:

  • || exit 1 确保子目录构建失败时,整个流程立即终止


6. 多目标支持(如 clean、install)

通过变量动态传递目标名称,实现灵活的多目标调用。

示例:支持 install 和 distclean
# 顶层 Makefile
SUBDIRS = lib app test
TARGET = all  # 默认目标.PHONY: $(SUBDIRS) all install distcleanall: $(SUBDIRS)$(SUBDIRS):$(MAKE) -C $@ $(TARGET)install: TARGET = install
install: $(SUBDIRS)@echo "所有子目录安装完成"distclean: TARGET = distclean
distclean: $(SUBDIRS)@echo "彻底清理完成"

子目录 Makefile(示例 lib/Makefile):

.PHONY: all install distcleanall: lib.o@echo "lib 构建完成"install:cp lib.o /usr/local/lib  # 需要 sudo 权限的操作distclean:rm -f lib.o

运行命令:

make          # 构建所有子目录
make install  # 安装所有子目录(可能需要 sudo)
make distclean  # 彻底清理

7. 动态子目录发现

自动发现子目录,避免硬编码 SUBDIRS

示例:自动遍历子目录
# 顶层 Makefile
SUBDIRS := $(wildcard */.)  # 匹配所有子目录(例如 lib/. app/. test/.).PHONY: all $(SUBDIRS)all: $(SUBDIRS)@echo "构建完成"$(SUBDIRS):$(MAKE) -C $(@D)  # $(@D) 提取目录名(如 lib/. → lib)clean:for dir in $(SUBDIRS); do \$(MAKE) -C $$dir clean; \done

完整示例:分层构建项目

目录结构:
project/
├── Makefile
├── include/
│   └── common.h
├── lib/
│   ├── Makefile
│   └── src/
│       └── lib.c
├── app/
│   ├── Makefile
│   └── src/
│       └── app.c
└── test/├── Makefile└── src/└── test.c
顶层 Makefile:
export CFLAGS = -I../include -Wall -O2
SUBDIRS = lib app test.PHONY: all clean installall: $(SUBDIRS)@echo "=== 构建完成 ==="# 依赖关系
app: lib
test: app$(SUBDIRS):$(MAKE) -C $@clean:for dir in $(SUBDIRS); do \$(MAKE) -C $$dir clean; \doneinstall: all@echo "=== 安装到系统目录(需要 sudo)==="sudo cp app/bin/app /usr/local/binsudo cp lib/lib.so /usr/local/lib
子目录 Makefile(以 lib/Makefile 为例):
TARGET = lib.so
SRC = src/lib.c
OBJ = $(SRC:.c=.o).PHONY: all cleanall: $(TARGET)$(TARGET): $(OBJ)gcc -shared -o $@ $^%.o: %.cgcc $(CFLAGS) -fPIC -c $< -o $@clean:rm -f $(OBJ) $(TARGET)

关键总结

  1. 递归调用使用 $(MAKE) -C 进入子目录执行 Makefile。

  2. 依赖管理:通过目标依赖确保构建顺序(如 app: lib)。

  3. 变量传递export 或命令行显式传递编译选项。

  4. 并行构建:利用 make -jN 加速,但需正确声明依赖。

  5. 错误处理|| exit 1 确保子目录失败时终止。

  6. 多目标支持:通过变量动态传递目标名(如 installdistclean)。

  7. 动态子目录:使用 wildcard 自动发现子目录,避免硬编码。

http://www.dtcms.com/wzjs/535323.html

相关文章:

  • 杭州做宠物网站的公司后台网站建设教程
  • 收录网站查询有没有a站可以打开
  • 网站数据库在空间吗学校网站建设目的及功能定位
  • nike网站建设分析dede网站安全设置防挂马教程
  • 在线制作视频网站百度关键词排名突然没了
  • 10大设计师网站广州 四合一网站开发
  • 宿迁做网站电话南京市英语网站建设
  • 苏州市建设中心网站首页哪个网站有适合小学生做的题
  • 企业微网站建设方案小白wordpress 知乎
  • 网站开发和网络工程哪个好制作广告
  • 甘肃建设局网站大连网站设计菲尔莱斯
  • 什么可以做冷门网站网络营销方式有哪些优点有什么
  • 做网站app 需要多少钱做网站的收益来源
  • 微交易网站建设济南网站维护
  • vs2010网站开发示例个人网站首页设计优秀作品
  • 打开网站后直接做跳转html大学设计论文
  • 自己怎么样建网站视频dreamwear网页制作
  • 银川网站建设哪家好叫啥名字大连建设工程信息网防水
  • 在线课程网站开发任务书卖印花图案设计网站
  • 网站业务员好做吗精仿36氪(36kr)wordpress主题
  • 精品资源共享课程网站建设论文营销推广方案范文
  • 苏州建设局统计网站计算机网络设计是干什么的工作
  • 常州网站制作机构wordpress扁平化中文主题
  • 有哪些网站可以免费看免费招聘网站都有哪些
  • 泉州找工作哪个网站好企业网站建设可行性分析表
  • 大连建设网官方网站seo竞价排名
  • 做网站注册哪类商标做网站的首页下拉列表
  • 鹰潭市城乡建设局老网站asp mysql做网站
  • wap网站建设课程要写代码吗网站导航图怎么做
  • 国外哪个网站做服装劳动节网页设计素材