Dreamweaver CS5.5序列号

<p>1192-1313-4240-0415-2225-5323
1192-1756-8921-7408-0509-4870
1192-1321-8328-4108-7860-1096
1325-0742-6238-7407-1242-6814
1325-0224-6081-7924-2537-9878
1325-0529-4958-2338-7643-2197
1325-0971-9639-6533-2029-7805
1325-0445-2906-3119-6186-8002
1325-0049-7842-6249-6141-8983
1325-0678-8050-4981-1337-8429
1325-0671-2509-1381-3854-2559
 </p>

使用MonoTouch进行iOS开发

开发环境准备

可以参考这篇博文对进行虚拟机环境配置做一下大致的了解。由于 MonoTouch 即将支持 XCode 4, 所以,推荐的开发环境为:

  • 安装 OSX 10.6 ;
  • 安装 XCode 4 到 /Developer 目录, 这样可以使用 XCode 4 提供的编译工具进行编译;
  • 安装 XCode 3 到 /XCode3 目录, 这样可以使用 XCode 3 提供的独立的 Interface Builder;
  • 安装 Mono SDK For Mac OSX 的最新版本;
  • 安装 MonoTouch 的最新试用版;
  • 安装 MonoDevelop for mac osx。

阅读剩余部分 -

点点 - 张静波

<p>继 <<这支烟灭了以后>>  张静波给力的推出了很多好听的单曲. 独特的声音.博主还是很喜欢的.近期推下他的歌</p><p>这首点点 .旋律很好 .</p><p> </p><p>如果生命不是很长
给我你的肩膀
纵然你是我意外的悲伤
也请你将我放在心上
如果青春不是很长
给我你的胸膛
今后这世上旅途的过往
就请你不要将我遗忘 这孤独
漫天飞舞 我可以 笑着哭
谁能够不为爱坚持
谁不是天使
谁写了悲伤的诗
谁得了结局 审讯的开始
谁冷落了悲事重重
谁又点起了往事
谁只是影子
谁想起谁的城市
谁握着钥匙 谁看了谁写的字
如果生命不是很长
给我你的肩膀
纵然你是我意外的悲伤
也请你将我放在心上
如果青春不是很长
给我你的胸膛
今后这世上旅途的过往
就请你不要将我遗忘这孤独
漫天飞舞 我可以 笑着哭
谁能够不为爱坚持
谁不是天使 谁写了悲伤的诗
谁得了结局
审讯的开始
谁冷落了悲事重重
谁又点起了往事
谁只是影子
谁想起谁的城市
谁握着钥匙 谁看了谁写的字
不被爱坚持
谁不是天使
谁写了悲伤的诗 谁得了结局 审讯的开始
谁都不为谁终止
谁又点起了往事 世界是影子
谁想起谁的城市
谁握着钥匙 谁看了谁写的字
我知道生命不是很长</p>

天使的难过 -- 张静波

<p>天使的难过</p><div style="page-break-after: always;"><span style="display: none;"><!--more-->& nbsp ;</span></div><p>

词、曲、演唱:张静波

你伸出了冰冷的手
你说全部生命都给你
够不够 够不够
你说岁月在悄悄流走
你说你所有梦的终点
是厮守 是厮守

深夜你总是守侯在窗口在窗口
望着黑色延伸的尽头很久很久
灯光一直照在你身后你身后
风吹过 你的长发幽幽 心也幽幽

那年你总是跳着唱着
就像是一首绽放的歌
总是发出声响的笑着
透明的欢乐
片片花瓣被风吹落了
你却唱起了悲伤的歌
那泪水在你的眼角亮着
诉说天使的难过</p>

阅读剩余部分 -

jquery的extend和fn.extend

<p>jQuery为开发插件提拱了两个方法,分别是:</p><p>jQuery.fn.extend(object);</p><p>jQuery.extend(object);</p><p>jQuery.extend(object); 为扩展jQuery类本身.为类添加新的方法。</p><p>jQuery.fn.extend(object);给jQuery对象添加方法。</p><p>fn 是什么东西呢。查看jQuery代码,就不难发现。</p><div style="page-break-after: always;"><span style="display: none;"><!--more-->& nbsp ;</span></div><p>jQuery.fn = jQuery.prototype = {</p><p>init: function( selector, context ) {//....</p><p>//......</p><p>};</p><p>原来 jQuery.fn = jQuery.prototype。对prototype肯定不会陌生啦。</p><p>虽然 javascript 没有明确的类的概念,但是用类来理解它,会更方便。</p><p>jQuery便是一个封装得非常好的类,比如我们用 语句 $(&quot;#btn1&quot;) 会生成一个 jQuery类的实例。</p><p>jQuery.extend(object); 为jQuery类添加添加类方法,可以理解为添加静态方法。如:</p><p>$.extend({</p><p>add:function(a,b){return a+b;}</p><p>});</p><p>便为 jQuery 添加一个为 add 的 “静态方法”,之后便可以在引入 jQuery 的地方,使用这个方法了,</p><p>$.add(3,4); &nbsp;//return 7</p><p>(贴码党注:请注意他是直接使$去调用Add方法。)</p><p>jQuery.fn.extend(object); 对jQuery.prototype进得扩展,就是为jQuery类添加“成员函数”。jQuery类的实例可以使用这个“成员函数”。</p><p>比如我们要开发一个插件,做一个特殊的编辑框,当它被点击时,便alert 当前编辑框里的内容。可以这么做:</p><p>1</p><p>$.fn.extend({ &nbsp;</p><p>&nbsp;alertWhileClick:function(){ &nbsp;</p><p>&nbsp; &nbsp; &nbsp;$(this).click(function(){  </p><p>          alert($(this).val()); &nbsp;</p><p>&nbsp; &nbsp; &nbsp; });</p><p>&nbsp; &nbsp; }</p><p>});</p><p>$("#input1").alertWhileClick(); //页面上为:<input id="input1" type="text"/></p><p>$(&quot;#input1&quot;) 为一个jQuery实例,当它调用成员方法 alertWhileClick后,便实现了扩展,每次被点击时它会先弹出目前编辑里的内容。</p><p>(贴码党注:请注意它是使用$("#input1")类的实例去调用的。)</p><p>真实的开发过程中,当然不会做这么小白的插件,事实上jQuery提拱了丰富的操作文档,事件,CSS ,Ajax、效果的方法,结合这些方法,便可以开发出更加 Niubility 的插件。</p>

阅读剩余部分 -

Chrome 开发者工具使用详解

<p>Chrome Web 开发者工具页面结构与样式</p><div id="post-content"><p>浏 览器开发者工具的使用是Web前端开发工程师必须要掌握技能。本文介绍的是chrome自带的开发者工具,首先从页面的结构和样式来介绍。本文的 目的是介绍chrome开发者工具的基础用法。或许你用别的工具,如firebug或IE的开发者工具,但本文介绍的功能,其他对应工具上应该也有相应的 功能,可以帮助你了解对比。</p><h3>浏览器开发者工具功能:</h3><ul> <li>查看元素的html结构</li> <li>概览页面的css,以及某一元素的样式</li> <li>实时编辑css来调样式</li> <li>查看http请求</li> <li>页面中运行js</li> <li>检测页面性能瓶颈,做性能评估</li> <li>查看页面在本地存储的数据 <div style="page-break-after: always;"><span style="display: none;"><!--more-->& nbsp ;</span></div> </li></ul><h3>浏览器开发者工具</h3><p>在开始讲解chrome的开发者工具前,先简单列举一下目前主流浏览器提供的开发者工具</p><h4>chrome 浏览器开发者工具</h4><p>Chrome 开发者工个使用入门</p><p>Chromechrome canary和chromium都带有该工具。</p><h4>safari 浏览器开发者工具</h4><p>Chrome 开发者工具使用基础</p><p>safari是采用Web Inspector 它的更新没有chrome频繁。</p><ul> <li>下载地址:apple.com/safari/</li> <li>打开方式,快捷键:ctrl + alt + i,或者选择菜单“工具”->“显示web检查器”</li> <li>参考文档:developer.apple.com/library/safari/documentation</li> <li>注意:也可以在页面想要查看的元素上,右键点击->查看元素 打开</li></ul><h3>firefox 浏览器开发者工具</h3><p>Chrome 开发者工具使用基础</p><p>Chrome 开发者工具入门</p><p>Firefox现在也自带了开发者工具,它的元素定位效果很好firebug,任然可以以插件的形式安装。</p><h3>IE 浏览器开发者工具</h3><p>Chrome 开发者工具基础</p><ul> <li>下载地址:microsoft.com/ie</li> <li>打开快捷键:F12</li> <li>参考文档:msdn.microsoft.com/en-us/library/dd565628</li> <li>注意:安装 chrome frame,chrome的浏览器开发者工具在IE下也可用</li></ul><h3>opera浏览器开发者工具-dragonfly</h3><p>Chrome 开发者工具使用基础</p><ul> <li>下载地址:opera.com/browser/</li> <li>打开快捷键:ctrl + shift + i</li> <li>参考文档:opera.com/dragonfly/documentation/</li> <li>注意:dragonfly是opera浏览器的一部分</li></ul><p>注意,本教程中是以chrome canary,所以介绍的一些特性在beta和稳定版中可能没有</p><p>在开始介绍元素面板前,先介绍一下头部和底部的一些功能。</p><p>Chrome 开发者工具使用基础</p><p>上图标记点介绍:</p><ul> <li>1关闭开发者工具的按钮</li> <li>2、选择面板的标签项</li> <li>3用户自定义的一个第三方扩展应用-PageSpeed</li> <li>4可以调整开发者工具的布局</li> <li>5显示/隐藏控制台</li> <li>6、点击后可在页面中选择元素</li> <li>7页面js报错信息</li> <li>8、打开/关闭设置面板</li></ul><p>可以根据个人习惯来调整开发者工具的位置点击上图标记4的按钮来切换开发者工具的位置,使它可以如下图那样显示:</p><p>Chrome 开发者工具使用基础</p><p>元素面板展现浏览器渲染后的html结构页面js操作dom后的结果也会实时展现如下截图:</p><p>Chrome 开发者工具使用基础</p><ul> <li>1Html结构树</li> <li>2三角型表示该元素有子元素。三角型的不同方向表示展开或折叠</li> <li>3、元素面包屑,从根节点开始,到选中的当前元素。鼠标滑过相应节点,页面中会高亮相应的节点区域</li> <li>4可拖动的分割线,风格html结构树和css样式信息</li> <li>5、可展开折叠的模块,包括css样式信息和其他</li> <li>6计算后的样式板块-展示选中元素的样式信息</li> <li>7、处理是否显示元素从浏览器中继承过来的样式</li> <li>8显示用户的样式,如页面中引用的styles.css文件,或通过js设置的样式,或者通过开发者工具添加的样式</li> <li>9添加新规则–可以给选择的元素添加样式</li> <li>10触发元素状态,可以设置元素的状态,如hover(用户鼠标滑过元素的效果),actice等。截图中对应的按钮icon表示点击触发后,默认状态是关闭的</li> <li>11可以设置颜色显示格式。可以设置为用户自定义的hex、RGB或HSL</li> <li>12、显示元素的和模型</li></ul><p>元素面板可以查看和编辑元素和其样式打开开发者工具,点击第一个标签项,也可以通过在页面元素上右键点击–>查看元素。有很多用途,可以编辑或添加新元素节点;可以查看元素样式信息,并且可以对样式进行添加、删除等操作</p><h3>DOM 编辑</h3><p>在元素面板中编辑dom很简单删除节点只需简单邮件点击节点 选择 “删除节点”删除父节点,子节点也会被删除。小提示:也可以通过键盘的 delete键 删除选择的节点</p><p>双击节点可以修改节点的类型。如下图,修改p节点事实上,修改节点的开始标签类型,其对应的闭合标签类型也会同时改变。</p><p>Chrome 开发者工具使用基础</p><p>添加属性添加属性,右键点击元素选择“添加属性”光标焦点放到你想要添加属性的元素上,然后输入你想要添加的属性。例如,添加class=“title”通过键盘的tab键可以切换到下一个属性进行编辑。</p><p>编辑属性编辑属性和添加属性一样,在想要编辑的属性或属性值上双击即可编辑修改输入框中会高亮你双击的属性或属性值。</p><p>编辑HTML编辑html只需要选择相应节点右键点击 选择“编辑HTML”</p><p>开发者工具提供了很好的页面元素定位功能。在元素面板中鼠标滑过浏览器渲染的html结构树时,页面中对应的的元素区域会高亮显示这非常方便于在html结构树上定位页面元素。</p><p>Chrome 开发者工具使用基础</p><p>当然如果鼠标滑过的节点对应在页面中的区域不在浏览器的可视区域中就看不到高亮了但这中情况下页面会在元素相应的方位上显示一个提示框。也可以右键点击元素,选择“滚动到可视区域”,则对应元素区域会滚动到浏览器的可视区域中</p><p>Chrome 开发者工具使用基础</p><p>开发者工具还有搜索功能当工具面板获得焦点后,快捷键ctrl+f会打开搜索框。如在输入框中输入“body”就会快速找到页面中的第一个body。</p><p>Chrome 开发者工具使用基础</p><h3>查看样式信息</h3><p>在介绍元素面板右侧的样式面板前,先给一个元素同时设置marginpadding和border,在鼠标滑过该元素时你会看到如下的盒模型。</p><p>Chrome 开发者工具使用基础</p><p>Chrome 开发者工具使用基础</p><p>如果发现有浮动元素显示的和模型有问题,可以通过样式面板区域的“盒模型”模块来查看元素的marginpadding、border 。如果没有学习或了解css盒模型,那么它是一个学习盒模型的好帮手</p><p>它告诉你元素是怎么渲染的,找到问题的原因</p><p>该面板可以查看元素尺寸、padding、border和margin的值,单位是px。鼠标滑过各个区域时页面中会高亮显示相应的区域</p><h3>设置样式信息</h3><p>如下图展开样式面板。在空白处点击,光标会自动定位到输入框开始设置样式输入属性名,按tab键就会自动聚焦到属性值的输入框,然后输入想要的值。</p><div><div id="highlighter_636542"><table> <tbody> <tr> <td> <div> <div>border:1pxsolidgreen</div> </div> </td> </tr> </tbody></table><p>Chrome 开发者工具使用基础</p><p> </p><p>在编辑样式属性名或属性值值时,输入有自动完成功能,可以通过tab键或键盘向右箭头来补全你所选择的当输入的属性值单位为px或百分比时,可以通过键盘的向上、向下键来增加和减小数值,还可以通过组合键shift+向上/向下键以10倍的值增加或减小
编辑颜色值时,可以直接输入颜色值,也可以通过点击颜色小方块弹出的取色面板来选择颜色。还可以按shift点击颜色小方块来切换颜色值的模式</p><p>Chrome 开发者工具使用基础</p><p>可以通过点击+号icon来给某个元素添加样式,例如元素如下:</p><div><table id="highlighter_210790"> <tbody> <tr> <td> <div> <div><h1 id="something">Hello</h1></div> </div> </td> </tr> </tbody></table><div style="clear:both;"> </div></div><p>点击+号icon后会自动添加一条规则如下:</p><div><table id="highlighter_641086"> <tbody> <tr> <td> <div> <div>#something { }</div> </div> </td> </tr> </tbody></table><div style="clear:both;"> </div></div><p>如果html如下:</p><div><table id="highlighter_436812"> <tbody> <tr> <td> <div> <div><h1 class="some-class">Hello</h1></div> </div> </td> </tr> </tbody></table><div style="clear:both;"> </div></div><p>那么所对应的规则如下:</p><div><table id="highlighter_634208"> <tbody> <tr> <td> <div> <div>.some-class { }</div> </div> </td> </tr> </tbody></table><div style="clear:both;"> </div></div><p>若html结构如下:</p><div><table id="highlighter_610826"> <tbody> <tr> <td> <div> <div><h1>Hello</h1></div> </div> </td> </tr> </tbody></table><div style="clear:both;"> </div></div><p>则会增加如下一条:</p><div><table id="highlighter_577405"> <tbody> <tr> <td> <div> <div>.h1{ }</div> </div> </td> </tr> </tbody></table><div style="clear:both;"> </div></div><p>那如果元素有多个class如下:</p><div><table id="highlighter_364908"> <tbody> <tr> <td> <div> <div><h1 class="class1 class2 class3">Hi there</h1></div> </div> </td> </tr> </tbody></table><div style="clear:both;"> </div></div><p>会生成一条如下:</p><div><table id="highlighter_286400"> <tbody> <tr> <td> <div> <div>.class1 .class2 .class3{ }</div> </div> </td> </tr> </tbody></table><div style="clear:both;"> </div></div><p>这些生成的规则也可以编辑</p><p>资源面板展示了页面中的所有资源。下图是资源面板截图:</p><p>Chrome 开发者工具使用基础</p><ul> <li>1资源面板tab;</li> <li>2、左侧栏分类列出页面资源如“框架”、“session存储”,如果前面有箭头点击展开还可以看到更多信息。注意左侧栏的大小是可以调整的;</li> <li>3、页面资源包括字体图片、js、css和页面本身。如果页面中有frame或iframe,展开Frames会看到其对应的frame和iframe页面层次结构更清晰</li> <li>4、数据库显示页面相关的SQL数据库数据信息;</li> <li>5相应IndexedDB 也展示页面的IndexedDB 信息;</li> <li>6、以键/值 形式列表展示本地存储的数据;</li> <li>7以键/值列表显示session存储数据;</li> <li>8、根据域名列举cookie;</li> <li>9显示通过manifest缓存的资源。包括很多信息,如js库文件会显示文件地址大小和类型;</li> <li>10、右侧用来显示每个资源对应的详细信息。</li></ul><p>注意,可以修改编辑资源信息,如编辑本地存储的数据,来调试页面资源</p><h3>查看页面中框架中的内容</h3><p>虽然现在由frame组成的页面越来越少见了,但查看框架内容的方法还是有必要了解的下面截图,是一个由frame组成的页面。</p><p>Chrome 开发者工具使用基础</p><p>每个frame都相关的资源都在一个文件夹下,同样点击展开可以了解页面的资源js、css、图片文件和字体情况。点击选中一个框架,页面中其对应的区域会高亮显示</p><p>注意:不会列出系统已有的,如“arial”“Helvetica”等,只会列出浏览器需要下载安装的</p><p>Chrome 开发者工具使用基础</p><p>如上图,对应的字体会显示在右侧,字体大小会根据右侧区域大小来调整大小</p><p>Chrome 开发者工具使用基础</p><p>如上图,对应图片会在右侧显示,图片大小也会根据右侧区域大小来自适应如果图片有透明,透明部分会显示成棋盘格子来表示透明图片信息,如图片大小、文件大小和图片格式会在图片下面显示。</p><p>点击脚本文件,文件内容会如实显示在右侧。</p><p>Chrome 开发者工具使用基础</p><p>如上图,格式难以阅读,后续教程会详细介绍如何查看格式化后的js代码</p><p>可以查看页面加载的所有css文件。同查看js文件方法一样。但通常不会从这里来查看样式。如下图:</p><p>Chrome 开发者工具使用基础</p><h3>加载失败的资源</h3><p>偶尔,浏览器下载资源失败或者代码出错</p><p>Chrome 开发者工具使用基础</p><p>如上图,出错的资源右侧会显示一个红色标记,数字表示出错的个数,点击资源,右侧会显示出错信息</p><h3>保存和查看资源</h3><p>右键点击资源会出现菜单,如下图:</p><p>Chrome 开发者工具使用基础</p><p>可以选择保存该资源,也可以选择在新标签页中查看,当然也还可以做些别的双击资源会在新标签页中打开资源。</p><h3>cookies </h3><p>查看某个网站的cookie信息如图,访问twitter,然后通过资源面板查看cookie信息。</p><p>Chrome 开发者工具使用基础</p><ul> <li>[name]-字段名如字段名为“remember_checked”,其值为1,这可能说明用户在登陆的时候选择了记住我;</li> <li>[value]-字段所对应的值如“_twitter_sess”所对应的值为一串加密了的session ID;</li> <li>[domain]-cookie所在的域上图的“.twitter.com”表明其子域也是可以访问该cookie的;</li> <li>[path]-跟域相同,设置有效的路径设置为“/”表明允许所在路径下都可以访问cookie;</li> <li>[expires]-浏览器可以删除该cookie的日期;</li> <li>[size]-cookie的大小,单位bytes;</li> <li>[HTTP]-cookie的访问允许HTTP协议这可以防止跨站js获取cookie攻击;</li> <li>[secure]]-只允许加密连接访问cookie,如HTTPS;</li></ul><p>可以通过右键菜单,选择“删除”来删除所选cookie。下图是查看本地存储信息的截图:</p><p>Chrome 开发者工具使用基础</p><p>当用户第一次访问该页面时,浏览器会下载css文件再次刷新该页面感觉快了些,因为它将css存在了本地存储中。厨房水槽应用中有了一些字段,如下:</p><div><div id="highlighter_539025"><table> <tbody> <tr> <td>3a867610-670a-11e1-a90e-4318029d18bb-http://dev.sencha.com/deploy/touch/examples/production/kitchensink/resources/css/app.css</td> </tr> </tbody></table><table border="0" cellpadding="0" cellspacing="0"> <tbody> <tr> <td> <div> <div>/45e6f4ffe818855b26f3dcbfc156025eca58e4f5/code,pre,pre*{font-family:Menlo,Monaco,Courier,monospace}</div> </div> </td> </tr> </tbody></table><p>Steve Souders有一篇文章关于静态资源的本地存储 。在移动设备上应用本地存储对提升性能很有效。</p><h3>缓存应用</h3><p>可以查看浏览缓存了哪些资源。如下图:</p><p>Chrome 开发者工具使用基础</p><ul> <li>[resource]-资源的完整路径。典型的资源包括静态资源和html文件,manifest文件也属于其中;</li> <li>[type]-可以改变。Manifest文件的文件类型是Manifest,其他的manifest文件中定义的文件类型为explicit。Fallback类型的文件是那些需要回调资源文件的回调文件;</li> <li>[size]-资源文件的大小,单位bytes;</li></ul></div></div></div></div></div>

阅读剩余部分 -

c 语言变量类型注释

<p>1 数据类型关键字

A.基本数据类型(5个)</p><p>

void :声明函数无返回值或无参数,声明无类型指针,显式丢弃运算结果


char :字符型类型数据,属于整型数据的一种


int :整型数据,通常为编译器指定的机器字长


float :单精度浮点型数据,属于浮点数据的一种</p><div style="page-break-after: always;"><span style="display: none;"><!--more-->& nbsp ;</span></div><p>

 

double :双精度浮点型数据,属于浮点数据的一种

 

 

 

B .类型修饰关键字(4个)



short :修饰int,短整型数据,可省略被修饰的int。

long :修饰int,长整形数据,可省略被修饰的int。



signed :修饰整型数据,有符号数据类型

 
unsigned :修饰整型数据,无符号数据类型



C .复杂类型关键字(5个)


struct :结构体声明



union :共用体声明


enum :枚举声明


typedef :声明类型别名


sizeof :得到特定类型或特定类型变量的大小


D .存储级别关键字(6个)



auto :指定为自动变量,由编译器自动分配及释放。通常在栈上分配



static :指定为静态变量,分配在静态变量区,修饰函数时,指定函数作用域为文件内部



register :指定为寄存器变量,建议编译器将变量存储到寄存器中使用,也可以修饰函数形参,建议编译器通过寄存器而不是堆栈传递参数

 

extern :指定对应变量为外部变量,即标示变量或者函数的定义在别的文件中,提示编译器遇到此变量和函数时在其他模块中寻找其定义。



const:与volatile合称“cv特性”,指定变量不可被当前线程/进程改变(但有可能被系统或其他线程/进程改变)

volatile:与const合称“cv特性”,指定变量的值有可能会被系统或其他进程/线程改变,强制编译器每次从内存中取得该变量的值



2 流程控制关键字



A .跳转结构(4个)


return :用在函数体中,返回特定值(或者是void值,即不返回值)

continue :结束当前循环,开始下一轮循环

break :跳出当前循环或switch结构

goto :无条件跳转语句


 

B .分支结构(5个)



if :条件语句,后面不需要放分号



else :条件语句否定分支(与if连用)


switch :开关语句(多重分支语句)


case :开关语句中的分支标记


default :开关语句中的“其他”分支,可选。

 


C .循环结构(3个)


for:for 循环结构,for(1;2;3)4;的执行顺序为1->2->4->3->2...循环,其中2为循环条件。在整个for循环过 程中,表达式1只计算一次,表达式2和表达式3则可能计算多次,也可能一次也不计算。循环体可能多次执行,也可能一次都不执行。


do :do循环结构,do 1 while(2); 的执行顺序是1->2->1...循环,2为循环条件

while :while循环结构,while(1) 2; 的执行顺序是1->2->1...循环,1为循环条件</p>

阅读剩余部分 -

随机文章

最近回复

分类

其它

友情连接

推广链接