static的全部用法收集整理

本文详细解释了C++中static关键字的多种用途,包括类的静态成员、静态函数、局部静态变量及仅在当前源文件中可见的全局变量和函数等,并对比了auto关键字的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

static的全部用法
     要理解static,就必须要先理解另一个与之相对的关键字,很多人可能都还不知道有这个关键字,那就是auto,其实我们通常声明的不用static修饰的变量,都是auto的,因为它是默认的,就象short和long总是默认为int一样;我们通常声明一个变量:
     int a;
     string s;
     其实就是:
     auto int a;
     auto string s;
     而static变量的声明是:
     static int a;
     static string s;
     这样似乎可以更有利于理解auto和static是一对成对的关键字吧,就像private,protected,public一样;
     对于static的不理解,其实就是对于auto的不理解,因为它是更一般的;有的东西你天天在用,但未必就代表你真正了解它;auto的含义是由程序自动控制变量的生存周期,通常指的就是变量在进入其作用域的时候被分配,离开其作用域的时候被释放;而static就是不auto,变量在程序初始化时被分配,直到程序退出前才被释放;也就是static是按照程序的生命周期来分配释放变量的,而不是变量自己的生命周期;所以,像这样的例子:
     void func()
     {
         int a;
         static int b;
     }
     每一次调用该函数,变量a都是新的,因为它是在进入函数体的时候被分配,退出函数体的时候被释放,所以多个线程调用该函数,都会拥有各自独立的变量a,因为它总是要被重新分配的;而变量b不管你是否使用该函数,在程序初始化时就被分配的了,或者在第一次执行到它的声明的时候分配(不同的编译器可能不同),所以多个线程调用该函数的时候,总是访问同一个变量b,这也是在多线程编程中必须注意的!
static的全部用法:
1.类的静态成员:
class A
{
private:
     static int s_;
};
     在cpp中必须对它进行初始化:
int A::s_ = 0;// 注意,这里没有static的修饰!
     类的静态成员是该类所有实例的共用成员,也就是在该类的范畴内是个全局变量,也可以理解为是一个名为A::s_的全局变量,只不过它是带有类安全属性的;道理很简单,因为它是在程序初始化的时候分配的,所以只分配一次,所以就是共用的;
     类的静态成员必须初始化,道理也是一样的,因为它是在程序初始化的时候分配的,所以必须有初始化,类中只是声明,在cpp中才是初始化,你可以在初始化的代码上放个断点,在程序执行main的第一条语句之前就会先走到那;如果你的静态成员是个类,那么就会调用到它的构造函数;
2.类的静态函数:
class A
{
private:
     static void func(int );
};
     实现的时候也不需要static的修饰,因为static是声明性关键字;
类的静态函数是在该类的范畴内的全局函数,不能访问类的私有成员,只能访问类的静态成员,不需要类的实例即可调用;实际上,它就是增加了类的访问权限的全局函数:void A::func(int);
     静态成员函数可以继承和覆盖,但无法是虚函数;
3.只在cpp内有效的全局变量:
     在cpp文件的全局范围内声明:
     static int g_ = 0;
     这个变量的含义是在该cpp内有效,但是其他的cpp文件不能访问这个变量;如果有两个cpp文件声明了同名的全局静态变量,那么他们实际上是独立的两个变量;
     如果不使用static声明全局变量:
     int g_ = 0;
     那么将无法保证这个变量不被别的cpp共享,也无法保证一定能被别的cpp共享,因为要让多个cpp共享一个全局变量,应将它声明为extern(外部)的;也有可能编译会报告变量被重复定义;总之不建议这样的写法,不明确这个全局变量的用法;
     如果在一个头文件中声明:
     static int g_vaule = 0;
     那么会为每个包含该头文件的cpp都创建一个全局变量,但他们都是独立的;所以也不建议这样的写法,一样不明确需要怎样使用这个变量,因为只是创建了一组同名而不同作用域的变量;
     这里顺便说一下如何声明所有cpp可共享的全局变量,在头文件里声明为extern的:
     extern int g_;      // 注意,不要初始化值!
     然后在其中任何一个包含该头文件的cpp中初始化(一次)就好:
     int g_ = 0;      // 初始化一样不要extern修饰,因为extern也是声明性关键字;
     然后所有包含该头文件的cpp文件都可以用g_这个名字访问相同的一个变量;
4.只在cpp内有效的全局函数:
     在cpp内声明:
     static void func();
     函数的实现不需要static修饰,那么这个函数只可在本cpp内使用,不会同其他cpp中的同名函数引起冲突;道理和如果不使用static会引起的问题和第3点一样;不要在头文件中声明static的全局函数,不要在cpp内声明非static的全局函数,如果你要在多个cpp中复用该函数,就把它的声明提到头文件里去,否则在cpp内部声明需要加上static修饰;在C语言中这点由为重要!
### Django 模板中 `block` 和 `static` 的用法 在 Django 中,模板继承是一种强大的功能,允许开发者通过定义父模板和子模板来实现代码重用。其中,`{% block %}` 是用于模板继承的核心标签之一[^1]。 #### `{% block %}` 标签的作用 `{% block %}` 定义了一个可以被子模板覆盖的内容区域。通常,在父模板中会预先定义一些常见的结构(如 HTML 头部、导航栏等),而具体的页面内容则由子模板填充到这些区块中。例如: ```html <!-- base.html --> <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>{% block title %}Default Title{% endblock %}</title> </head> <body> {% block content %} Default Content {% endblock %} </body> </html> ``` 在这个例子中,`base.html` 提供了一个基本的 HTML 结构,并预留了两个可替换的部分:`title` 和 `content`。任何继承该模板的子模板都可以重新定义这两个部分的具体内容。 #### 子模板如何扩展父模板中的区块 子模板可以通过指定相同的区块名称来覆盖父模板中的默认内容。如果希望保留并追加父模板中的内容,则可以在子模板中使用 `{{ block.super }}` 来调用父级内容。例如: ```html <!-- child.html --> {% extends "base.html" %} {% block title %}Custom Page Title{% endblock %} {% block content %} {{ block.super }} <p>This is additional content added by the child template.</p> {% endblock %} ``` 在这里,`child.html` 覆盖了 `title` 区块,并向 `content` 区块追加了一些额外的信息。 --- #### 静态文件的引入 (`{% static %}`) 为了加载 CSS 文件、JavaScript 或图片等静态资源,Django 提供了 `{% static %}` 标签。它会在运行时解析为实际的 URL 地址。要使用此标签,需先确保已在项目的 `settings.py` 中正确配置了 `STATIC_URL` 和 `STATIC_ROOT` 参数[^2]。 下面是一个简单的示例,展示如何在模板中引用静态文件: ```html <!-- 使用 static 标签加载样式表 --> <link rel="stylesheet" href="{% static 'css/style.css' %}"> <img src="{% static 'images/logo.png' %}" alt="Logo"> <script src="{% static 'js/script.js' %}"></script> ``` 注意:在开发环境中,Django 自动处理静态文件;但在生产环境下,需要手动收集静态文件至统一目录并通过 Web 服务器提供服务[^3]。 --- #### 常见错误及其解决办法 以下是几个与 `{% block %}` 和 `{% static %}` 相关的常见问题以及解决方案: 1. **未找到静态文件** 如果浏览器无法加载静态资源,请确认以下几点: - 是否已启用 `django.contrib.staticfiles` 应用; - 是否设置了正确的 `STATICFILES_DIRS` 和 `STATIC_ROOT`; - 生产模式下是否执行过命令 `python manage.py collectstatic`。 2. **区块嵌套不匹配** 当多个模板层之间存在复杂的区块关系时,可能会发生意外行为。建议仔细检查每层模板中是否有遗漏关闭的 `{% endblock %}` 标记。 3. **忘记加载 `static` 模板库** 在某些情况下,即使写了 `{% static ... %}`,也可能报错提示未知标记。这是因为当前模板尚未显式载入所需的模块。应在顶部加入如下语句: ```html {% load static %} ``` --- ### 总结 综上所述,掌握 `{% block %}` 和 `{% static %}` 的正确用法对于构建高效且易于维护的 Django 网站至关重要。合理规划模板层次结构能够显著减少重复劳动,同时利用好静态文件管理机制有助于提升用户体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值