zoukankan      html  css  js  c++  java
  • day09

           今日内容:

    一:复习:

    1文件处理:

        1;操作文件的三步骤;打开文件。操作文件。释放文件

        2:读,写

        3:边读边写:with open('1.txt', 'r', encoding='utf-8') as rf:
                             with open('2.txt', 'w', encoding='utf-8') as wf:
                                      for line in rf:
                                      wf.write(line)

    2,模式:           1.模式 主模式:r | w | a | x  r: 文件必须有的读,游标默认在开头,游标可以移动  w:文件有清空,无创建的写模式,虽然游标可以移动,但该模式一定会清空文件  a:文件有追加,无创建的写模式,游标永远从末尾开始操作  x:文件无创建写,有报错   从模式:t | b | +  t:默认模式,以字符形式操作  b:以字节形式操作  +:可读可写

                           2.seek(offset, type)  -- offset: 偏移的字节数  -- type:0 - 游标从头开始  |  1 - 游标从当前开始  | 2 - 游标从末尾开始  -- 游标操作必须在rb模式下

    二;内存管理 

    引用计数:垃圾回收机制的依据

    1.变量的值被引用,该值的引用计数 +1
                        2.变量的值被解绑,该值的引用计数 -1
                        3.引用计数为0时就会被垃圾回收机制回收

    2.引用计数会出现循环引用问题:相互引用无法释放

          1.两个变量引用其值,值之间又相互引用
          2.变量与值进行解绑,但是值之间还存在相互引用,导致值得引用计数永远 >0
          3.引用计数>0的值永远无法被引用计数机制回收,导致内存泄露

    标记清除:解决循环引用问题

    所有线程能访问到的栈区变量,称之为 gc roots对象

                          1.所有gc roots对象可以直接或间接访问到的变量值,都会被 标记机制 标记为存活状态
                          2.将所有存活状态的值形成新的拷贝,变量完成重新引用
                          3.清除机制 会将之前所有产生的值都进行回收

    分代回收:采用的还是引用计数来回收,是对该机制的一个优化措施

                          1.刚产生的变量值放在新生代中高频率检查,如果引用计数为0,就是采用引用计数机制回收,长期存活的变量值经过多次检查后会提高分代
                          2.分带又高,检查频率越低,且还能继续提高一直存活的变量值的分带,从而来提高整体垃圾回收的效率

  • 相关阅读:
    二分查找(通过相对位置判断区间位置)--17--二分--LeetCode33搜索旋转排序数组
    归并排序(归并排序求逆序对数)--16--归并排序--Leetcode面试题51.数组中的逆序对
    22-Java-Hibernate框架(二)
    21-Java-Hibernate框架(一)
    操作系统-5-进程管理(二)
    操作系统-4-进程管理(一)
    操作系统-3-操作系统引论
    操作系统-2-存储管理之LRU页面置换算法(LeetCode146)
    20-Java-正则表达式
    19-Java-核心类库2-包装类、Integer类、String类、StringBuffer类、StringBuilder类
  • 原文地址:https://www.cnblogs.com/Fzhiyuan/p/10759553.html
Copyright © 2011-2022 走看看