c – 常数,但仅适用于此范围的其余部分

我有时会遇到这样的情况,即变量是const是有意义的,但仅适用于其范围的后半部分.例如,块的第一部分可能设置值,如果很明显我们已经“完成”设置该变量,则其余部分的可读性可能会提高 –
void foo() {
  int n;
  // Do things that result in initialization of n

  freeze n;  // Imaginary construct that declares "n" const for rest of scope

  // Later steps that depend on 'n' but do not change it
}

是否存在捕获此模式的C语言?当然,块的后半部分可以移动到一个单独的功能,但是可以在不移动任何东西的情况下完成吗?

解决方法

而不是将不可变部分包装为lambda,如何将初始化部分包装成lambda并将其作为const int获取?然后就没有机会改变可变的int n.
void foo() {
  const int n = []() { ;
      // Do things that result in initialization of n
      return initialized_n;
  }();    

  // Later steps that depend on 'n' but do not change it
}

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...