zoukankan      html  css  js  c++  java
  • 关于报错“syntax error near unexpected token `”和回车换行

    本来是很简单一个事情,转过来是因为打字机这事比较有趣……

    http://blog.csdn.net/xyp84/archive/2009/08/11/4435899.aspx

    摘要一下:

    回车

    换行

    0D

    0A

    <CR>

    <LF>

    Carriage Return

    Line Feed

     

    “/r”

    “/n”

    win32

    0D

    0D 0A

    unix

    0D

    0A

    ============淡定的分割线===============

    今天写了个shell脚本,在自己机器上运行正常,给同事,运行报错syntax error near unexpected token `,左看右看shell脚本没有问题,没有办法google搜索,发现一位仁兄讲的挺好,内容如下:

          用命令vi -b 打开你的SHELL脚本文件,你会。发现每行脚本最后多了个^M。

      那么接下来就要搞清楚这个^M是什么东东?

      long long ago.....  老式的电传打字机使用两个字符来另起新行。一个字符把滑动架移回首位 (称为回车,<CR>,ASCII码为0D),另一个字符把纸上移一行 (称为换行, <LF>,ASCII码为0A)。当计算机问世以后,存储器曾经非常昂贵。有些人就认定没必要用两个字符来表示行尾。UNIX 开发者决定他们可以用 一个字符来表示行尾,Linux沿袭Unix,也是<LF>。Apple 开发者规定了用<CR>。开发 MS-DOS以及Windows 的那些家伙则决定沿用老式的<CR><LF>。

      因为MS-DOS及Windows是回车+换行来表示换行,因此在Linux下用Vim查看在Windows下用VC写的代码,行尾后的“^M”符号,表示的是符。

      在Vim中解决这个问题,很简单,在Vim中利用替换功能就可以将“^M”都干掉,键入如下替换命令行:

      1)vi -b setup.sh

      2)在命令编辑行<就是: 按ESC键 然后shift+:冒号>输入:%s/^M//g

      注意:上述命令行中的“^M”符,不是“^”再加上“M”,而是由“Ctrl+v”、“Ctrl+M”键生成的。

      这样替换掉以后,保存就可以执行了。当然还有其他的替换方式比如:

      a.一些linux版本有 dos2unix 程序,可以用来祛除^M。

      b.cat filename1 | tr -d "/r" > newfile 去掉^M生成一个新文件,还有sed命令等,凡是可以替换的命令都是可以用来新生成一个文件的。

          按照上面所说的,删除^Mshell脚本就运行正常,后来问同事,原来他windows记事本中修改了程序路径,导致每一行多出了^M。

    http://blog.csdn.net/windless0530/article/details/6077654

     先说点常识问题:

    因为MS-DOS及Windows是回车+换行来表示换行,因此在Linux下用Vim查看在Windows下用VC写的代码,行尾后的“^M”符号,表示的是符。
    现在,你使用vim -b 打开你的文件。就会发现每一行都有^M ,那么我们可以是用全局替换替换掉

    ................解决方法

            在命令编辑行<就是: 按ESC键 然后shift+:冒号>输入:%s/^M//g

         注意:上述命令行中的“^M”符,不是“^”再加上“M”,而是由“Ctrl+v”、“Ctrl+M”键生成的。 

    MyISAM中确实很容易就会发生Lock一大片的情况,主要是某些情况下某个表的耗时Select语句,阻塞了Insert语句,然后Insert语句就锁住了这个表,让其他的Select语句无法执行。

    简单的说就是耗时的Select语句,参杂了一些Insert语句,导致大面积Select被Lock,演变成了串行执行。

    参数如下:

    concurrent_insert  通过查看 show variables like '%concurrent%'

    0: 表示不能并发,Select, insert之间只能串行执行

    1:表中有空洞(删除记录留下的)情况下,阻塞insert; 表中无空洞的情况下,Insert并发插入表尾

    2:无论是否有空洞都并发插入表尾

    默认情况下, 这个值是1, 所以在既有Select又有insert的情况下,很容易就出现了近似串行的执行场景。


    解决方法:

    1.  concurrent_insert=2  坏处就是delete的空洞永远都不去补回来了,浪费空间,浪费了cpu扫描

    2.  --low-priority-updates启用mysqld,让select有更高优先级

    3.  在语句中加上HIGH_PRIORITY, LOW_PRIORITY以定义优先级,让select赶在insert锁定之前执行

    http://hi.baidu.com/dmkj2008/item/0b58d20c228a9f8e03ce1b46

  • 相关阅读:
    element 步骤条steps 点击事件
    element-ui的rules中正则表达式
    从master分支创建自己的分支
    2.1 系统调用io实现原理
    2-3形参和实参
    2-2函数
    2-1.编译和链接
    linux高编信号-------setitimer()、getitimer()
    linux高编IO-------有限状态机编程原理(mycpy)
    linux高编线程-------线程同步-条件变量
  • 原文地址:https://www.cnblogs.com/youngt/p/3713510.html
Copyright © 2011-2022 走看看